public class TermAutomatonQuery extends Query
PhraseQuery
, MultiPhraseQuery
and SpanNearQuery
. It is likely
slow, since it visits any document having any of the terms (i.e. it
acts like a disjunction, not a conjunction like PhraseQuery
), and then it must merge-sort all positions within each
document to test whether/how many times the automaton matches.
After creating the query, use createState()
, setAccept(int, boolean)
, addTransition(int, int, java.lang.String)
and addAnyTransition(int, int)
to
build up the automaton. Once you are done, call finish()
and
then execute the query.
This code is very new and likely has exciting bugs!
Constructor and Description |
---|
TermAutomatonQuery(String field) |
Modifier and Type | Method and Description |
---|---|
void |
addAnyTransition(int source,
int dest)
Adds a transition matching any term.
|
void |
addTransition(int source,
int dest,
BytesRef term)
Adds a transition to the automaton.
|
void |
addTransition(int source,
int dest,
String term)
Adds a transition to the automaton.
|
int |
createState()
Returns a new state; state 0 is always the initial state.
|
Weight |
createWeight(IndexSearcher searcher,
ScoreMode scoreMode,
float boost) |
boolean |
equals(Object other)
Returns true iff
o is equal to this. |
void |
finish()
Call this once you are done adding states/transitions.
|
void |
finish(int maxDeterminizedStates)
Call this once you are done adding states/transitions.
|
int |
hashCode() |
Query |
rewrite(IndexReader reader) |
void |
setAccept(int state,
boolean accept)
Marks the specified state as accept or not.
|
String |
toDot()
Returns the dot (graphviz) representation of this automaton.
|
String |
toString(String field) |
classHash, sameClassAs, toString
public TermAutomatonQuery(String field)
public int createState()
public void setAccept(int state, boolean accept)
public void addTransition(int source, int dest, String term)
public void addTransition(int source, int dest, BytesRef term)
public void addAnyTransition(int source, int dest)
public void finish()
public void finish(int maxDeterminizedStates)
maxDeterminizedStates
- Maximum number of states created when
determinizing the automaton. Higher numbers allow this operation to
consume more memory but allow more complex automatons.public Weight createWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost) throws IOException
createWeight
in class Query
IOException
public boolean equals(Object other)
o
is equal to this.public String toDot()
public Query rewrite(IndexReader reader) throws IOException
rewrite
in class Query
IOException
Copyright © 2000-2019 Apache Software Foundation. All Rights Reserved.