Frequent Items Sketch Java Example

import java.io.FileInputStream;
import java.io.FileOutputStream;
import org.apache.datasketches.memory.Memory;
import org.apache.datasketches.ArrayOfStringsSerDe;
import org.apache.datasketches.frequencies.ErrorType;
import org.apache.datasketches.frequencies.ItemsSketch;

// simplified file operations and no error handling for clarity

// this section generates two sketches and serializes them into files
{
  ItemsSketch<String> sketch1 = new ItemsSketch<String>(64);
  sketch1.update("a");
  sketch1.update("a");
  sketch1.update("b");
  sketch1.update("c");
  sketch1.update("a");
  sketch1.update("d");
  sketch1.update("a");
  FileOutputStream out1 = new FileOutputStream("FrequentStringsSketch1.bin");
  out1.write(sketch1.toByteArray(new ArrayOfStringsSerDe()));
  out1.close();
  
  ItemsSketch<String> sketch2 = new ItemsSketch<String>(64);
  sketch2.update("e");
  sketch2.update("a");
  sketch2.update("f");
  sketch2.update("f");
  sketch2.update("f");
  sketch2.update("g");
  sketch2.update("a");
  sketch2.update("f");
  FileOutputStream out2 = new FileOutputStream("FrequentStringsSketch2.bin");
  out2.write(sketch2.toByteArray(new ArrayOfStringsSerDe()));
  out2.close();
}

// this section deserializes the sketches, produces a union and prints the result
{
  FileInputStream in1 = new FileInputStream("FrequentStringsSketch1.bin");
  byte[] bytes1 = new byte[in1.available()];
  in1.read(bytes1);
  in1.close();
  ItemsSketch<String> sketch1 = ItemsSketch.getInstance(Memory.wrap(bytes1), new ArrayOfStringsSerDe());

  FileInputStream in2 = new FileInputStream("FrequentStringsSketch2.bin");
  byte[] bytes2 = new byte[in2.available()];
  in2.read(bytes2);
  in2.close();
  ItemsSketch<String> sketch2 = ItemsSketch.getInstance(Memory.wrap(bytes2), new ArrayOfStringsSerDe());

  // we could merge sketch2 into sketch1 or the other way around
  // this is an example of using a new sketch as a union and keeping the original sketches intact
  ItemsSketch<String> union = new ItemsSketch<String>(64);
  union.merge(sketch1);
  union.merge(sketch2);

  ItemsSketch.Row<String>[] items = union.getFrequentItems(ErrorType.NO_FALSE_POSITIVES);
  System.out.println("Frequent items: " + items.length);
  System.out.println(ItemsSketch.Row.getRowHeader());
  for (ItemsSketch.Row<String> row: items) {
    System.out.println(row.toString());
  }
}

Output:
Frequent items: 7
       Est          UB          LB Item
         6           6           6 a
         4           4           4 f
         1           1           1 d
         1           1           1 b
         1           1           1 e
         1           1           1 c
         1           1           1 g