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

com.yahoo.sketches.quantiles.DoublesUnion 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.quantiles;

import com.yahoo.memory.Memory;

/**
 * The API for Union operations for quantiles DoublesSketches
 *
 * @author Lee Rhodes
 */
public abstract class DoublesUnion {

  /**
   * Returns a new UnionBuilder
   * @return a new UnionBuilder
   */
  public static final DoublesUnionBuilder builder() {
    return new DoublesUnionBuilder();
  }

  /**
   * Returns true if this union is empty
   * @return true if this union is empty
   */
  public abstract boolean isEmpty();

  /**
   * Returns true if this union is direct
   * @return true if this union is direct
   */
  public abstract boolean isDirect();

  /**
   * Returns the configured maxK of this Union.
   * @return the configured maxK of this Union.
   */
  public abstract int getMaxK();

  /**
   * Returns the effective k of this Union.
   * @return the effective k of this Union.
   */
  public abstract int getEffectiveK();


  /**
   * Iterative union operation, which means this method can be repeatedly called.
   * Merges the given sketch into this union object.
   * The given sketch is not modified.
   * It is required that the ratio of the two K values be a power of 2.
   * This is easily satisfied if each of the K values is already a power of 2.
   * If the given sketch is null or empty it is ignored.
   *
   * 

It is required that the results of the union operation, which can be obtained at any time, * is obtained from {@link #getResult() }. * * @param sketchIn the sketch to be merged into this one. */ public abstract void update(DoublesSketch sketchIn); /** * Iterative union operation, which means this method can be repeatedly called. * Merges the given Memory image of a DoublesSketch into this union object. * The given Memory object is not modified and a link to it is not retained. * It is required that the ratio of the two K values be a power of 2. * This is easily satisfied if each of the K values is already a power of 2. * If the given sketch is null or empty it is ignored. * *

It is required that the results of the union operation, which can be obtained at any time, * is obtained from {@link #getResult() }. * * @param mem Memory image of sketch to be merged */ public abstract void update(Memory mem); /** * Update this union with the given double (or float) data Item. * * @param dataItem The given double datum. */ public abstract void update(double dataItem); /** * Gets the result of this Union operation as a copy of the internal state. * This enables further union update operations on this state. * @return the result of this Union operation */ public abstract DoublesSketch getResult(); /** * Gets the result of this Union operation (without a copy) and resets this Union to the * virgin state. * * @return the result of this Union operation and reset. */ public abstract DoublesSketch getResultAndReset(); /** * Resets this Union to a virgin state. */ public abstract void reset(); // /** // * Serialize this union as an ordered, non-compact byte array of a DoublesSketch. // * @return this union as an ordered, non-compact byte array of a DoublesSketch. // */ // public abstract byte[] toByteArray(); /** * Returns summary information about the backing sketch. */ @Override public abstract String toString(); /** * Returns summary information about the backing sketch. Used for debugging. * @param sketchSummary if true includes sketch summary * @param dataDetail if true includes data detail * @return summary information about the sketch. */ public abstract String toString(boolean sketchSummary, boolean dataDetail); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy