Package org.apache.lucene.util.bkd
Class BKDReader
- java.lang.Object
- 
- org.apache.lucene.index.PointValues
- 
- org.apache.lucene.util.bkd.BKDReader
 
 
- 
- All Implemented Interfaces:
- Accountable
 
 public final class BKDReader extends PointValues implements Accountable Handles intersection of an multi-dimensional shape in byte[] space with a block KD-tree previously written withBKDWriter.- WARNING: This API is experimental and might change in incompatible ways in the next release.
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description classBKDReader.IndexTreeUsed to walk the in-heap indexstatic classBKDReader.IntersectStateUsed to track all state for a single call tointersect(org.apache.lucene.index.PointValues.IntersectVisitor).- 
Nested classes/interfaces inherited from class org.apache.lucene.index.PointValuesPointValues.IntersectVisitor, PointValues.Relation
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected intpackedBytesLengthprotected intpackedIndexBytesLength- 
Fields inherited from class org.apache.lucene.index.PointValuesMAX_DIMENSIONS, MAX_NUM_BYTES
 
- 
 - 
Constructor SummaryConstructors Constructor Description BKDReader(IndexInput in)Caller must pre-seek the providedIndexInputto the index location thatBKDWriter.finish(org.apache.lucene.store.IndexOutput)returned
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description longestimatePointCount(PointValues.IntersectVisitor visitor)Estimate the number of points that would be visited byPointValues.intersect(org.apache.lucene.index.PointValues.IntersectVisitor)with the givenPointValues.IntersectVisitor.intgetBytesPerDimension()Returns the number of bytes per dimensionintgetDocCount()Returns the total number of documents that have indexed at least one point.BKDReader.IntersectStategetIntersectState(PointValues.IntersectVisitor visitor)Create a newBKDReader.IntersectStatebyte[]getMaxPackedValue()Returns maximum value for each dimension, packed, or null ifPointValues.size(org.apache.lucene.index.IndexReader, java.lang.String)is0byte[]getMinPackedValue()Returns minimum value for each dimension, packed, or null ifPointValues.size(org.apache.lucene.index.IndexReader, java.lang.String)is0intgetNumDataDimensions()Returns how many data dimensions are represented in the valuesintgetNumIndexDimensions()Returns how many dimensions are used for the indexvoidintersect(PointValues.IntersectVisitor visitor)Finds all documents and points matching the provided visitor.booleanisLeafNode(int nodeID)longramBytesUsed()Return the memory usage of this object in bytes.longsize()Returns the total number of indexed points across all documents.voidvisitLeafBlockValues(BKDReader.IndexTree index, BKDReader.IntersectState state)Visits all docIDs and packed values in a single leaf block- 
Methods inherited from class org.apache.lucene.index.PointValuesgetDocCount, getMaxPackedValue, getMinPackedValue, size
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.lucene.util.AccountablegetChildResources
 
- 
 
- 
- 
- 
Constructor Detail- 
BKDReaderpublic BKDReader(IndexInput in) throws IOException Caller must pre-seek the providedIndexInputto the index location thatBKDWriter.finish(org.apache.lucene.store.IndexOutput)returned- Throws:
- IOException
 
 
- 
 - 
Method Detail- 
intersectpublic void intersect(PointValues.IntersectVisitor visitor) throws IOException Description copied from class:PointValuesFinds all documents and points matching the provided visitor. This method does not enforce live documents, so it's up to the caller to test whether each document is deleted, if necessary.- Specified by:
- intersectin class- PointValues
- Throws:
- IOException
 
 - 
estimatePointCountpublic long estimatePointCount(PointValues.IntersectVisitor visitor) Description copied from class:PointValuesEstimate the number of points that would be visited byPointValues.intersect(org.apache.lucene.index.PointValues.IntersectVisitor)with the givenPointValues.IntersectVisitor. This should run many times faster thanPointValues.intersect(IntersectVisitor).- Specified by:
- estimatePointCountin class- PointValues
- See Also:
- DocIdSetIterator.cost()
 
 - 
getIntersectStatepublic BKDReader.IntersectState getIntersectState(PointValues.IntersectVisitor visitor) Create a newBKDReader.IntersectState
 - 
visitLeafBlockValuespublic void visitLeafBlockValues(BKDReader.IndexTree index, BKDReader.IntersectState state) throws IOException Visits all docIDs and packed values in a single leaf block- Throws:
- IOException
 
 - 
ramBytesUsedpublic long ramBytesUsed() Description copied from interface:AccountableReturn the memory usage of this object in bytes. Negative values are illegal.- Specified by:
- ramBytesUsedin interface- Accountable
 
 - 
getMinPackedValuepublic byte[] getMinPackedValue() Description copied from class:PointValuesReturns minimum value for each dimension, packed, or null ifPointValues.size(org.apache.lucene.index.IndexReader, java.lang.String)is0- Specified by:
- getMinPackedValuein class- PointValues
 
 - 
getMaxPackedValuepublic byte[] getMaxPackedValue() Description copied from class:PointValuesReturns maximum value for each dimension, packed, or null ifPointValues.size(org.apache.lucene.index.IndexReader, java.lang.String)is0- Specified by:
- getMaxPackedValuein class- PointValues
 
 - 
getNumDataDimensionspublic int getNumDataDimensions() Description copied from class:PointValuesReturns how many data dimensions are represented in the values- Specified by:
- getNumDataDimensionsin class- PointValues
 
 - 
getNumIndexDimensionspublic int getNumIndexDimensions() Description copied from class:PointValuesReturns how many dimensions are used for the index- Specified by:
- getNumIndexDimensionsin class- PointValues
 
 - 
getBytesPerDimensionpublic int getBytesPerDimension() Description copied from class:PointValuesReturns the number of bytes per dimension- Specified by:
- getBytesPerDimensionin class- PointValues
 
 - 
sizepublic long size() Description copied from class:PointValuesReturns the total number of indexed points across all documents.- Specified by:
- sizein class- PointValues
 
 - 
getDocCountpublic int getDocCount() Description copied from class:PointValuesReturns the total number of documents that have indexed at least one point.- Specified by:
- getDocCountin class- PointValues
 
 - 
isLeafNodepublic boolean isLeafNode(int nodeID) 
 
- 
 
-