當前位置: 首頁>>代碼示例>>Java>>正文


Java ResolvedDependency類代碼示例

本文整理匯總了Java中edu.uw.easysrl.dependencies.ResolvedDependency的典型用法代碼示例。如果您正苦於以下問題:Java ResolvedDependency類的具體用法?Java ResolvedDependency怎麽用?Java ResolvedDependency使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ResolvedDependency類屬於edu.uw.easysrl.dependencies包,在下文中一共展示了ResolvedDependency類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: predictedDependencyStream

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
public Stream<ResolvedDependency> predictedDependencyStream(final SyntaxTreeNode parse,
                                                            final boolean generateDependencies,
                                                            final List<InputWord> leaves,
                                                            final boolean local) {
    if (parse == null) {
        return Stream.empty();
    }
    final Set<UnlabelledDependency> unlabeledDependencies = new HashSet<>();
    if (generateDependencies) {
        dependencyGenerator.generateDependencies(parse, unlabeledDependencies);
    } else {
        if (local) {
            unlabeledDependencies.addAll(parse.getResolvedUnlabelledDependencies());
        } else {
            SyntaxUtil.subtreeStream(parse).forEach(subtree -> unlabeledDependencies.addAll(subtree.getResolvedUnlabelledDependencies()));
        }
    }
    return CCGBankEvaluation
            .convertDeps(leaves, unlabeledDependencies)
            .stream()
            .filter(x -> x.getHead() != x.getArgument())
            .filter(x -> validDependencies.contains(x.getCategory().toString() + x.getArgNumber()));
}
 
開發者ID:uwnlp,項目名稱:neuralccg,代碼行數:24,代碼來源:DependencyEvaluator.java

示例2: updateStats

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
public void updateStats(final Set<ResolvedDependency> goldDependencies,
                        final List<Category> goldCategories,
                        final List<Util.Scored<SyntaxTreeNode>> predictedParses,
                        final DependencyEvaluator evaluator) {
    sentenceCount.incrementAndGet();
    if (predictedParses != null) {
        parsableSentenceCount.incrementAndGet();
    } else {
        evaluator.evaluate(goldDependencies, null, overallStats);
        return;
    }

    final SyntaxTreeNode topParse = predictedParses.get(0).getObject();
    evaluator.evaluate(goldDependencies, topParse, overallStats);
    final int numCorrect = (int) CollectionUtil.zip(
            topParse.getLeaves().stream().map(SyntaxTreeNode::getCategory),
            goldCategories.stream(), Object::equals).filter(Boolean::booleanValue).count();
    correctlySupertaggedWords.addAndGet(numCorrect);
    totalWords.addAndGet(goldCategories.size());
}
 
開發者ID:uwnlp,項目名稱:neuralccg,代碼行數:21,代碼來源:EvaluationStatistics.java

示例3: filter

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
/**
 * Return all the dependencies that's relevant to this structure.
 * @param dependencies
 * @return
 */
public ImmutableSet<ResolvedDependency> filter(Collection<ResolvedDependency> dependencies) {
    if (!singleHeaded) {
        return dependencies.stream()
                .collect(Collectors.groupingBy(ResolvedDependency::getHead))
                .values().stream()
                .filter(deps -> {
                    ImmutableList<Integer> argList = deps.stream()
                            .map(ResolvedDependency::getArgument)
                            .distinct()
                            .collect(GuavaCollectors.toImmutableList());
                    return argList.size() == argumentIndices.size() &&
                            argList.containsAll(argumentIndices) && argumentIndices.containsAll(argList);
                })
                .flatMap(Collection::stream)
                .collect(GuavaCollectors.toImmutableSet());
    }
    if (!headIsVP) {
        return dependencies.stream()
                .filter(d -> d.getArgument() == argumentIndices.get(0))
                .collect(GuavaCollectors.toImmutableSet());
    }
    return dependencies.stream()
            .filter(d -> d.getHead() == argumentIndices.get(0))
            .collect(GuavaCollectors.toImmutableSet());
}
 
開發者ID:uwnlp,項目名稱:hitl_parsing,代碼行數:31,代碼來源:AnswerStructure.java

示例4: BasicQuestionAnswerPair

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
public BasicQuestionAnswerPair(int sentenceId, int parseId, Parse parse,
                          int predicateIndex, Category predicateCategory, int argumentNumber,
                          int questionMainIndex, QuestionType questionType,
                          Set<ResolvedDependency> questionDeps, List<String> question,
                          ResolvedDependency targetDep, TextWithDependencies answer) {
    this.predicateIndex = predicateIndex;
    this.predicateCategory = predicateCategory;
    this.argumentNumber = argumentNumber;
    this.questionMainIndex = questionMainIndex;
    this.questionType = questionType;
    this.questionDeps = questionDeps;
    this.question = question;
    this.targetDep = targetDep;
    this.answer = answer.tokens;
    this.answerDeps = answer.dependencies;
    this.parseId = parseId;
    this.sentenceId = sentenceId;
    this.parse = parse;
}
 
開發者ID:uwnlp,項目名稱:hitl_parsing,代碼行數:20,代碼來源:BasicQuestionAnswerPair.java

示例5: getArgumentIdsForDependency

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
public static Set<Integer> getArgumentIdsForDependency(final List<String> words, Parse parse,
                                                       ResolvedDependency dependency) {
    Set<Integer> answers = new HashSet<>();
    Category answerCategory = dependency.getCategory().getArgument(dependency.getArgNumber());
    int argumentId = dependency.getArgument();
    if (answerCategory.equals(Category.PP) || words.get(argumentId).equals("to")) {
        parse.dependencies.stream()
                .filter(d -> d.getHead() == argumentId)
                .forEach(d2 -> answers.add(d2.getArgument()));
        if (answers.size() == 0) {
            answers.add(argumentId);
        }
    } else {
        answers.add(argumentId);
    }
    return answers;
}
 
開發者ID:uwnlp,項目名稱:hitl_parsing,代碼行數:18,代碼來源:TextGenerationHelper.java

示例6: combineNodes

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
@Override
public AgendaItem combineNodes(final AgendaItem leftChild, final AgendaItem rightChild, final SyntaxTreeNode node) {
	final int score = scoreNode(node);

	if (rightChild.getParse().getHead().getWord().equals("around")) {
		Util.debugHook();
	}

	int expectedDeps = 0;
	for (final ResolvedDependency dep : gold) {
		if (expected(leftChild, rightChild, dep) || expected(rightChild, leftChild, dep)) {
			expectedDeps++;
		}
	}

	final double insideScore = leftChild.getInsideScore() + rightChild.getInsideScore() + score;
	return new AgendaItem(node, insideScore, leftChild.outsideScoreUpperbound + rightChild.outsideScoreUpperbound
			- globalUpperBound - expectedDeps, leftChild.getStartOfSpan(), leftChild.getSpanLength()
			+ rightChild.getSpanLength(), true);
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:21,代碼來源:OracleDependenciesModel.java

示例7: scoreNode

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
private int scoreNode(final SyntaxTreeNode node) {
	int score = 0;
	for (final UnlabelledDependency dep : node.getResolvedUnlabelledDependencies()) {
		if (!CCGBankEvaluation.filter(words.get(dep.getHead()), dep.getCategory(), dep.getArgNumber())) {
			for (final int arg : dep.getArguments()) {
				if (gold.contains(new ResolvedDependency(dep.getHead(), dep.getCategory(), dep.getArgNumber(), arg,
						SRLFrame.NONE, null))) {
					score++;
				} else {
					score--;
				}
			}
		}
	}
	return score;
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:17,代碼來源:OracleDependenciesModel.java

示例8: parseDisjunctive

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
private DisjunctiveNode parseDisjunctive(final Key key, final Map<Key, DisjunctiveNode> disjuctiveNodeCache,
		final Map<ResolvedDependency, DisjunctiveNode> dependencyNodeCache,
		final Map<Value, ConjunctiveNode> conjuctiveNodeCache) {
	DisjunctiveTreeNode result = (DisjunctiveTreeNode) disjuctiveNodeCache.get(key);

	if (result == null) {
		result = new DisjunctiveTreeNode(key.category, key.startIndex, key.lastIndex, key.ruleClass);

		for (final Value child : key.getChildren()) {
			result.addChild(parseConjunctive(child, disjuctiveNodeCache, conjuctiveNodeCache, dependencyNodeCache,
					result));
		}
		disjuctiveNodeCache.put(key, result);
	}

	return result;
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:18,代碼來源:FeatureForest.java

示例9: getAllDependencies

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
private void getAllDependencies(final Key key, final Set<ResolvedDependency> result, final Set<Key> visited) {
	if (visited.contains(key)) {
		return;
	}

	visited.add(key);

	for (final Value value : key.getChildren()) {
		for (final ResolvedDependency dep : value.getDependencies()) {
			result.add(dep);
		}

		for (final Key child : value.getChildren()) {
			getAllDependencies(child, result, visited);
		}
	}

}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:19,代碼來源:CompressedChart.java

示例10: showDependency

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
/**
 * Decide which dependencies are worth showing.
 */
private boolean showDependency(final ResolvedDependency dep, final SyntaxTreeNode parse) {
	final SyntaxTreeNodeLeaf predicateNode = parse.getLeaves().get(dep.getHead());
	if (dep.getHead() == dep.getArgumentIndex()) {
		return false;
	} else if (dep.getSemanticRole() != SRLFrame.NONE) {
		return true;
	} else if (predicateNode.getPos().startsWith("JJ") && dep.getCategory() != Category.valueOf("NP/N")) {
		// Adjectives, excluding determiners
		return true;
	} else if (Category.valueOf("(S\\NP)/(S\\NP)") == dep.getCategory()) {
		// Exclude auxiliary verbs. Hopefully the SRL will have already identified the times this category isn't
		// an auxiliary.
		return false;
	} else if (predicateNode.getPos().startsWith("NN") && dep.getCategory().isFunctionInto(Category.N)) {
		// Checking category to avoid annoying getting a "subject" dep on yesterday|NN|(S\NP)\(S\NP)
		return true;
	} else if (predicateNode.getPos().startsWith("VB")) {
		// Other verb arguments, e.g. particles
		return true;
	} else {
		return false;
	}
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:27,代碼來源:ParsePrinter.java

示例11: printParse

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
@Override
protected void printParse(final SyntaxTreeNode parse, final int sentenceNumber, final StringBuilder result) {
	final List<List<ResolvedDependency>> labels = new ArrayList<>();
	for (final SyntaxTreeNodeLeaf leaf : parse.getLeaves()) {
		labels.add(new ArrayList<>(leaf.getCategory().getNumberOfArguments()));
		for (int i = 0; i < leaf.getCategory().getNumberOfArguments(); i++) {
			labels.get(labels.size() - 1).add(null); // TODO
		}
	}

	for (final ResolvedDependency dep : parse.getAllLabelledDependencies()) {

		final List<ResolvedDependency> labelsForWord = labels.get(dep.getHead());
		if (dep.getArgumentIndex() > -1) {
			labelsForWord.set(dep.getArgNumber() - 1, dep);
		}

	}

	Preconditions.checkState(parse.getSemantics().isPresent());
	result.append(parse.getSemantics().get());
	Util.debugHook();
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:24,代碼來源:ParsePrinter.java

示例12: getLemma

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
/**
 * Gets a lemma for a phrase. Multiword phrases are collapsed into a single token. If a parse is provided, it will
 * collapse verb-particle constructions.
 */
public String getLemma(final String word, final String pos, final Optional<CCGandSRLparse> parse, final int wordIndex) {
	String lemma = word == null ? null : MorphaStemmer.stemToken(word.toLowerCase().replaceAll(" ", "_"), pos);
	if (parse.isPresent()) {
		final List<ResolvedDependency> deps = parse.get().getOrderedDependenciesAtPredicateIndex(wordIndex);
		for (final ResolvedDependency dep : deps) {
			if (dep != null && dep.getCategory().getArgument(dep.getArgNumber()) == Category.PR) {
				// Merge predicates in verb-particle constructions, e.g. pick_up
				lemma = lemma + "_" + parse.get().getLeaf(dep.getArgumentIndex()).getWord();
			}
		}

	}

	return lemma;
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:20,代碼來源:Lexicon.java

示例13: makeCopulaVerb

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
/**
 * Special-case semantics for copular verbs:
 *
 * TODO verbs with expletive arguments and 'other' prepositions
 */
private Logic makeCopulaVerb(final List<ResolvedDependency> deps, final List<Variable> vars, final Variable head,
		final CCGandSRLparse parse) {
	Logic statement;
	if (deps.get(1) != null && deps.get(1).getPreposition() != Preposition.NONE) {
		// S\NP/PP_on --> on(x,y,e)
		statement = new AtomicSentence(getPrepositionPredicate(deps, 1, parse), vars.get(1), vars.get(0), head);
	} else {
		if (deps.get(0) != null && deps.get(0).getPreposition() != Preposition.NONE) {
			// Can happen in questions: S[q]/PP/NP Is the ball on the table?
			statement = new AtomicSentence(getPrepositionPredicate(deps, 0, parse), vars.get(0), vars.get(1), head);
		} else {
			// S\NP/NP
			SemanticType type = SemanticType.T;
			type = SemanticType.make(head.getType(), type);
			type = SemanticType.make(vars.get(1).getType(), type);
			type = SemanticType.make(vars.get(0).getType(), type);
			
			Constant pred = new Constant("eq", type);
			
			statement = new AtomicSentence(pred, vars.get(0), vars.get(1), head);
		}
	}

	return LambdaExpression.make(statement, vars);
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:31,代碼來源:CopulaLexicon.java

示例14: getPrepositionPredicate

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
private String getPrepositionPredicate(final List<ResolvedDependency> deps, final int arg,
		final CCGandSRLparse parse) {
	final Preposition preposition = deps.get(arg).getPreposition();
	String result = preposition.toString();
	if (preposition == Preposition.OTHER) {
		// Hack to fill in the prepositions the parse didn't track. Look for PP/NP nodes whose argument is the same
		// as the PP arg of the verb.
		for (final ResolvedDependency dep : parse.getCcgParse().getAllLabelledDependencies()) {
			if (dep.getCategory().equals(Category.valueOf("PP/NP"))
					&& dep.getArgumentIndex() == deps.get(arg).getArgumentIndex()) {
				result = parse.getCcgParse().getLeaves().get(dep.getHead()).getWord();
			}
		}
	}

	return result.toLowerCase();
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:18,代碼來源:CopulaLexicon.java

示例15: evaluateStep

import edu.uw.easysrl.dependencies.ResolvedDependency; //導入依賴的package包/類
public RetrievalStatistics evaluateStep(final Set<ResolvedDependency> goldDependencies,
                                        final SyntaxTreeNode predictedParse,
                                        final boolean generateDependencies,
                                        final List<InputWord> leaves) {
    final RetrievalStatistics stats = new RetrievalStatistics();
    stats.update(goldDependencies.stream()
                    .filter(dep -> SyntaxUtil.isDependencyAtStep(dep, predictedParse)),
            predictedDependencyStream(predictedParse, generateDependencies, leaves, true));
    return stats;
}
 
開發者ID:uwnlp,項目名稱:neuralccg,代碼行數:11,代碼來源:DependencyEvaluator.java


注:本文中的edu.uw.easysrl.dependencies.ResolvedDependency類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。