public abstract class Weight extends Object
The purpose of Weight
is to ensure searching does not modify a
Query
, so that a Query
instance can be reused.
IndexSearcher
dependent state of the query should reside in the
Weight
.
AtomicReader
dependent state should reside in the Scorer
.
Since Weight
creates Scorer
instances for a given
AtomicReaderContext
(scorer(AtomicReaderContext, Bits)
)
callers must maintain the relationship between the searcher's top-level
IndexReaderContext
and the context used to create a Scorer
.
A Weight
is used in the following way:
Weight
is constructed by a top-level query, given a
IndexSearcher
(Query.createWeight(IndexSearcher)
).
getValueForNormalization()
method is called on the
Weight
to compute the query normalization factor
Similarity.queryNorm(float)
of the query clauses contained in the
query.
normalize(float, float)
. At
this point the weighting is complete.
Scorer
is constructed by
scorer(AtomicReaderContext, Bits)
.
Constructor and Description |
---|
Weight() |
Modifier and Type | Method and Description |
---|---|
BulkScorer |
bulkScorer(AtomicReaderContext context,
boolean scoreDocsInOrder,
Bits acceptDocs)
Optional method, to return a
BulkScorer to
score the query and send hits to a Collector . |
abstract Explanation |
explain(AtomicReaderContext context,
int doc)
An explanation of the score computation for the named document.
|
abstract Query |
getQuery()
The query that this concerns.
|
abstract float |
getValueForNormalization()
The value for normalization of contained query clauses (e.g.
|
abstract void |
normalize(float norm,
float topLevelBoost)
Assigns the query normalization factor and boost from parent queries to this.
|
abstract Scorer |
scorer(AtomicReaderContext context,
Bits acceptDocs)
Returns a
Scorer which scores documents in/out-of order according
to scoreDocsInOrder . |
boolean |
scoresDocsOutOfOrder()
Returns true iff this implementation scores docs only out of order.
|
public abstract Explanation explain(AtomicReaderContext context, int doc) throws IOException
context
- the readers context to create the Explanation
for.doc
- the document's id relative to the given context's readerIOException
- if an IOException
occurspublic abstract Query getQuery()
public abstract float getValueForNormalization() throws IOException
IOException
public abstract void normalize(float norm, float topLevelBoost)
public abstract Scorer scorer(AtomicReaderContext context, Bits acceptDocs) throws IOException
Scorer
which scores documents in/out-of order according
to scoreDocsInOrder
.
NOTE: even if scoreDocsInOrder
is false, it is
recommended to check whether the returned Scorer
indeed scores
documents out of order (i.e., call scoresDocsOutOfOrder()
), as
some Scorer
implementations will always return documents
in-order.
NOTE: null can be returned if no documents will be scored by this
query.
context
- the AtomicReaderContext
for which to return the Scorer
.acceptDocs
- Bits that represent the allowable docs to match (typically deleted docs
but possibly filtering other documents)Scorer
which scores documents in/out-of order.IOException
- if there is a low-level I/O errorpublic BulkScorer bulkScorer(AtomicReaderContext context, boolean scoreDocsInOrder, Bits acceptDocs) throws IOException
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.context
- the AtomicReaderContext
for which to return the Scorer
.scoreDocsInOrder
- specifies whether in-order scoring of documents is required. Note
that if set to false (i.e., out-of-order scoring is required),
this method can return whatever scoring mode it supports, as every
in-order scorer is also an out-of-order one. However, an
out-of-order scorer may not support DocIdSetIterator.nextDoc()
and/or DocIdSetIterator.advance(int)
, therefore it is recommended to
request an in-order scorer if use of these
methods is required.acceptDocs
- Bits that represent the allowable docs to match (typically deleted docs
but possibly filtering other documents)BulkScorer
which scores documents and
passes them to a collector.IOException
- if there is a low-level I/O errorpublic boolean scoresDocsOutOfOrder()
Collector
's
acceptsDocsOutOfOrder
and
bulkScorer(AtomicReaderContext, boolean, Bits)
to
create a matching Scorer
instance for a given Collector
, or
vice versa.
NOTE: the default implementation returns false
, i.e.
the Scorer
scores documents in-order.
Copyright © 2000-2014 Apache Software Foundation. All Rights Reserved.