Package opennlp.uima.util
Class AnnotationComboIterator
java.lang.Object
opennlp.uima.util.AnnotationComboIterator
- All Implemented Interfaces:
Iterable<AnnotationIteratorPair>
,Iterator<AnnotationIteratorPair>
public class AnnotationComboIterator
extends Object
implements Iterable<AnnotationIteratorPair>, Iterator<AnnotationIteratorPair>
UIMA Annotation iterator combination of super- and subiterator.
This class supports a common idiom in UIMA annotation iteration, where you need to iterate over two kinds of annotations in lock-step. For example, you often want to iterate over all sentences, then do something on each sentence and all tokens in that sentence. Here's how to do this with this class.
CAS cas = ... Type sentenceType = ..., tokenType = ... // Init with CAS, upper and lower type. AnnotationComboIterator it = new AnnotationComboIterator(cas, sentenceType, tokenType); // Iterate over sentences for (AnnotationIteratorPair aiPair : it) { // Obtain sentence annotation AnnotationFS sentence = aiPair.getAnnotation(); // Do something with sentence... // Iterate over tokens for (AnnotationFS token : aiPair.getSubIterator()) { // Do something with tokens... } }The combo iterator returns in its
next()
method a pair of an annotation of the upper
type (e.g., sentence), and an iterator over annotations of the lower type (e.g., tokens). Note
that both the upper and lower iterator also implement the Iterable interface and can be use
directly in for-loops.
Note that only this usage is safe. To keep the implementation efficient, the combo iterator keeps two iterators internally that it increments in lock-step. Do not attempt, for example, to collect more than one of the subiterators (token iterator in our example). Do not use this class if your intended usage does not fall into this pattern.
-
Constructor Summary
ConstructorDescriptionAnnotationComboIterator
(org.apache.uima.cas.CAS cas, org.apache.uima.cas.Type upper, org.apache.uima.cas.Type lower) Create a new combo iterator. -
Method Summary
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface java.lang.Iterable
forEach, spliterator
Methods inherited from interface java.util.Iterator
forEachRemaining
-
Constructor Details
-
AnnotationComboIterator
public AnnotationComboIterator(org.apache.uima.cas.CAS cas, org.apache.uima.cas.Type upper, org.apache.uima.cas.Type lower) Create a new combo iterator.- Parameters:
cas
- TheCAS
we're operating on.upper
- TheType
of the upper iterator, e.g., sentence.lower
- TheType
of the lower iterator, e.g., token.
-
-
Method Details
-
hasNext
public boolean hasNext()- Specified by:
hasNext
in interfaceIterator<AnnotationIteratorPair>
-
next
- Specified by:
next
in interfaceIterator<AnnotationIteratorPair>
-
iterator
- Specified by:
iterator
in interfaceIterable<AnnotationIteratorPair>
-
remove
public void remove()Not supported.- Specified by:
remove
in interfaceIterator<AnnotationIteratorPair>
-