All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.yahoo.sketches.theta.AnotB Maven / Gradle / Ivy

/*
 * Copyright 2015-16, Yahoo! Inc.
 * Licensed under the terms of the Apache License 2.0. See LICENSE file at the project root for terms.
 */

package com.yahoo.sketches.theta;

import com.yahoo.memory.Memory;

/**
 * The API for the set difference operation A and not B operations.
 * This is a stateless operation. However, to make the API
 * more consistent with the other set operations the intended use is:
 * 

 * AnotB aNotB = SetOperationBuilder.buildAnotB();
 * aNotB.update(SketchA, SketchB); //Called only once.
 * CompactSketch result = aNotB.getResult();
 * 
* *

Calling the update function a second time essentially clears the internal state and updates * with the new pair of sketches. * * @author Lee Rhodes */ public interface AnotB { /** * Perform A-and-not-B set operation on the two given sketches. * A null sketch is interpreted as an empty sketch. * * @param a The incoming sketch for the first argument * @param b The incoming sketch for the second argument */ void update(Sketch a, Sketch b); /** * Gets the result of this operation as a CompactSketch of the chosen form * @param dstOrdered * See Destination Ordered * * @param dstMem * See Destination Memory. * * @return the result of this operation as a CompactSketch of the chosen form */ CompactSketch getResult(boolean dstOrdered, Memory dstMem); /** * Gets the result of this operation as an ordered CompactSketch on the Java heap * @return the result of this operation as an ordered CompactSketch on the Java heap */ CompactSketch getResult(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy