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

org.apache.datasketches.theta.AnotB Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

package org.apache.datasketches.theta;

import org.apache.datasketches.Family;
import org.apache.datasketches.memory.WritableMemory;

/**
 * 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. * *

As an alternative, one can use the aNotB method that returns the result immediately. * * @author Lee Rhodes */ public abstract class AnotB extends SetOperation { @Override public Family getFamily() { return Family.A_NOT_B; } /** * 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 */ public abstract CompactSketch getResult(); /** * Gets the result of this set operation as a CompactSketch of the chosen form * @param dstOrdered * See Destination Ordered. * * @param dstMem * See Destination Memory. * * @return the result of this set operation as a CompactSketch of the chosen form */ public abstract CompactSketch getResult(boolean dstOrdered, WritableMemory dstMem); /** * 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 */ public abstract void update(Sketch a, Sketch b); /** * Perform A-and-not-B set operation on the two given sketches and return the result as an * ordered CompactSketch on the heap. * @param a The incoming sketch for the first argument * @param b The incoming sketch for the second argument * @return an ordered CompactSketch on the heap */ public CompactSketch aNotB(final Sketch a, final Sketch b) { return aNotB(a, b, true, null); } /** * Perform A-and-not-B set operation on the two given sketches and return the result as a * CompactSketch. * @param a The incoming sketch for the first argument * @param b The incoming sketch for the second argument * @param dstOrdered * See Destination Ordered. * @param dstMem * See Destination Memory. * @return the result as a CompactSketch. */ public abstract CompactSketch aNotB(Sketch a, Sketch b, boolean dstOrdered, WritableMemory dstMem); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy