當前位置: 首頁>>代碼示例>>Java>>正文


Java Intersection.update方法代碼示例

本文整理匯總了Java中com.yahoo.sketches.theta.Intersection.update方法的典型用法代碼示例。如果您正苦於以下問題:Java Intersection.update方法的具體用法?Java Intersection.update怎麽用?Java Intersection.update使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.yahoo.sketches.theta.Intersection的用法示例。


在下文中一共展示了Intersection.update方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: evaluate

import com.yahoo.sketches.theta.Intersection; //導入方法依賴的package包/類
/**
 * Main logic called by hive if sketchSize is also passed in. Computes the
 * intersection of two sketches of same or different column.
 *
 * @param firstSketchBytes
 *          first sketch to be intersected.
 * @param secondSketchBytes
 *          second sketch to be intersected.
 * @param hashSeed
 *          Only required if input sketches were constructed using an update seed that was not the default.
 * @return resulting sketch of intersection.
 */
public BytesWritable evaluate(final BytesWritable firstSketchBytes,
    final BytesWritable secondSketchBytes, final long hashSeed) {
  Sketch firstSketch = null;
  if (firstSketchBytes != null && firstSketchBytes.getLength() > 0) {
    firstSketch = Sketch.wrap(Memory.wrap(firstSketchBytes.getBytes()), hashSeed);
  }

  Sketch secondSketch = null;
  if (secondSketchBytes != null && secondSketchBytes.getLength() > 0) {
    secondSketch = Sketch.wrap(Memory.wrap(secondSketchBytes.getBytes()), hashSeed);
  }

  final Intersection intersect = SetOperation.builder().setSeed(hashSeed).buildIntersection();
  intersect.update(firstSketch);
  intersect.update(secondSketch);
  return new BytesWritable(intersect.getResult().toByteArray());
}
 
開發者ID:DataSketches,項目名稱:sketches-hive,代碼行數:30,代碼來源:IntersectSketchUDF.java

示例2: updateIntersection

import com.yahoo.sketches.theta.Intersection; //導入方法依賴的package包/類
/*************************************************************************************************
 * Updates an intersection from a bag of sketches
 *
 * @param bag A bag of sketchTuples.
 * @param intersection The intersection to update
 * @param seed to check against incoming sketches
 */
private static void updateIntersection(final DataBag bag, final Intersection intersection,
    final long seed) {
  //Bag is not empty. process each innerTuple in the bag
  for (Tuple innerTuple : bag) {
    //validate the inner Tuples
    final Object f0 = extractFieldAtIndex(innerTuple, 0);
    if (f0 == null) {
    continue;
  }
    final Byte type = extractTypeAtIndex(innerTuple, 0);
  // add only the first field of the innerTuple to the intersection
  if (type == DataType.BYTEARRAY) {
    final DataByteArray dba = (DataByteArray) f0;
    final Memory srcMem = Memory.wrap(dba.get());
    final Sketch sketch = Sketch.wrap(srcMem, seed);
    intersection.update(sketch);
  }
  else {
    throw new IllegalArgumentException(
        "Field type was not DataType.BYTEARRAY: " + type);
    }
  }
}
 
開發者ID:DataSketches,項目名稱:sketches-pig,代碼行數:31,代碼來源:Intersect.java

示例3: exec

import com.yahoo.sketches.theta.Intersection; //導入方法依賴的package包/類
@Override //IntermediateFinal exec
public Tuple exec(final Tuple inputTuple) throws IOException { //throws is in API

  final Intersection intersection = SetOperation.builder().setSeed(mySeed_).buildIntersection();
  final DataBag outerBag = extractBag(inputTuple); //InputTuple.bag0
  if (outerBag == null) {  //must have non-empty outer bag at field 0.
    return myEmptyCompactOrderedSketchTuple_;
  }
  //Bag is not empty.

  for (Tuple dataTuple : outerBag) {
    final Object f0 = extractFieldAtIndex(dataTuple, 0); //inputTuple.bag0.dataTupleN.f0
    //must have non-null field zero
    if (f0 == null) {
      continue; //go to next dataTuple if there is one.  If none, exception is thrown.
    }
    //f0 is not null
    if (f0 instanceof DataBag) {
      final DataBag innerBag = (DataBag)f0; //inputTuple.bag0.dataTupleN.f0:bag
      if (innerBag.size() == 0) {
        continue; //go to next dataTuple if there is one.  If none, exception is thrown.
      }
      //If field 0 of a dataTuple is again a Bag all tuples of this inner bag
      // will be passed into the union.
      //It is due to system bagged outputs from multiple mapper Initial functions.
      //The Intermediate stage was bypassed.
      updateIntersection(innerBag, intersection, mySeed_); //process all tuples of innerBag

    }
    else if (f0 instanceof DataByteArray) { //inputTuple.bag0.dataTupleN.f0:DBA
      //If field 0 of a dataTuple is a DataByteArray we assume it is a sketch from a prior call
      //It is due to system bagged outputs from multiple mapper Intermediate functions.
      // Each dataTuple.DBA:sketch will merged into the union.
      final DataByteArray dba = (DataByteArray) f0;
      final Memory srcMem = Memory.wrap(dba.get());
      final Sketch sketch = Sketch.wrap(srcMem, mySeed_);
      intersection.update(sketch);
    }
    else { // we should never get here.
      throw new IllegalArgumentException("dataTuple.Field0: Is not a DataByteArray: "
          + f0.getClass().getName());
    }
  }

  final CompactSketch compactSketch = intersection.getResult(true, null);
  return compactOrderedSketchToTuple(compactSketch);
}
 
開發者ID:DataSketches,項目名稱:sketches-pig,代碼行數:48,代碼來源:Intersect.java


注:本文中的com.yahoo.sketches.theta.Intersection.update方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。