Interface LeafCollector
-
- All Known Implementing Classes:
AllGroupHeadsCollector,AllGroupHeadsCollector.ScoringGroupHeadsCollector,AllGroupHeadsCollector.SortingGroupHeadsCollector,AllGroupsCollector,BlockGroupingCollector,BooleanScorer.OrCollector,CachingCollector.NoScoreCachingLeafCollector,CachingCollector.ScoreCachingLeafCollector,CollectingMatcher.MatchCollector,DistinctValuesCollector,DistinctValuesCollector.ValuesCollector,DocValuesTermsCollector,FilterLeafCollector,FirstPassGroupingCollector,GlobalOrdinalsCollector.OrdinalMapCollector,GlobalOrdinalsCollector.SegmentOrdinalCollector,GlobalOrdinalsWithScoreCollector.OrdinalMapCollector,GlobalOrdinalsWithScoreCollector.SegmentOrdinalCollector,GroupFacetCollector,MemoryAccountingBitsetCollector,MultiCollector.MultiLeafCollector,MultiCollectorManager.Collectors.LeafCollectors,QueryIndex.MonitorQueryCollector,SecondPassGroupingCollector,SimpleCollector,TermGroupFacetCollector,TermGroupFacetCollector.MV,TermGroupFacetCollector.SV,TermsCollector,TermsCollector.MV,TermsCollector.SV,TermsWithScoreCollector,TermsWithScoreCollector.MV,TermsWithScoreCollector.MV.Avg,TermsWithScoreCollector.SV,TermsWithScoreCollector.SV.Avg,TopFieldCollector.MultiComparatorLeafCollector,TopGroupsCollector,TopGroupsCollector.MaxScoreCollector,TopScoreDocCollector.ScorerLeafCollector,TopSuggestDocsCollector,TotalHitCountCollector
public interface LeafCollectorCollector decouples the score from the collected doc: the score computation is skipped entirely if it's not needed. Collectors that do need the score should implement the
setScorer(org.apache.lucene.search.Scorable)method, to hold onto the passedScorerinstance, and callScorable.score()within the collect method to compute the current hit's score. If your collector may request the score for a single hit multiple times, you should useScoreCachingWrappingScorer.NOTE: The doc that is passed to the collect method is relative to the current reader. If your collector needs to resolve this to the docID space of the Multi*Reader, you must re-base it by recording the docBase from the most recent setNextReader call. Here's a simple example showing how to collect docIDs into a BitSet:
IndexSearcher searcher = new IndexSearcher(indexReader); final BitSet bits = new BitSet(indexReader.maxDoc()); searcher.search(query, new Collector() { public LeafCollector getLeafCollector(LeafReaderContext context) throws IOException { final int docBase = context.docBase; return new LeafCollector() { // ignore scorer public void setScorer(Scorer scorer) throws IOException { } public void collect(int doc) throws IOException { bits.set(docBase + doc); } }; } });Not all collectors will need to rebase the docID. For example, a collector that simply counts the total number of hits would skip it.
-
-
Method Summary
All Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description voidcollect(int doc)Called once for every document matching a query, with the unbased document number.default DocIdSetIteratorcompetitiveIterator()Optionally returns an iterator over competitive documents.voidsetScorer(Scorable scorer)Called before successive calls tocollect(int).
-
-
-
Method Detail
-
setScorer
void setScorer(Scorable scorer) throws java.io.IOException
Called before successive calls tocollect(int). Implementations that need the score of the current document (passed-in tocollect(int)), should save the passed-in Scorer and call scorer.score() when needed.- Throws:
java.io.IOException
-
collect
void collect(int doc) throws java.io.IOExceptionCalled once for every document matching a query, with the unbased document number.Note: The collection of the current segment can be terminated by throwing a
CollectionTerminatedException. In this case, the last docs of the currentLeafReaderContextwill be skipped andIndexSearcherwill swallow the exception and continue collection with the next leaf.Note: This is called in an inner search loop. For good search performance, implementations of this method should not call
IndexSearcher.doc(int)orIndexReader.document(int)on every hit. Doing so can slow searches by an order of magnitude or more.- Throws:
java.io.IOException
-
competitiveIterator
default DocIdSetIterator competitiveIterator() throws java.io.IOException
Optionally returns an iterator over competitive documents. Collectors should delegate this method to their comparators if their comparators provide the skipping functionality over non-competitive docs. The default is to returnnullwhich is interpreted as the collector provide any competitive iterator.- Throws:
java.io.IOException
-
-