当前位置: 首页>>代码示例>>Java>>正文


Java Type.isComplex方法代码示例

本文整理汇总了Java中edu.cornell.cs.nlp.spf.mr.language.type.Type.isComplex方法的典型用法代码示例。如果您正苦于以下问题:Java Type.isComplex方法的具体用法?Java Type.isComplex怎么用?Java Type.isComplex使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在edu.cornell.cs.nlp.spf.mr.language.type.Type的用法示例。


在下文中一共展示了Type.isComplex方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: typeToSyntax

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
public static Syntax typeToSyntax(Type type) {
	if (type instanceof RecursiveComplexType) {
		// Basically something like and:<t*,t>, so we need two arguments, to
		// get something like N|N|N
		final RecursiveComplexType recursiveType = (RecursiveComplexType) type;
		return new ComplexSyntax(
				typeToSyntax(recursiveType.getFinalRange()),
				recurviseArgsToSyntax(recursiveType.getDomain(),
						recursiveType.getMinArgs()), Slash.VERTICAL);
	} else if (type.isComplex()) {
		return new ComplexSyntax(typeToSyntax(type.getRange()),
				typeToSyntax(type.getDomain()), Slash.VERTICAL);
	} else if (type == LogicLanguageServices.getTypeRepository()
			.getTruthValueType()) {
		// Case primitive type.
		// All things of type T have CCG category S
		return Syntax.S;
	} else {
		// Else NP
		return Syntax.NP;
	}
}
 
开发者ID:clic-lab,项目名称:spf,代码行数:23,代码来源:SplittingServices.java

示例2: isPartialLiteral

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
protected boolean isPartialLiteral(Literal literal) {
	// Count number of arguments on predicate type
	Type type = literal.getPredicateType();
	int numArgs = 0;
	while (type.isComplex()) {
		if (type instanceof RecursiveComplexType) {
			numArgs += ((RecursiveComplexType) type).getMinArgs();
			type = ((RecursiveComplexType) type).getFinalRange();
		} else {
			++numArgs;
			type = type.getRange();
		}
	}

	return literal.numArgs() < numArgs;
}
 
开发者ID:clic-lab,项目名称:spf,代码行数:17,代码来源:Evaluation.java

示例3: isEntityToTruthType

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
private static boolean isEntityToTruthType(Type type) {
	if (type.isComplex()) {
		final Type genType = LogicLanguageServices.getTypeRepository()
				.generalizeType(type);
		return LogicLanguageServices.getTypeRepository().getEntityType()
				.equals(((ComplexType) genType).getDomain())
				&& LogicLanguageServices.getTypeRepository()
						.getTruthValueType()
						.equals(((ComplexType) genType).getRange());
	} else {
		return false;
	}
}
 
开发者ID:clic-lab,项目名称:spf,代码行数:14,代码来源:AToExists.java

示例4: visit

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
@Override
public void visit(LogicalConstant logicalConstant) {
	final Type type = logicalConstant.getType();
	if (!type.isArray() && !type.isComplex()) {
		constants.add(logicalConstant);
	}
}
 
开发者ID:clic-lab,项目名称:spf,代码行数:8,代码来源:GetAllSimpleLogicalConstants.java

示例5: getFinalType

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
public static Type getFinalType(Type type) {
	Type currentType = type;
	while (!(currentType instanceof RecursiveComplexType)
			&& currentType.isComplex()) {
		currentType = currentType.getRange();
	}
	return currentType;
}
 
开发者ID:clic-lab,项目名称:amr,代码行数:9,代码来源:AMRServices.java

示例6: typeShiftSemantics

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
/**
 * (lambda $0:x (g $0)) ==> (lambda $0:<x,t> (lambda $1:x (and:<t*,t> ($0
 * $1) (g $1))))
 */
protected LogicalExpression typeShiftSemantics(LogicalExpression sem) {
	final Type semType = sem.getType();
	final Type range = semType.getRange();

	if (semType.isComplex()
			&& range.equals(LogicLanguageServices.getTypeRepository()
					.getTruthValueType())) {

		// Make sure the expression is wrapped with lambda operators, since
		// the variables are required
		final Lambda lambda = (Lambda) sem;

		// Variable for the new outer lambda
		final Variable outerVariable = new Variable(LogicLanguageServices
				.getTypeRepository().getTypeCreateIfNeeded(
						LogicLanguageServices.getTypeRepository()
								.getTruthValueType(),
						lambda.getArgument().getType()));

		// Create the literal applying the function to the original
		// argument
		final LogicalExpression[] args = new LogicalExpression[1];
		args[0] = lambda.getArgument();
		final Literal newLiteral = new Literal(outerVariable, args);

		// Create the conjunction of newLitral and the original body
		final Literal conjunction = new Literal(
				LogicLanguageServices.getConjunctionPredicate(),
				ArrayUtils.create(newLiteral, lambda.getBody()));

		// The new inner lambda
		final Lambda innerLambda = new Lambda(lambda.getArgument(),
				conjunction);

		// The new outer lambda
		final Lambda outerLambda = new Lambda(outerVariable, innerLambda);

		// Simplify the output and return it
		final LogicalExpression ret = Simplify.of(outerLambda);

		return ret;
	}

	return null;
}
 
开发者ID:clic-lab,项目名称:spf,代码行数:50,代码来源:SententialAdverbialTypeShifting.java

示例7: typeShiftSemantics

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
/**
 * (lambda $0:x (g $0)) ==> (lambda $0:<x,t> (lambda $1:x (and:<t*,t> ($0
 * $1) (g $1))))
 */
protected LogicalExpression typeShiftSemantics(LogicalExpression sem) {
	final Type semType = sem.getType();
	final Type range = semType.getRange();

	if (semType.isComplex() && range.equals(LogicLanguageServices
			.getTypeRepository().getTruthValueType())) {

		// Make sure the expression is wrapped with lambda operators, since
		// the variables are required
		final Lambda lambda = (Lambda) sem;

		// Variable for the new outer lambda
		final Variable outerVariable = new Variable(LogicLanguageServices
				.getTypeRepository().getTypeCreateIfNeeded(
						LogicLanguageServices.getTypeRepository()
								.getTruthValueType(),
						lambda.getArgument().getType()));

		// Create the literal applying the function to the original
		// argument
		final LogicalExpression[] args = new LogicalExpression[1];
		args[0] = lambda.getArgument();
		final Literal newLiteral = new Literal(outerVariable, args);

		// Create the conjunction of newLitral and the original body
		final Literal conjunction = new Literal(
				LogicLanguageServices.getConjunctionPredicate(),
				ArrayUtils.create(newLiteral, lambda.getBody()));

		// The new inner lambda
		final Lambda innerLambda = new Lambda(lambda.getArgument(),
				conjunction);

		// The new outer lambda
		final Lambda outerLambda = new Lambda(outerVariable, innerLambda);

		// Simplify the output and return it
		final LogicalExpression ret = Simplify.of(outerLambda);

		return ret;
	}

	return null;
}
 
开发者ID:clic-lab,项目名称:spf,代码行数:49,代码来源:AbstractShiftingRule.java

示例8: apply

import edu.cornell.cs.nlp.spf.mr.language.type.Type; //导入方法依赖的package包/类
@Override
public ParseRuleResult<LogicalExpression> apply(
		Category<LogicalExpression> left,
		Category<LogicalExpression> right, SentenceSpan span) {

	// Right side must be a complex category.
	if (!(right instanceof ComplexCategory<?>)) {
		return null;
	}
	// It's the secondary argument of the composition.
	final ComplexCategory<LogicalExpression> secondary = (ComplexCategory<LogicalExpression>) right;

	// Verify secondary slash.
	if (!secondary.hasSlash(Slash.FORWARD)) {
		return null;
	}

	// Get the embedded X from the secondary. First verify we have the right
	// structure.
	if (!(secondary.getSyntax().getLeft() instanceof ComplexSyntax)
			|| !((ComplexSyntax) secondary.getSyntax().getLeft())
					.getSlash().equals(Slash.BACKWARD)) {
		return null;
	}
	final Syntax secondaryT = ((ComplexSyntax) secondary.getSyntax()
			.getLeft()).getLeft();
	final Syntax secondaryX = ((ComplexSyntax) secondary.getSyntax()
			.getLeft()).getRight();

	// Verify the Xs (see javadoc above) match.
	if (secondaryX.unify(left.getSyntax()) == null) {
		return null;
	}

	// Get the semantic type of the final result in the type raised
	// semantics.
	final Type secondaryReturnType = secondary.getSemantics().getType()
			.getRange();
	// Verify it matches the type of the primary semantics.
	if (secondaryReturnType == null
			|| !secondaryReturnType.isComplex()
			|| !left.getSemantics()
					.getType()
					.isExtendingOrExtendedBy(
							secondaryReturnType.getDomain())) {
		return null;
	}

	// Apply type raising.
	final ParseRuleResult<LogicalExpression> raisingResult = typeRaising
			.apply(left, left.getSyntax(), secondaryT,
					secondaryReturnType.getRange());
	if (raisingResult == null) {
		return null;
	}

	final ParseRuleResult<LogicalExpression> compositionResult = doComposition(
			raisingResult.getResultCategory(), right, false);

	if (compositionResult == null) {
		return null;
	}

	return new ParseRuleResult<LogicalExpression>(getName(),
			compositionResult.getResultCategory());
}
 
开发者ID:clic-lab,项目名称:spf,代码行数:67,代码来源:ForwardTypeRaisedComposition.java


注:本文中的edu.cornell.cs.nlp.spf.mr.language.type.Type.isComplex方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。