Package org.apache.lucene.util
Class DocIdSetBuilder
- java.lang.Object
-
- org.apache.lucene.util.DocIdSetBuilder
-
public final class DocIdSetBuilder extends java.lang.ObjectA builder ofDocIdSets. At first it uses a sparse structure to gather documents, and then upgrades to a non-sparse bit set once enough hits match. To add documents, you first need to callgrow(int)in order to reserve space, and then callDocIdSetBuilder.BulkAdder.add(int)on the returnedDocIdSetBuilder.BulkAdder.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private static classDocIdSetBuilder.Bufferprivate static classDocIdSetBuilder.BufferAdderstatic classDocIdSetBuilder.BulkAdderUtility class to efficiently add many docs in one go.private static classDocIdSetBuilder.FixedBitSetAdder
-
Field Summary
Fields Modifier and Type Field Description private DocIdSetBuilder.BulkAdderadderprivate FixedBitSetbitSetprivate java.util.List<DocIdSetBuilder.Buffer>buffersprivate longcounterprivate intmaxDoc(package private) booleanmultivalued(package private) doublenumValuesPerDocprivate intthresholdprivate inttotalAllocated
-
Constructor Summary
Constructors Constructor Description DocIdSetBuilder(int maxDoc)Create a builder that can contain doc IDs between0andmaxDoc.DocIdSetBuilder(int maxDoc, int docCount, long valueCount)DocIdSetBuilder(int maxDoc, PointValues values, java.lang.String field)Create aDocIdSetBuilderinstance that is optimized for accumulating docs that match the givenPointValues.DocIdSetBuilder(int maxDoc, Terms terms)Create aDocIdSetBuilderinstance that is optimized for accumulating docs that match the givenTerms.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidadd(DocIdSetIterator iter)Add the content of the providedDocIdSetIteratorto this builder.private DocIdSetBuilder.BufferaddBuffer(int len)private intadditionalCapacity(int numDocs)DocIdSetbuild()Build aDocIdSetfrom the accumulated doc IDs.private static DocIdSetBuilder.Bufferconcat(java.util.List<DocIdSetBuilder.Buffer> buffers)Concatenate the buffers in any order, leaving at least one empty slot in the end NOTE: this method might reuse one of the arraysprivate static intdedup(int[] arr, int length)private voidensureBufferCapacity(int numDocs)DocIdSetBuilder.BulkAddergrow(int numDocs)Reserve space and return aDocIdSetBuilder.BulkAdderobject that can be used to add up tonumDocsdocuments.private voidgrowBuffer(DocIdSetBuilder.Buffer buffer, int additionalCapacity)private static booleannoDups(int[] a, int len)private voidupgradeToBitSet()
-
-
-
Field Detail
-
maxDoc
private final int maxDoc
-
threshold
private final int threshold
-
multivalued
final boolean multivalued
-
numValuesPerDoc
final double numValuesPerDoc
-
buffers
private java.util.List<DocIdSetBuilder.Buffer> buffers
-
totalAllocated
private int totalAllocated
-
bitSet
private FixedBitSet bitSet
-
counter
private long counter
-
adder
private DocIdSetBuilder.BulkAdder adder
-
-
Constructor Detail
-
DocIdSetBuilder
public DocIdSetBuilder(int maxDoc)
Create a builder that can contain doc IDs between0andmaxDoc.
-
DocIdSetBuilder
public DocIdSetBuilder(int maxDoc, Terms terms) throws java.io.IOExceptionCreate aDocIdSetBuilderinstance that is optimized for accumulating docs that match the givenTerms.- Throws:
java.io.IOException
-
DocIdSetBuilder
public DocIdSetBuilder(int maxDoc, PointValues values, java.lang.String field) throws java.io.IOExceptionCreate aDocIdSetBuilderinstance that is optimized for accumulating docs that match the givenPointValues.- Throws:
java.io.IOException
-
DocIdSetBuilder
DocIdSetBuilder(int maxDoc, int docCount, long valueCount)
-
-
Method Detail
-
add
public void add(DocIdSetIterator iter) throws java.io.IOException
Add the content of the providedDocIdSetIteratorto this builder. NOTE: if you need to build aDocIdSetout of a singleDocIdSetIterator, you should rather useRoaringDocIdSet.Builder.- Throws:
java.io.IOException
-
grow
public DocIdSetBuilder.BulkAdder grow(int numDocs)
Reserve space and return aDocIdSetBuilder.BulkAdderobject that can be used to add up tonumDocsdocuments.
-
ensureBufferCapacity
private void ensureBufferCapacity(int numDocs)
-
additionalCapacity
private int additionalCapacity(int numDocs)
-
addBuffer
private DocIdSetBuilder.Buffer addBuffer(int len)
-
growBuffer
private void growBuffer(DocIdSetBuilder.Buffer buffer, int additionalCapacity)
-
upgradeToBitSet
private void upgradeToBitSet()
-
concat
private static DocIdSetBuilder.Buffer concat(java.util.List<DocIdSetBuilder.Buffer> buffers)
Concatenate the buffers in any order, leaving at least one empty slot in the end NOTE: this method might reuse one of the arrays
-
dedup
private static int dedup(int[] arr, int length)
-
noDups
private static boolean noDups(int[] a, int len)
-
-