Class JapaneseTokenizer
- java.lang.Object
-
- org.apache.lucene.util.AttributeSource
-
- org.apache.lucene.analysis.TokenStream
-
- org.apache.lucene.analysis.Tokenizer
-
- org.apache.lucene.analysis.ja.JapaneseTokenizer
-
- All Implemented Interfaces:
Closeable,AutoCloseable
public final class JapaneseTokenizer extends Tokenizer
Tokenizer for Japanese that uses morphological analysis.This tokenizer sets a number of additional attributes:
BaseFormAttributecontaining base form for inflected adjectives and verbs.PartOfSpeechAttributecontaining part-of-speech.ReadingAttributecontaining reading and pronunciation.InflectionAttributecontaining additional part-of-speech information for inflected forms.
This tokenizer uses a rolling Viterbi search to find the least cost segmentation (path) of the incoming characters. For tokens that appear to be compound (> length 2 for all Kanji, or > length 7 for non-Kanji), we see if there is a 2nd best segmentation of that token after applying penalties to the long tokens. If so, and the Mode is
JapaneseTokenizer.Mode.SEARCH, we output the alternate segmentation as well.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classJapaneseTokenizer.ModeTokenization mode: this determines how the tokenizer handles compound and unknown words.-
Nested classes/interfaces inherited from class org.apache.lucene.util.AttributeSource
AttributeSource.AttributeFactory, AttributeSource.State
-
-
Field Summary
Fields Modifier and Type Field Description static JapaneseTokenizer.ModeDEFAULT_MODEDefault tokenization mode.
-
Constructor Summary
Constructors Constructor Description JapaneseTokenizer(Reader input, UserDictionary userDictionary, boolean discardPunctuation, JapaneseTokenizer.Mode mode)Create a new JapaneseTokenizer.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidend()This method is called by the consumer after the last token has been consumed, afterTokenStream.incrementToken()returnedfalse(using the newTokenStreamAPI).booleanincrementToken()Consumers (i.e.,IndexWriter) use this method to advance the stream to the next token.voidreset()Resets this stream to the beginning.voidreset(Reader input)Expert: Reset the tokenizer to a new reader.voidsetGraphvizFormatter(GraphvizFormatter dotOut)Expert: set this to produce graphviz (dot) output of the Viterbi lattice-
Methods inherited from class org.apache.lucene.analysis.Tokenizer
close, correctOffset
-
Methods inherited from class org.apache.lucene.util.AttributeSource
addAttribute, addAttributeImpl, captureState, clearAttributes, cloneAttributes, copyTo, equals, getAttribute, getAttributeClassesIterator, getAttributeFactory, getAttributeImplsIterator, hasAttribute, hasAttributes, hashCode, reflectAsString, reflectWith, restoreState, toString
-
-
-
-
Field Detail
-
DEFAULT_MODE
public static final JapaneseTokenizer.Mode DEFAULT_MODE
Default tokenization mode. Currently this isJapaneseTokenizer.Mode.SEARCH.
-
-
Constructor Detail
-
JapaneseTokenizer
public JapaneseTokenizer(Reader input, UserDictionary userDictionary, boolean discardPunctuation, JapaneseTokenizer.Mode mode)
Create a new JapaneseTokenizer.- Parameters:
input- Reader containing textuserDictionary- Optional: if non-null, user dictionary.discardPunctuation- true if punctuation tokens should be dropped from the output.mode- tokenization mode.
-
-
Method Detail
-
setGraphvizFormatter
public void setGraphvizFormatter(GraphvizFormatter dotOut)
Expert: set this to produce graphviz (dot) output of the Viterbi lattice
-
reset
public void reset(Reader input) throws IOException
Description copied from class:TokenizerExpert: Reset the tokenizer to a new reader. Typically, an analyzer (in its reusableTokenStream method) will use this to re-use a previously created tokenizer.- Overrides:
resetin classTokenizer- Throws:
IOException
-
reset
public void reset() throws IOExceptionDescription copied from class:TokenStreamResets this stream to the beginning. This is an optional operation, so subclasses may or may not implement this method.TokenStream.reset()is not needed for the standard indexing process. However, if the tokens of aTokenStreamare intended to be consumed more than once, it is necessary to implementTokenStream.reset(). Note that if your TokenStream caches tokens and feeds them back again after a reset, it is imperative that you clone the tokens when you store them away (on the first pass) as well as when you return them (on future passes afterTokenStream.reset()).- Overrides:
resetin classTokenStream- Throws:
IOException
-
end
public void end()
Description copied from class:TokenStreamThis method is called by the consumer after the last token has been consumed, afterTokenStream.incrementToken()returnedfalse(using the newTokenStreamAPI). Streams implementing the old API should upgrade to use this feature. This method can be used to perform any end-of-stream operations, such as setting the final offset of a stream. The final offset of a stream might differ from the offset of the last token eg in case one or more whitespaces followed after the last token, but aWhitespaceTokenizerwas used.- Overrides:
endin classTokenStream
-
incrementToken
public boolean incrementToken() throws IOExceptionDescription copied from class:TokenStreamConsumers (i.e.,IndexWriter) use this method to advance the stream to the next token. Implementing classes must implement this method and update the appropriateAttributeImpls with the attributes of the next token.The producer must make no assumptions about the attributes after the method has been returned: the caller may arbitrarily change it. If the producer needs to preserve the state for subsequent calls, it can use
AttributeSource.captureState()to create a copy of the current attribute state.This method is called for every token of a document, so an efficient implementation is crucial for good performance. To avoid calls to
AttributeSource.addAttribute(Class)andAttributeSource.getAttribute(Class), references to allAttributeImpls that this stream uses should be retrieved during instantiation.To ensure that filters and consumers know which attributes are available, the attributes must be added during instantiation. Filters and consumers are not required to check for availability of attributes in
TokenStream.incrementToken().- Specified by:
incrementTokenin classTokenStream- Returns:
- false for end of stream; true otherwise
- Throws:
IOException
-
-