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 itsnext()
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
Constructors Constructor Description AnnotationComboIterator(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
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
hasNext()
Iterator<AnnotationIteratorPair>
iterator()
AnnotationIteratorPair
next()
void
remove()
Not supported.-
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 Detail
-
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 Detail
-
hasNext
public boolean hasNext()
- Specified by:
hasNext
in interfaceIterator<AnnotationIteratorPair>
-
next
public AnnotationIteratorPair next()
- Specified by:
next
in interfaceIterator<AnnotationIteratorPair>
-
iterator
public Iterator<AnnotationIteratorPair> iterator()
- Specified by:
iterator
in interfaceIterable<AnnotationIteratorPair>
-
remove
public void remove()
Not supported.- Specified by:
remove
in interfaceIterator<AnnotationIteratorPair>
-
-