Package org.apache.lucene.facet.range
Class LongRangeFacetCounts
java.lang.Object
org.apache.lucene.facet.Facets
org.apache.lucene.facet.FacetCountsWithFilterQuery
org.apache.lucene.facet.range.LongRangeFacetCounts
Facets implementation that computes counts for dynamic long ranges. Use this for
 dimensions that change in real-time (e.g. a relative time based dimension like "Past day", "Past
 2 days", etc.) or that change for each request (e.g. distance from the user's location, "< 1
 km", "< 2 km", etc.).- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected int[]Counts.protected final StringOur field name.protected final Range[]Ranges passed to constructor.protected intTotal number of hits.Fields inherited from class org.apache.lucene.facet.FacetCountsWithFilterQueryfastMatchQuery
- 
Constructor SummaryConstructorsConstructorDescriptionLongRangeFacetCounts(String field, FacetsCollector hits, LongRange... ranges) CreateLongRangeFacetCountsusing long values from the specified field.LongRangeFacetCounts(String field, MultiLongValuesSource valuesSource, FacetsCollector hits, LongRange... ranges) CreateLongRangeFacetCounts, using the providedMultiLongValuesSourceif non-null.LongRangeFacetCounts(String field, MultiLongValuesSource valuesSource, FacetsCollector hits, Query fastMatchQuery, LongRange... ranges) CreateLongRangeFacetCounts, using the providedMultiLongValuesSourceif non-null.LongRangeFacetCounts(String field, LongValuesSource valueSource, FacetsCollector hits, LongRange... ranges) CreateLongRangeFacetCounts, using the providedLongValuesSourceif non-null.LongRangeFacetCounts(String field, LongValuesSource valueSource, FacetsCollector hits, Query fastMatchQuery, LongRange... ranges) CreateLongRangeFacetCounts, using the providedLongValuesSourceif non-null.
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidcount(String field, List<FacetsCollector.MatchingDocs> matchingDocs) Counts from the provided field.getAllChildren(String dim, String... path) Returns all child labels with non-zero counts under the specified path.getAllDims(int topN) Returns topN labels for any dimension that had hits, sorted by the number of hits that dimension matched; this is used for "sparse" faceting, where many different dimensions were indexed, for example depending on the type of document.protected LongRange[]getSpecificValue(String dim, String... path) Return the count or value for a specific path.getTopChildren(int topN, String dim, String... path) Returns the topN child labels under the specified path.protected longmapDocValue(long l) protected org.apache.lucene.facet.range.LongRangeCountertoString()Methods inherited from class org.apache.lucene.facet.FacetCountsWithFilterQuerycreateIteratorMethods inherited from class org.apache.lucene.facet.FacetsgetTopDims, validateTopN
- 
Field Details- 
rangesRanges passed to constructor.
- 
countsprotected int[] countsCounts.
- 
fieldOur field name.
- 
totCountprotected int totCountTotal number of hits.
 
- 
- 
Constructor Details- 
LongRangeFacetCountspublic LongRangeFacetCounts(String field, FacetsCollector hits, LongRange... ranges) throws IOException CreateLongRangeFacetCountsusing long values from the specified field. The field may be single-valued (NumericDocValues) or multi-valued (SortedNumericDocValues), and will be interpreted as containing long values.- Throws:
- IOException
 
- 
LongRangeFacetCountspublic LongRangeFacetCounts(String field, LongValuesSource valueSource, FacetsCollector hits, LongRange... ranges) throws IOException CreateLongRangeFacetCounts, using the providedLongValuesSourceif non-null. IfvalueSourceis null, doc values from the providedfieldwill be used.- Throws:
- IOException
 
- 
LongRangeFacetCountspublic LongRangeFacetCounts(String field, MultiLongValuesSource valuesSource, FacetsCollector hits, LongRange... ranges) throws IOException CreateLongRangeFacetCounts, using the providedMultiLongValuesSourceif non-null. IfvaluesSourceis null, doc values from the providedfieldwill be used.- Throws:
- IOException
 
- 
LongRangeFacetCountspublic LongRangeFacetCounts(String field, LongValuesSource valueSource, FacetsCollector hits, Query fastMatchQuery, LongRange... ranges) throws IOException CreateLongRangeFacetCounts, using the providedLongValuesSourceif non-null. IfvalueSourceis null, doc values from the providedfieldwill be used. Use the providedQueryas a fastmatch: only documents passing the filter are checked for the matching ranges, which is helpful when the providedLongValuesSourceis costly per-document, such as a geo distance.- Throws:
- IOException
 
- 
LongRangeFacetCountspublic LongRangeFacetCounts(String field, MultiLongValuesSource valuesSource, FacetsCollector hits, Query fastMatchQuery, LongRange... ranges) throws IOException CreateLongRangeFacetCounts, using the providedMultiLongValuesSourceif non-null. IfvaluesSourceis null, doc values from the providedfieldwill be used. Use the providedQueryas a fastmatch: only documents passing the filter are checked for the matching ranges, which is helpful when the providedLongValuesSourceis costly per-document, such as a geo distance.- Throws:
- IOException
 
 
- 
- 
Method Details- 
getLongRanges
- 
mapDocValueprotected long mapDocValue(long l) 
- 
setupCounterprotected org.apache.lucene.facet.range.LongRangeCounter setupCounter()
- 
countprotected void count(String field, List<FacetsCollector.MatchingDocs> matchingDocs) throws IOException Counts from the provided field.- Throws:
- IOException
 
- 
getAllChildrenReturns all child labels with non-zero counts under the specified path. Users should make no assumptions about ordering of the children. Returns null if the specified path doesn't exist or if this dimension was never seen.NOTE: This implementation guarantees that ranges will be returned in the order specified by the user when calling the constructor. - Specified by:
- getAllChildrenin class- Facets
- Throws:
- IOException
 
- 
getTopChildrenDescription copied from class:FacetsReturns the topN child labels under the specified path. Returns null if the specified path doesn't exist or if this dimension was never seen.- Specified by:
- getTopChildrenin class- Facets
- Throws:
- IOException
 
- 
getSpecificValueDescription copied from class:FacetsReturn the count or value for a specific path. Returns -1 if this path doesn't exist, else the count.- Specified by:
- getSpecificValuein class- Facets
- Throws:
- IOException
 
- 
getAllDimsDescription copied from class:FacetsReturns topN labels for any dimension that had hits, sorted by the number of hits that dimension matched; this is used for "sparse" faceting, where many different dimensions were indexed, for example depending on the type of document.- Specified by:
- getAllDimsin class- Facets
- Throws:
- IOException
 
- 
toString
 
-