本文整理汇总了Java中ixa.kaflib.Term类的典型用法代码示例。如果您正苦于以下问题:Java Term类的具体用法?Java Term怎么用?Java Term使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
Term类属于ixa.kaflib包,在下文中一共展示了Term类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: extractPOStags
import ixa.kaflib.Term; //导入依赖的package包/类
/**
* POS tags ngram extraction from a kaf document
*
* @param int length : which 'n' use for 'n-grams'
* @param KAFDocument kafDoc : postagged kaf document to extract ngrams from.
* @param boolean save : safe ngrams to file or not.
* @return TreeSet<String> return lemma ngrams of length length
*/
public TreeSet<String> extractPOStags(KAFDocument kafDoc, boolean save)
{
TreeSet<String> result = new TreeSet<String>();
for (Term term : kafDoc.getTerms())
{
String pos = "POS_"+term.getPos();
// for good measure, test that the lemma is not already included as a feature
if (! getAttIndexes().containsKey(pos))
{
addNumericFeature(pos);
result.add(pos);
}
}
return result;
}
示例2: indexMarkables
import ixa.kaflib.Term; //导入依赖的package包/类
private static Markable[] indexMarkables(final List<Term> terms,
final Iterable<Markable> markables) {
final Map<Term, Integer> termIndex = Maps.newHashMap();
for (int i = 0; i < terms.size(); ++i) {
termIndex.put(terms.get(i), i);
}
final Markable[] markableIndex = new Markable[terms.size()];
for (final Markable markable : markables) {
for (final Term term : markable.getTerms()) {
final Integer index = termIndex.get(term);
if (index != null) {
markableIndex[index] = markable;
}
}
}
return markableIndex;
}
示例3: SRLElement
import ixa.kaflib.Term; //导入依赖的package包/类
SRLElement(final SRLElement parent, final Object element, final boolean useProposition) {
this.parent = parent;
this.element = element;
if (useProposition) {
final Predicate predicate = (Predicate) element;
final Set<Term> termSet = Sets.newHashSet();
termSet.addAll(predicate.getTerms());
for (final Role role : predicate.getRoles()) {
termSet.addAll(role.getTerms());
}
this.terms = Ordering.from(Term.OFFSET_COMPARATOR).immutableSortedCopy(termSet);
} else if (element instanceof Predicate) {
this.terms = ((Predicate) element).getTerms();
} else {
this.terms = ((Role) element).getTerms();
}
this.begin = this.terms.get(0).getOffset();
this.end = endOf(this.terms.get(this.terms.size() - 1));
}
示例4: filterTerms
import ixa.kaflib.Term; //导入依赖的package包/类
public static List<Term> filterTerms(final Iterable<Term> terms) {
final List<Term> result = Lists.newArrayList();
boolean atBeginning = true;
for (final Term term : Ordering.from(Term.OFFSET_COMPARATOR).sortedCopy(terms)) {
final char pos = Character.toUpperCase(term.getPos().charAt(0));
if (atBeginning && (pos == 'D' || pos == 'P')) {
continue;
}
for (final WF word : term.getWFs()) {
final String text = word.getForm();
if (SYMBOLS.contains(text) || !WF_EXCLUSION_PATTERN.matcher(text).matches()) {
result.add(term);
atBeginning = false;
break;
}
}
}
return result;
}
示例5: hasHead
import ixa.kaflib.Term; //导入依赖的package包/类
public static boolean hasHead(final KAFDocument document, final Object annotation,
final Term head) {
List<Span<Term>> spans;
if (annotation instanceof Coref) {
spans = ((Coref) annotation).getSpans();
} else if (annotation instanceof Entity) {
spans = ((Entity) annotation).getSpans();
} else if (annotation instanceof Timex3) {
spans = ImmutableList.of(KAFDocument.newTermSpan(document
.getTermsByWFs(((Timex3) annotation).getSpan().getTargets())));
} else if (annotation instanceof Predicate) {
spans = ImmutableList.of(((Predicate) annotation).getSpan());
} else if (annotation instanceof Role) {
spans = ImmutableList.of(((Role) annotation).getSpan());
} else {
throw new IllegalArgumentException("Unsupported annotation: " + annotation);
}
for (final Span<Term> span : spans) {
if (head == extractHead(document, span)) {
return true;
}
}
return false;
}
示例6: getRefs
import ixa.kaflib.Term; //导入依赖的package包/类
private static List<ExternalRef> getRefs(final Object annotation) {
List<ExternalRef> refs = ImmutableList.of();
if (annotation instanceof Term) {
refs = ((Term) annotation).getExternalRefs();
} else if (annotation instanceof Entity) {
refs = ((Entity) annotation).getExternalRefs();
} else if (annotation instanceof Predicate) {
refs = ((Predicate) annotation).getExternalRefs();
} else if (annotation instanceof Role) {
refs = ((Role) annotation).getExternalRefs();
} else if (annotation instanceof Opinion) {
refs = ((Opinion) annotation).getExternalRefs();
} else if (annotation instanceof OpinionExpression) {
refs = ((OpinionExpression) annotation).getExternalRefs();
} else if (annotation instanceof OpinionTarget) {
refs = ((OpinionTarget) annotation).getExternalRefs();
} else if (annotation instanceof OpinionHolder) {
refs = ((OpinionHolder) annotation).getExternalRefs();
} else {
throw new IllegalArgumentException("Unsupported annotation object: " + annotation);
}
return refs;
}
示例7: termRangesFor
import ixa.kaflib.Term; //导入依赖的package包/类
public static List<Range> termRangesFor(final KAFDocument document, final Iterable<Term> terms) {
final List<Range> ranges = Lists.newArrayList();
int startIndex = -1;
int lastIndex = -2;
for (final Term term : Ordering.from(Term.OFFSET_COMPARATOR).sortedCopy(terms)) {
final int termIndex = document.getTerms().indexOf(term);
if (termIndex - lastIndex > 1) {
if (startIndex >= 0) {
ranges.add(Range.create(startIndex, lastIndex + 1));
}
startIndex = termIndex;
}
lastIndex = termIndex;
}
if (startIndex != -1 && lastIndex >= startIndex) {
ranges.add(Range.create(startIndex, lastIndex + 1));
}
return ranges;
}
示例8: rangesFor
import ixa.kaflib.Term; //导入依赖的package包/类
public static List<Range> rangesFor(final KAFDocument document, final Iterable<Term> terms) {
final List<Range> ranges = Lists.newArrayList();
int startOffset = -1;
int endOffset = -1;
int termIndex = -2;
for (final Term term : Ordering.from(Term.OFFSET_COMPARATOR).sortedCopy(terms)) {
final int lastTermIndex = termIndex;
termIndex = document.getTerms().indexOf(term);
if (termIndex - lastTermIndex > 1) {
if (startOffset != -1) {
ranges.add(Range.create(startOffset, endOffset));
}
startOffset = term.getOffset();
}
endOffset = NAFUtils.getEnd(term);
}
if (startOffset != -1 && endOffset > startOffset) {
ranges.add(Range.create(startOffset, endOffset));
}
return ranges;
}
示例9: splitSpan
import ixa.kaflib.Term; //导入依赖的package包/类
public static final List<Span<Term>> splitSpan(final KAFDocument document,
final Span<Term> span, final Iterable<Term> heads) {
final Set<Term> excludedTerms = document.getTermsByDepDescendants(heads);
final List<Span<Term>> spans = Lists.newArrayList();
for (final Term head : heads) {
final Set<Term> terms = document.getTermsByDepAncestors(ImmutableSet.of(head));
terms.removeAll(excludedTerms);
terms.add(head);
terms.retainAll(span.getTargets());
if (!terms.isEmpty()) {
spans.add(KAFDocument.newTermSpan(Ordering.from(Term.OFFSET_COMPARATOR)
.sortedCopy(terms), head));
}
}
return spans;
}
示例10: isActiveFormHelper
import ixa.kaflib.Term; //导入依赖的package包/类
private static Boolean isActiveFormHelper(final KAFDocument document, final Term term) {
final Dep dep = document.getDepToTerm(term);
if (dep == null) {
return Boolean.FALSE;
}
final Term parent = dep.getFrom();
final String word = parent.getStr().toLowerCase();
final String pos = parent.getMorphofeat();
if (pos.startsWith("NN")) {
return Boolean.FALSE;
}
if (word.matches("am|are|is|was|were|be|been|being")) {
return Boolean.FALSE;
}
if (word.matches("ha(ve|s|d|ving)")) {
return Boolean.TRUE;
}
if (pos.matches("VBZ|VBD|VBP|MD")) {
return Boolean.FALSE;
}
return isActiveFormHelper(document, parent);
}
示例11: matchExtendedPos
import ixa.kaflib.Term; //导入依赖的package包/类
public static java.util.function.Predicate<Term> matchExtendedPos(final KAFDocument document,
final String... posPrefixes) {
return new java.util.function.Predicate<Term>() {
@Override
public boolean test(final Term term) {
final String pos = extendedPos(document, term);
for (final String prefix : posPrefixes) {
if (pos.startsWith(prefix)) {
return true;
}
}
return false;
}
};
}
示例12: sentenceForSpan
import ixa.kaflib.Term; //导入依赖的package包/类
@Nullable
private static Integer sentenceForSpan(Span<Term> termSpan) {
HashSet<Integer> sentences = new HashSet<>();
for (Term term : termSpan.getTargets()) {
sentences.add(term.getSent());
}
if (sentences.size() != 1) {
return null;
}
for (Integer sentence : sentences) {
return sentence;
}
return null;
}
示例13: getSpan
import ixa.kaflib.Term; //导入依赖的package包/类
public static List<Term> getSpan(List<Term> terms, String interval) {
if (interval == null) {
return new ArrayList<Term>();
}
Matcher matcher = spanPatt.matcher(interval);
if (!matcher.matches()) {
return new ArrayList<Term>();
}
int start = Integer.parseInt(matcher.group(1));
int end = Integer.parseInt(matcher.group(2)) - 1;
LOGGER.debug("Start: " + start + " - End: " + end);
return getSpan(terms, start, end);
}
示例14: match
import ixa.kaflib.Term; //导入依赖的package包/类
public Multimap<Term, T> match(final KAFDocument document, final Iterable<Term> terms) {
Preconditions.checkNotNull(document);
final Set<Term> termSet = ImmutableSet.copyOf(terms);
final Multimap<Term, T> result = HashMultimap.create();
for (final Term term : termSet) {
final String lemma = term.getLemma();
final String stem = Stemming.stem(null, lemma);
for (final T lexeme : ImmutableSet.copyOf(Iterables.concat(
this.lemmaIndex.get(term.getLemma()), this.stemIndex.get(stem)))) {
if (lexeme.match(document, termSet, term)) {
result.put(term, lexeme);
}
}
}
return result;
}
示例15: getTermsFromSpan
import ixa.kaflib.Term; //导入依赖的package包/类
private static Span<Term> getTermsFromSpan(KAFDocument document, String span) {
String[] parts = span.split("[^a-z0-9A-Z_]+");
Span<Term> termSpan = KAFDocument.newTermSpan();
if (parts.length == 1) {
Integer id = getTermFromSpan(parts[0]);
termSpan.addTarget(document.getTerms().get(id));
}
else if (parts.length > 1) {
Integer id1 = getTermFromSpan(parts[0]);
Integer id2 = getTermFromSpan(parts[parts.length - 1]);
for (int i = id1; i <= id2; i++) {
termSpan.addTarget(document.getTerms().get(i));
}
}
return termSpan;
}