Class IndriAndWeight

  • All Implemented Interfaces:
    SegmentCacheable

    public class IndriAndWeight
    extends Weight
    The Weight for IndriAndQuery, used to normalize, score and explain these queries.
    • Field Detail

      • weights

        private final java.util.ArrayList<Weight> weights
      • scoreMode

        private final ScoreMode scoreMode
      • boost

        private final float boost
    • Constructor Detail

      • IndriAndWeight

        public IndriAndWeight​(IndriAndQuery query,
                              IndexSearcher searcher,
                              ScoreMode scoreMode,
                              float boost)
                       throws java.io.IOException
        Throws:
        java.io.IOException
    • Method Detail

      • getScorer

        private Scorer getScorer​(LeafReaderContext context)
                          throws java.io.IOException
        Throws:
        java.io.IOException
      • scorer

        public Scorer scorer​(LeafReaderContext context)
                      throws java.io.IOException
        Description copied from class: Weight
        Returns a Scorer which can iterate in order over all matching documents and assign them a score.

        NOTE: null can be returned if no documents will be scored by this query.

        NOTE: The returned Scorer does not have LeafReader.getLiveDocs() applied, they need to be checked on top.

        Specified by:
        scorer in class Weight
        Parameters:
        context - the LeafReaderContext for which to return the Scorer.
        Returns:
        a Scorer which scores documents in/out-of order.
        Throws:
        java.io.IOException - if there is a low-level I/O error
      • bulkScorer

        public BulkScorer bulkScorer​(LeafReaderContext context)
                              throws java.io.IOException
        Description copied from class: Weight
        Optional method, to return a BulkScorer to score the query and send hits to a Collector. Only queries that have a different top-level approach need to override this; the default implementation pulls a normal Scorer and iterates and collects the resulting hits which are not marked as deleted.
        Overrides:
        bulkScorer in class Weight
        Parameters:
        context - the LeafReaderContext for which to return the Scorer.
        Returns:
        a BulkScorer which scores documents and passes them to a collector.
        Throws:
        java.io.IOException - if there is a low-level I/O error
      • isCacheable

        public boolean isCacheable​(LeafReaderContext ctx)
        Returns:
        true if the object can be cached against a given leaf
      • explain

        public Explanation explain​(LeafReaderContext context,
                                   int doc)
                            throws java.io.IOException
        Description copied from class: Weight
        An explanation of the score computation for the named document.
        Specified by:
        explain in class Weight
        Parameters:
        context - the readers context to create the Explanation for.
        doc - the document's id relative to the given context's reader
        Returns:
        an Explanation for the score
        Throws:
        java.io.IOException - if an IOException occurs