Class ValueSource.ValueSourceComparator
- java.lang.Object
-
- org.apache.lucene.search.FieldComparator<T>
-
- org.apache.lucene.search.SimpleFieldComparator<java.lang.Double>
-
- org.apache.lucene.queries.function.ValueSource.ValueSourceComparator
-
- All Implemented Interfaces:
LeafFieldComparator
- Enclosing class:
- ValueSource
class ValueSource.ValueSourceComparator extends SimpleFieldComparator<java.lang.Double>
Implement aFieldComparatorthat works off of theFunctionValuesfor a ValueSource instead of the normal Lucene FieldComparator that works off of a FieldCache.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.apache.lucene.search.FieldComparator
FieldComparator.RelevanceComparator, FieldComparator.TermOrdValComparator, FieldComparator.TermValComparator
-
-
Constructor Summary
Constructors Constructor Description ValueSourceComparator(java.util.Map fcontext, int numHits)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intcompare(int slot1, int slot2)Compare hit at slot1 with hit at slot2.intcompareBottom(int doc)Compare the bottom of the queue with this doc.intcompareTop(int doc)Compare the top value with this doc.voidcopy(int slot, int doc)This method is called when a new hit is competitive.voiddoSetNextReader(LeafReaderContext context)This method is called before collectingcontext.voidsetBottom(int bottom)Set the bottom slot, ie the "weakest" (sorted last) entry in the queue.voidsetTopValue(java.lang.Double value)Record the top value, for future calls toLeafFieldComparator.compareTop(int).java.lang.Doublevalue(int slot)Return the actual value in the slot.-
Methods inherited from class org.apache.lucene.search.SimpleFieldComparator
getLeafComparator, setScorer
-
Methods inherited from class org.apache.lucene.search.FieldComparator
compareValues, disableSkipping, setSingleSort
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.apache.lucene.search.LeafFieldComparator
competitiveIterator, setHitsThresholdReached
-
-
-
-
Field Detail
-
values
private final double[] values
-
docVals
private FunctionValues docVals
-
bottom
private double bottom
-
fcontext
private final java.util.Map fcontext
-
topValue
private double topValue
-
-
Method Detail
-
compare
public int compare(int slot1, int slot2)Description copied from class:FieldComparatorCompare hit at slot1 with hit at slot2.- Specified by:
comparein classFieldComparator<java.lang.Double>- Parameters:
slot1- first slot to compareslot2- second slot to compare- Returns:
- any
N < 0if slot2's value is sorted after slot1, anyN > 0if the slot2's value is sorted before slot1 and0if they are equal
-
compareBottom
public int compareBottom(int doc) throws java.io.IOExceptionDescription copied from interface:LeafFieldComparatorCompare the bottom of the queue with this doc. This will only invoked after setBottom has been called. This should return the same result asFieldComparator.compare(int,int)} as if bottom were slot1 and the new document were slot 2.For a search that hits many results, this method will be the hotspot (invoked by far the most frequently).
- Parameters:
doc- that was hit- Returns:
- any
N < 0if the doc's value is sorted after the bottom entry (not competitive), anyN > 0if the doc's value is sorted before the bottom entry and0if they are equal. - Throws:
java.io.IOException
-
copy
public void copy(int slot, int doc) throws java.io.IOExceptionDescription copied from interface:LeafFieldComparatorThis method is called when a new hit is competitive. You should copy any state associated with this document that will be required for future comparisons, into the specified slot.- Parameters:
slot- which slot to copy the hit todoc- docID relative to current reader- Throws:
java.io.IOException
-
doSetNextReader
public void doSetNextReader(LeafReaderContext context) throws java.io.IOException
Description copied from class:SimpleFieldComparatorThis method is called before collectingcontext.- Specified by:
doSetNextReaderin classSimpleFieldComparator<java.lang.Double>- Throws:
java.io.IOException
-
setBottom
public void setBottom(int bottom)
Description copied from interface:LeafFieldComparatorSet the bottom slot, ie the "weakest" (sorted last) entry in the queue. WhenLeafFieldComparator.compareBottom(int)is called, you should compare against this slot. This will always be called beforeLeafFieldComparator.compareBottom(int).- Parameters:
bottom- the currently weakest (sorted last) slot in the queue
-
setTopValue
public void setTopValue(java.lang.Double value)
Description copied from class:FieldComparatorRecord the top value, for future calls toLeafFieldComparator.compareTop(int). This is only called for searches that use searchAfter (deep paging), and is called before any calls toFieldComparator.getLeafComparator(LeafReaderContext).- Specified by:
setTopValuein classFieldComparator<java.lang.Double>
-
value
public java.lang.Double value(int slot)
Description copied from class:FieldComparatorReturn the actual value in the slot.- Specified by:
valuein classFieldComparator<java.lang.Double>- Parameters:
slot- the value- Returns:
- value in this slot
-
compareTop
public int compareTop(int doc) throws java.io.IOExceptionDescription copied from interface:LeafFieldComparatorCompare the top value with this doc. This will only invoked after setTopValue has been called. This should return the same result asFieldComparator.compare(int,int)} as if topValue were slot1 and the new document were slot 2. This is only called for searches that use searchAfter (deep paging).- Parameters:
doc- that was hit- Returns:
- any
N < 0if the doc's value is sorted after the top entry (not competitive), anyN > 0if the doc's value is sorted before the top entry and0if they are equal. - Throws:
java.io.IOException
-
-