java.lang.Object
org.apache.lucene.search.suggest.Lookup
org.apache.lucene.search.suggest.tst.TSTLookup
- All Implemented Interfaces:
Accountable
Suggest implementation based on a Ternary Search Tree
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class org.apache.lucene.search.suggest.Lookup
Lookup.LookupPriorityQueue, Lookup.LookupResult -
Field Summary
FieldsModifier and TypeFieldDescription(package private) TSTAutocompleteprivate longNumber of entries the lookup was built withprivate static final byteprivate static final byteprivate static final byteprivate static final byteprivate static final byte(package private) TernaryTreeNodeprivate final Directoryprivate final Stringprivate static final Comparator<BytesRef> TST uses UTF-16 sorting, so we need a suitable BytesRef comparator to do this.Fields inherited from class org.apache.lucene.search.suggest.Lookup
CHARSEQUENCE_COMPARATORFields inherited from interface org.apache.lucene.util.Accountable
NULL_ACCOUNTABLE -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionbooleanadd(CharSequence key, Object value) Adds a new node ifkeyalready exists, otherwise replaces its value.voidbuild(InputIterator iterator) Builds up a new internalLookuprepresentation based on the givenInputIterator.private static booleancharSeqEquals(CharSequence left, CharSequence right) get(CharSequence key) Returns the value for the specified key, or null if the key does not exist.longgetCount()Get the number of entries the lookup was built withbooleanDiscard current lookup data and load it from a previously saved copy.lookup(CharSequence key, Set<BytesRef> contexts, boolean onlyMorePopular, int num) Look up a key and return possible completion for this key.longReturns byte size of the underlying TSTprivate voidreadRecursively(DataInput in, TernaryTreeNode node) booleanstore(DataOutput output) Persist the constructed lookup data to a directory.private voidwriteRecursively(DataOutput out, TernaryTreeNode node) Methods inherited from class org.apache.lucene.search.suggest.Lookup
build, load, lookup, lookup, storeMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.lucene.util.Accountable
getChildResources
-
Field Details
-
root
TernaryTreeNode root -
autocomplete
TSTAutocomplete autocomplete -
count
private long countNumber of entries the lookup was built with -
tempDir
-
tempFileNamePrefix
-
utf8SortedAsUTF16SortOrder
TST uses UTF-16 sorting, so we need a suitable BytesRef comparator to do this. -
LO_KID
private static final byte LO_KID- See Also:
-
EQ_KID
private static final byte EQ_KID- See Also:
-
HI_KID
private static final byte HI_KID- See Also:
-
HAS_TOKEN
private static final byte HAS_TOKEN- See Also:
-
HAS_VALUE
private static final byte HAS_VALUE- See Also:
-
-
Constructor Details
-
TSTLookup
public TSTLookup()Creates a new TSTLookup with an empty Ternary Search Tree.- See Also:
-
TSTLookup
Creates a new TSTLookup, for building.- See Also:
-
-
Method Details
-
build
Description copied from class:LookupBuilds up a new internalLookuprepresentation based on the givenInputIterator. The implementation might re-sort the data internally.- Specified by:
buildin classLookup- Throws:
IOException
-
add
Adds a new node ifkeyalready exists, otherwise replaces its value.This method always returns true.
-
get
Returns the value for the specified key, or null if the key does not exist. -
charSeqEquals
-
lookup
public List<Lookup.LookupResult> lookup(CharSequence key, Set<BytesRef> contexts, boolean onlyMorePopular, int num) Description copied from class:LookupLook up a key and return possible completion for this key.- Specified by:
lookupin classLookup- Parameters:
key- lookup key. Depending on the implementation this may be a prefix, misspelling, or even infix.contexts- contexts to filter the lookup by, or null if all contexts are allowed; if the suggestion contains any of the contexts, it's a matchonlyMorePopular- return only more popular resultsnum- maximum number of results to return- Returns:
- a list of possible completions, with their relative weight (e.g. popularity)
-
readRecursively
- Throws:
IOException
-
writeRecursively
- Throws:
IOException
-
store
Description copied from class:LookupPersist the constructed lookup data to a directory. Optional operation.- Specified by:
storein classLookup- Parameters:
output-DataOutputto write the data to.- Returns:
- true if successful, false if unsuccessful or not supported.
- Throws:
IOException- when fatal IO error occurs.
-
load
Description copied from class:LookupDiscard current lookup data and load it from a previously saved copy. Optional operation.- Specified by:
loadin classLookup- Parameters:
input- theDataInputto load the lookup data.- Returns:
- true if completed successfully, false if unsuccessful or not supported.
- Throws:
IOException- when fatal IO error occurs.
-
ramBytesUsed
public long ramBytesUsed()Returns byte size of the underlying TST -
getCount
public long getCount()Description copied from class:LookupGet the number of entries the lookup was built with
-