Package org.apache.lucene.spatial.prefix
Class PrefixTreeStrategy
java.lang.Object
org.apache.lucene.spatial.SpatialStrategy
org.apache.lucene.spatial.prefix.PrefixTreeStrategy
- Direct Known Subclasses:
- RecursivePrefixTreeStrategy,- TermQueryPrefixTreeStrategy
An abstract SpatialStrategy based on 
SpatialPrefixTree. The two subclasses are RecursivePrefixTreeStrategy and TermQueryPrefixTreeStrategy. This strategy is most
 effective as a fast approximate spatial search filter.
 Characteristics: 
 
- Can index any shape; however only RecursivePrefixTreeStrategycan effectively search non-point shapes.
- Can index a variable number of shapes per field value. This strategy can do it via multiple
       calls to createIndexableFields(org.locationtech.spatial4j.shape.Shape)for a document or by giving it some sort of Shape aggregate (e.g. JTS WKT MultiPoint). The shape's boundary is approximated to a grid precision.
- Can query with any shape. The shape's boundary is approximated to a grid precision.
- Only SpatialOperation.Intersectsis supported. If only points are indexed then this is effectively equivalent to IsWithin.
- The strategy supports makeDistanceValueSource(org.locationtech.spatial4j.shape.Point,double)even for multi-valued data, so long as the indexed data is all points; the behavior is undefined otherwise. However, it will likely be removed in the future in lieu of using another strategy with a more scalable implementation. Use of this call is the only circumstance in which a cache is used. The cache is simple but as such it doesn't scale to large numbers of points nor is it real-time-search friendly.
Implementation:
The SpatialPrefixTree does most of the work, for example returning a list of terms
 representing grids of various sizes for a supplied shape. An important configuration item is
 setDistErrPct(double) which balances shape precision against scalability. See those
 javadocs.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionclassTokenstream for indexing cells of a shape
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected intprotected doublestatic final FieldTypeprotected final SpatialPrefixTreeprotected booleanFields inherited from class org.apache.lucene.spatial.SpatialStrategyctx
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptioncalcFacets(IndexReaderContext context, Bits topAcceptDocs, org.locationtech.spatial4j.shape.Shape inputShape, int facetLevel, int maxCells) Computes spatial facets in two dimensions as a grid of numbers.createCellIteratorToIndex(org.locationtech.spatial4j.shape.Shape shape, int detailLevel, Iterator<Cell> reuse) Field[]createIndexableFields(org.locationtech.spatial4j.shape.Shape shape) Returns the IndexableField(s) from theshapethat are to be added to theDocument.Field[]createIndexableFields(org.locationtech.spatial4j.shape.Shape shape, double distErr) TurnsSpatialPrefixTree.getTreeCellIterator(Shape, int)into aTokenStream.Field[]createIndexableFields(org.locationtech.spatial4j.shape.Shape shape, int detailLevel) doublegetGrid()protected booleanisPointShape(org.locationtech.spatial4j.shape.Shape shape) Returns true if theshapeis aPoint.booleanmakeDistanceValueSource(org.locationtech.spatial4j.shape.Point queryPoint, double multiplier) Make a ValueSource returning the distance between the center of the indexed shape andqueryPoint.protected CellToBytesRefIteratorvoidsetDefaultFieldValuesArrayLen(int defaultFieldValuesArrayLen) A memory hint used bySpatialStrategy.makeDistanceValueSource(org.locationtech.spatial4j.shape.Point)for how big the initial size of each Document's array should be.voidsetDistErrPct(double distErrPct) The default measure of shape precision affecting shapes at index and query times.voidsetPointsOnly(boolean pointsOnly) True if only indexed points shall be supported.Methods inherited from class org.apache.lucene.spatial.SpatialStrategygetFieldName, getSpatialContext, makeDistanceValueSource, makeQuery, makeRecipDistanceValueSource, toString
- 
Field Details- 
grid
- 
defaultFieldValuesArrayLenprotected int defaultFieldValuesArrayLen
- 
distErrPctprotected double distErrPct
- 
pointsOnlyprotected boolean pointsOnly
- 
FIELD_TYPE
 
- 
- 
Constructor Details- 
PrefixTreeStrategy
 
- 
- 
Method Details- 
getGrid
- 
setDefaultFieldValuesArrayLenpublic void setDefaultFieldValuesArrayLen(int defaultFieldValuesArrayLen) A memory hint used bySpatialStrategy.makeDistanceValueSource(org.locationtech.spatial4j.shape.Point)for how big the initial size of each Document's array should be. The default is 2. Set this to slightly more than the default expected number of points per document.
- 
getDistErrPctpublic double getDistErrPct()
- 
setDistErrPctpublic void setDistErrPct(double distErrPct) The default measure of shape precision affecting shapes at index and query times. Points don't use this as they are always indexed at the configured maximum precision (SpatialPrefixTree.getMaxLevels()); this applies to all other shapes. Specific shapes at index and query time can use something different than this default value. If you don't set a default then the default isSpatialArgs.DEFAULT_DISTERRPCT-- 2.5%.- See Also:
 
- 
isPointsOnlypublic boolean isPointsOnly()
- 
setPointsOnlypublic void setPointsOnly(boolean pointsOnly) True if only indexed points shall be supported. There are no "leafs" in such a case, except those at maximum precision.
- 
createIndexableFieldsDescription copied from class:SpatialStrategyReturns the IndexableField(s) from theshapethat are to be added to theDocument. These fields are expected to be marked as indexed and not stored.Note: If you want to store the shape as a string for retrieval in search results, you could add it like this: document.add(new StoredField(fieldName,ctx.toString(shape))); The particular string representation used doesn't matter to the Strategy since it doesn't use it.- Specified by:
- createIndexableFieldsin class- SpatialStrategy
- Returns:
- Not null nor will it have null elements.
 
- 
createIndexableFieldsTurnsSpatialPrefixTree.getTreeCellIterator(Shape, int)into aTokenStream.
- 
createIndexableFields
- 
tokenStream
- 
newCellToBytesRefIterator
- 
createCellIteratorToIndex
- 
makeDistanceValueSourcepublic DoubleValuesSource makeDistanceValueSource(org.locationtech.spatial4j.shape.Point queryPoint, double multiplier) Description copied from class:SpatialStrategyMake a ValueSource returning the distance between the center of the indexed shape andqueryPoint. If there are multiple indexed shapes then the closest one is chosen. The result is multiplied bymultiplier, which conveniently is used to get the desired units.- Specified by:
- makeDistanceValueSourcein class- SpatialStrategy
 
- 
calcFacetspublic HeatmapFacetCounter.Heatmap calcFacets(IndexReaderContext context, Bits topAcceptDocs, org.locationtech.spatial4j.shape.Shape inputShape, int facetLevel, int maxCells) throws IOException Computes spatial facets in two dimensions as a grid of numbers. The data is often visualized as a so-called "heatmap".- Throws:
- IOException
- See Also:
 
- 
isPointShapeprotected boolean isPointShape(org.locationtech.spatial4j.shape.Shape shape) Returns true if theshapeis aPoint. For custom spatial contexts, it may make sense to have certain other shapes return true.- WARNING: This API is experimental and might change in incompatible ways in the next release.
 
 
-