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


Java CCGBankEvaluation類代碼示例

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


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

示例1: DependencyEvaluator

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
public DependencyEvaluator(final File modelDir,
                           final Stream<DependencyParse> trainSentences) {
    try {
        dependencyGenerator = new DependencyGenerator(modelDir);
    } catch (final IOException e) {
        throw new RuntimeException(e);
    }

    log.info("Counting valid dependencies...");
    final ConcurrentHashMultiset<String> dependencyCounts = ConcurrentHashMultiset.create();
    trainSentences
            .parallel()
            .map(DependencyParse::getDependencies)
            .map(CCGBankEvaluation::asResolvedDependencies)
            .flatMap(Set::stream)
            .forEach(dep -> dependencyCounts.add(
                    dep.getCategory().toString() + dep.getArgNumber()));
    validDependencies = dependencyCounts.entrySet().stream()
            .filter(entry -> entry.getCount() >= 10)
            .map(Entry::getElement)
            .collect(Collectors.toSet());
    log.info("{} valid dependencies found", validDependencies.size());
}
 
開發者ID:uwnlp,項目名稱:neuralccg,代碼行數:24,代碼來源:DependencyEvaluator.java

示例2: predictedDependencyStream

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的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

示例3: scoreNode

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的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

示例4: GoldInputToParser

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
public GoldInputToParser(final DependencyParse goldParse, final List<List<ScoredCategory>> inputSupertags) {
    super(
            goldParse.getWords(),
            goldParse.getLeaves()
                    .stream()
                    .map(SyntaxTreeNode::getCategory)
                    .collect(Collectors.toList()),
            inputSupertags,
            inputSupertags != null);
    this.goldDependencies = CCGBankEvaluation.asResolvedDependencies(goldParse.getDependencies());
    this.oracleParse = null;
}
 
開發者ID:uwnlp,項目名稱:neuralccg,代碼行數:13,代碼來源:OracleModel.java

示例5: loadFromTestPool

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
public static Optional<ParseData> loadFromTestPool(boolean includeGold) {
    if (includeGold) {
        System.err.println("### Waring ### Reading test data with gold parses.");
    }
    POSTagger postagger = POSTagger.getStanfordTagger(Util.getFile(BaseCcgParser.modelFolder + "/posTagger"));
    List<List<InputReader.InputWord>> sentenceInputWords = new ArrayList<>();
    List<Parse> goldParses = new ArrayList<>();
    Iterator<ParallelCorpusReader.Sentence> sentenceIterator;
    try {
        sentenceIterator = ParallelCorpusReader.READER.readCcgTestSet();
    } catch (IOException e) {
        System.out.println(String.format("Failed to read %d sentences.", sentenceInputWords.size()));
        return Optional.empty();
    }
    while (sentenceIterator.hasNext()) {
        ParallelCorpusReader.Sentence sentence = sentenceIterator.next();
        List<InputReader.InputWord> taggedInput = postagger.tag(sentence.getInputWords());
        sentenceInputWords.add(taggedInput);
        Set<ResolvedDependency> goldDependencies = CCGBankEvaluation
                .asResolvedDependencies(sentence.getCCGBankDependencyParse().getDependencies());
        if (includeGold) {
            goldParses.add(new Parse(sentence.getCcgbankParse(), sentence.getLexicalCategories(), goldDependencies));
        } else {
            goldParses.add(null);
        }
    }
    System.out.println(String.format("Read %d sentences.", sentenceInputWords.size()));
    return Optional.of(makeParseData(sentenceInputWords, goldParses));
}
 
開發者ID:uwnlp,項目名稱:hitl_parsing,代碼行數:30,代碼來源:ParseDataLoader.java

示例6: loadFromPropBank

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
private static Optional<ParseData> loadFromPropBank(final boolean readDev) {
    if(readDev && devData != null) {
        return devData;
    }
    POSTagger postagger = POSTagger.getStanfordTagger(Util.getFile(BaseCcgParser.modelFolder + "/posTagger"));
    List<List<InputReader.InputWord>> sentenceInputWords = new ArrayList<>();
    List<Parse> goldParses = new ArrayList<>();
    Iterator<ParallelCorpusReader.Sentence> sentenceIterator;
    try {
        sentenceIterator = ParallelCorpusReader.READER.readCcgCorpus(readDev);
    } catch (IOException e) {
        System.out.println(String.format("Failed to read %d sentences.", sentenceInputWords.size()));
        devData = Optional.empty();
        return devData;
    }
    while (sentenceIterator.hasNext()) {
        ParallelCorpusReader.Sentence sentence = sentenceIterator.next();
        List<InputReader.InputWord> taggedInput = postagger.tag(sentence.getInputWords());
        sentenceInputWords.add(taggedInput);
        Set<ResolvedDependency> goldDependencies = CCGBankEvaluation
                .asResolvedDependencies(sentence.getCCGBankDependencyParse().getDependencies());
        goldParses.add(new Parse(sentence.getCcgbankParse(), sentence.getLexicalCategories(), goldDependencies));
    }
    System.out.println(String.format("Read %d sentences.", sentenceInputWords.size()));
    Optional<ParseData> data = Optional.of(makeParseData(sentenceInputWords, goldParses));
    if(readDev) {
        devData = data;
    }
    return data;
}
 
開發者ID:uwnlp,項目名稱:hitl_parsing,代碼行數:31,代碼來源:ParseDataLoader.java

示例7: getParse

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
protected Parse getParse(final List<InputReader.InputWord> sentence, final Scored<SyntaxTreeNode> scoredParse,
                         DependencyGenerator dependencyGenerator) {
    SyntaxTreeNode ccgParse = scoredParse.getObject();
    List<Category> categories = ccgParse.getLeaves().stream().map(SyntaxTreeNode::getCategory)
            .collect(Collectors.toList());
    Set<UnlabelledDependency> unlabelledDeps = new HashSet<>();
    dependencyGenerator.generateDependencies(ccgParse, unlabelledDeps);
    Set<ResolvedDependency> dependencies = CCGBankEvaluation.convertDeps(sentence, unlabelledDeps)
                    .stream()
                    .filter(x -> x.getHead() != x.getArgument())
                    .filter(x -> frequentDependenciesSet.contains(x.getCategory() + "." +  x.getArgNumber()))
                    .collect(Collectors.toSet());
    return new Parse(scoredParse.getObject(), categories, dependencies, scoredParse.getScore());
}
 
開發者ID:uwnlp,項目名稱:hitl_parsing,代碼行數:15,代碼來源:BaseCcgParser.java

示例8: buildAgenda

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
@Override
public void buildAgenda(final Agenda queue, final List<InputWord> words) {
	int i = 0;
	for (final InputWord w : words) {

		double max = 0.0;
		final Category goldCat = goldDeps.getLeaves().get(i).getCategory();
		for (final ScoredCategory scoredCat : tags.get(i)) {
			final Category c = scoredCat.getCategory();
			int numberOfDeps = 0;
			for (int j = 1; j <= c.getNumberOfArguments(); j++) {
				if (!CCGBankEvaluation.filter(this.words.get(i), c, j)) {
					numberOfDeps++;
				}
			}
			max = Math.max(max, scoredCat.getScore());
			if (c != goldCat) {
				// continue;
			} else {
				continue;
			}
			final int upperBound = c == goldCat ? goldDeps.getDependencies(i).size() : -numberOfDeps;
			queue.add(new AgendaItem(new SyntaxTreeNodeLeaf(w.word, w.pos, w.ner, c, i), scoredCat.getScore()
					* catScore, getOutsideUpperBound(i, i + 1) + upperBound, i, 1, true));

		}

		if (categories.contains(goldCat)) {
			queue.add(new AgendaItem(new SyntaxTreeNodeLeaf(w.word, w.pos, w.ner, goldCat, i), max * catScore,
					getOutsideUpperBound(i, i + 1) + goldDeps.getDependencies(i).size(), i, 1, true));
		}

		i++;
	}

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

示例9: makePipelineParser

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
private static PipelineSRLParser makePipelineParser(final File folder,
		final CommandLineArguments commandLineOptions, final double supertaggerBeam,
		final boolean outputDependencies) throws IOException {
	final POSTagger posTagger = POSTagger.getStanfordTagger(new File(folder, "posTagger"));
	final File labelClassifier = new File(folder, "labelClassifier");
	final LabelClassifier classifier = labelClassifier.exists() && outputDependencies ? Util
			.deserialize(labelClassifier) : CCGBankEvaluation.dummyLabelClassifier;

			return new PipelineSRLParser(new ParserAStar.Builder(folder).maxChartSize(100000)
			.supertaggerBeam(supertaggerBeam).nBest(commandLineOptions.getNbest())
			.maximumSentenceLength(commandLineOptions.getMaxLength()).build(), classifier, posTagger);
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:13,代碼來源:EasySRL.java

示例10: main

import edu.uw.easysrl.syntax.evaluation.CCGBankEvaluation; //導入依賴的package包/類
public static void main(final String[] args) throws IOException {
	final String pipelineFolder = Util.getHomeFolder() + "/Downloads/cnn/models/model_ccgbank";
	final Set<Category> categories = ImmutableSet.copyOf(TaggerEmbeddings.loadCategories(new File(pipelineFolder,
			"categories")));
	final Tagger tagger = Tagger.make(Util.getFile("~/Downloads/cnn/models/model_ccgbank"), 0.001, 50, null);// 0.1
	final OracleDependenciesModelFactory modelFactory = new OracleDependenciesModelFactory(tagger, categories);

	final File output = new File(Util.getHomeFolder() + "/Downloads/cnn/ccgbank_oracle0.01/train.stagged");
	final ParserAStar parser = new ParserAStar(modelFactory, 250, 1, Arrays.asList(Category.valueOf("S[dcl]"),
			Category.valueOf("S[q]"), Category.valueOf("S[wq]"), Category.valueOf("NP"),
			Category.valueOf("S[b]\\NP"), Category.valueOf("NP[nb]")), new File(pipelineFolder), 100000);
	int coverage = 0;
	int sentences = 0;
	int correctTags = 0;
	int totalTags = 0;
	final PrintWriter out = new PrintWriter(output);
	final Results results = new Results();
	for (final DependencyParse gold : CCGBankDependencies.loadCorpus(

			new File("/Users/mike/Documents/git/easyccg/testfiles/ccgbank"), Partition.TRAIN)) {

		final List<Scored<SyntaxTreeNode>> parses = parser.doParsing(new InputToParserWithGoldDeps(gold.getWords(),
				null, null, false, gold));

		if (sentences % 100 == 0) {
			System.out.println("Coverage:     " + Util.twoDP(100.0 * coverage / sentences));
			System.out.println("Supertagging: " + Util.twoDP(100.0 * correctTags / totalTags));
			System.out.println(results);
		}
		sentences++;
		if (parses == null) {
			continue;
		}
		coverage++;
		final SyntaxTreeNode parse = parses.get(0).getObject();
		int tagAcc = 0;
		for (int i = 0; i < gold.getWords().size(); i++) {
			if (parse.getLeaves().get(i).getCategory() == gold.getLeaves().get(i).getCategory()) {
				tagAcc++;
			}
		}

		final Set<UnlabelledDependency> deps2 = new HashSet<>();
		CCGBankEvaluation.extractDependencies(parse, deps2);
		Set<ResolvedDependency> deps = CCGBankEvaluation.convertDeps(gold.getWords(), deps2);
		final Set<ResolvedDependency> goldDeps = ImmutableSet.copyOf(gold.getResolvedDependencies());

		deps = deps.stream().filter(x -> validDeps.count(x.getCategory().toString() + x.getArgNumber()) >= 10)
				.collect(Collectors.toSet());

		results.add(new Results(deps.size(), com.google.common.collect.Sets.intersection(deps, goldDeps).size(),
				goldDeps.size()));

		correctTags += tagAcc;
		totalTags += gold.getWords().size();
		if (tagAcc < gold.getWords().size()) {
			System.out.println(tagAcc + "/" + gold.getWords().size());
			// System.out.println(ParsePrinter.SUPERTAG_PRINTER.print(parses.get(0).getObject(), 0));
			for (int i = 0; i < gold.getWords().size(); i++) {
				System.out.print(gold.getWords().get(i).word);
				if (parse.getLeaves().get(i).getCategory() != gold.getLeaves().get(i).getCategory()) {
					System.out.print("|" + gold.getLeaves().get(i).getCategory() + "|"
							+ parse.getLeaves().get(i).getCategory());
				}

				System.out.print(" ");
			}
			System.out.println();
		}

		out.println(ParsePrinter.SUPERTAG_PRINTER.print(parses.get(0).getObject(), 0));

	}

	out.close();
}
 
開發者ID:uwnlp,項目名稱:EasySRL,代碼行數:77,代碼來源:OracleDependenciesModel.java


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