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


Java Expressions.TRUE屬性代碼示例

本文整理匯總了Java中com.sri.ai.expresso.helper.Expressions.TRUE屬性的典型用法代碼示例。如果您正苦於以下問題:Java Expressions.TRUE屬性的具體用法?Java Expressions.TRUE怎麽用?Java Expressions.TRUE使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在com.sri.ai.expresso.helper.Expressions的用法示例。


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

示例1: constructComponentIntensionalSet

private static Expression constructComponentIntensionalSet(Type indexType, IntensionalSet intensionalSet, Expression additiveIdentityElement, Context intensionalSetContext) {
	Expression conditionedBody = IfThenElse.make(intensionalSet.getCondition(), intensionalSet.getHead(), additiveIdentityElement);
	Expression componentIndex  = Expressions.makeUniqueVariable("C", conditionedBody, intensionalSetContext);
	Expression indexExpression = IndexExpressions.makeIndexExpression(componentIndex, Expressions.parse(indexType.getName()));
	
	Expression intensionalCondition = Expressions.TRUE;
	// NOTE: handle the REAL cases where an SingleVariableLinearRealArithmeticConstraint is expected.
	if (indexType instanceof RealExpressoType || indexType instanceof RealInterval) {
		SingleVariableLinearRealArithmeticConstraint svlraConstraint = new SingleVariableLinearRealArithmeticConstraint(componentIndex, true, intensionalSetContext.getTheory());
		intensionalCondition = svlraConstraint;
	}
	
	Expression result = IntensionalSet.make(Sets.isMultiSet(intensionalSet) ? IntensionalSet.MULTI_SET_LABEL : IntensionalSet.UNI_SET_LABEL,
							new ExtensionalIndexExpressionsSet(Arrays.asList(indexExpression)), 								
							componentIndex, 
							intensionalCondition);
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:18,代碼來源:Measure.java

示例2: getQuantifierCondition

private static Expression getQuantifierCondition(Expression quantifier) {
	Expression result;
	if (quantifier instanceof IntensionalSet) {
		result = ((IntensionalSet)quantifier).getCondition();
	}
	else if (quantifier instanceof CountingFormula) {
		result = ((CountingFormula)quantifier).getBody();
	}
	else if (ForAll.isForAll(quantifier) 
			|| ThereExists.isThereExists(quantifier) 
			|| quantifier instanceof LambdaExpression) {
		// No conditions on these quantifiers, just default to true
		result = Expressions.TRUE; 
	}
	else {
		throw new UnsupportedOperationException("Quantifer currently not supported: "+quantifier);
	}
	
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:20,代碼來源:SetOfArgumentTuplesForFunctionOccurringInExpression.java

示例3: simplify

public static Expression simplify(Expression expression, Context context) {
	Expression result = expression;
	if (Equality.isEquality(expression) && expression.numberOfArguments() == 2) {
		Expression extensionalSet = null;
		Expression emptySet       = null;
		for (Expression arg : expression.getArguments()) {
			if (emptySet == null && Sets.isEmptySet(arg)) {
				emptySet = arg;
			}
			else if (extensionalSet == null && Sets.isExtensionalSet(arg)) {
				extensionalSet = arg;
			}
		}
		if (extensionalSet != null && emptySet != null) {
			if (extensionalSet.numberOfArguments() == 0) {
				result = Expressions.TRUE;
			}
			else {
				result = Expressions.FALSE;
			}
		}
	}
	
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:25,代碼來源:ExtensionalSetEqualEmptySetSimplifier.java

示例4: simplify

public static Expression simplify(Expression formula) {
	Expression result;
	if (formula.get(0).equals(Expressions.TRUE)) {
		result = Expressions.FALSE;
	}
	else if (formula.get(0).equals(Expressions.FALSE)) {
		result = Expressions.TRUE;
	}
	else if (formula.get(0).hasFunctor(FunctorConstants.NOT)) {
		result = formula.get(0).get(0);
	}
	else {
		result = formula;
	}
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:16,代碼來源:Not.java

示例5: simplify

public static Expression simplify(Expression disjunction) {
	Expression result = disjunction;
	if (disjunction.getArguments().contains(Expressions.TRUE)) {
		result = Expressions.TRUE;
	}
	else {
		LinkedHashSet<Expression> distinctArgumentsNotEqualToFalse = new LinkedHashSet<Expression>();
		Util.collect(disjunction.getArguments(), distinctArgumentsNotEqualToFalse, e -> ! e.equals(Expressions.FALSE));
		if (distinctArgumentsNotEqualToFalse.size() != disjunction.getArguments().size()) {
			if (distinctArgumentsNotEqualToFalse.size() == 0) {
				result = Expressions.FALSE;
			}
			else if (distinctArgumentsNotEqualToFalse.size() == 1) {
				result = Util.getFirst(distinctArgumentsNotEqualToFalse);
			}
			else if (distinctArgumentsNotEqualToFalse.size() != disjunction.numberOfArguments()) {
				result = Expressions.apply(FunctorConstants.OR, distinctArgumentsNotEqualToFalse);
			}
		}
	}
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:22,代碼來源:Or.java

示例6: simplify

public static Expression simplify(Expression expression) {
	if (expression.get(0).equals(expression.get(1))) {
		return Expressions.TRUE;
	}
	
	if (expression.get(0).equals(Expressions.TRUE)) {
		return expression.get(1);
	}
	else if (expression.get(0).equals(Expressions.FALSE)) {
		return Expressions.TRUE;
	}

	if (expression.get(1).equals(Expressions.TRUE)) {
		return Expressions.TRUE;
	}
	else if (expression.get(1).equals(Expressions.FALSE)) {
		return Not.make(expression.get(0));
	}

	return expression;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:21,代碼來源:Implication.java

示例7: simplify

public static Expression simplify(Expression conjunction) {
	Expression result = conjunction;
	if (conjunction.getArguments().contains(Expressions.FALSE)) {
		result = Expressions.FALSE;
	}
	else {
		LinkedHashSet<Expression> distinctArgumentsNotEqualToTrue = new LinkedHashSet<Expression>();
		Util.collect(conjunction.getArguments(), distinctArgumentsNotEqualToTrue, e -> ! e.equals(Expressions.TRUE));
		if (distinctArgumentsNotEqualToTrue.size() != conjunction.getArguments().size()) {
			if (distinctArgumentsNotEqualToTrue.size() == 0) {
				result = Expressions.TRUE;
			}
			else if (distinctArgumentsNotEqualToTrue.size() == 1) {
				result = Util.getFirst(distinctArgumentsNotEqualToTrue);
			}
			else if (distinctArgumentsNotEqualToTrue.size() != conjunction.numberOfArguments()) {
				result = Expressions.apply(FunctorConstants.AND, distinctArgumentsNotEqualToTrue);
			}
		}
	}
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:22,代碼來源:And.java

示例8: simplify

public static Expression simplify(Expression expression) {
	if (expression.get(0).equals(expression.get(1))) {
		return Expressions.TRUE;
	}
	
	if (expression.get(0).equals(Expressions.TRUE)) {
		return expression.get(1);
	}
	else if (expression.get(0).equals(Expressions.FALSE)) {
		return Not.make(expression.get(1));
	}

	if (expression.get(1).equals(Expressions.TRUE)) {
		return expression.get(0);
	}
	else if (expression.get(1).equals(Expressions.FALSE)) {
		return Not.make(expression.get(0));
	}

	return expression;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:21,代碼來源:Equivalence.java

示例9: simplify

/**
 * Returns FALSE if given disequality has equal arguments, TRUE if they contain distinct constants,
 * and the disequality itself otherwise.
 */
public static Expression simplify(Expression disequality, Context context) {
	Expression result;
	if (disequality.get(0).equals(disequality.get(1))) {
		result = Expressions.FALSE;
	}
	else {
		Set<Expression> constants = new LinkedHashSet<Expression>();
		Set<Expression> nonConstants = new LinkedHashSet<Expression>();
		Util.collect(disequality.getArguments(), constants, context.getIsUniquelyNamedConstantPredicate(), nonConstants);
		if (constants.size() > 1) {
			result = Expressions.TRUE;
		}
		else if (constants.size() == 1 && constants.contains(Expressions.FALSE)) {
			result = And.make(new ArrayList<Expression>(nonConstants));
		}
		else if (constants.size() == 1 && constants.contains(Expressions.TRUE)) {
			ArrayList<Expression> negatedNonConstants = Util.mapIntoArrayList(nonConstants, e -> Not.make(e));
			result = And.make(new ArrayList<Expression>(negatedNonConstants));
		}
		else {
			result = disequality;
		}
	}
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:29,代碼來源:Disequality.java

示例10: simplify

/**
 * Returns TRUE if given equality has all-equal arguments, FALSE if they contain distinct constants,
 * and the equality itself otherwise.
 * Note that this is much faster than eliminating duplicates as well, which requires constructing another equality.
 */
public static Expression simplify(Expression equality, Context context) {
	Expression result;
	if (Util.allEqual(equality.getArguments())) {
		result = Expressions.TRUE;
	}
	else {
		Set<Expression> constants = new LinkedHashSet<Expression>();
		Set<Expression> nonConstants = new LinkedHashSet<Expression>();
		Util.collect(equality.getArguments(), constants, context.getIsUniquelyNamedConstantPredicate(), nonConstants);
		if (constants.size() > 1) {
			result = Expressions.FALSE;
		}
		else if (constants.size() == 1 && constants.contains(Expressions.TRUE)) {
			result = And.make(new ArrayList<Expression>(nonConstants));
		}
		else if (constants.size() == 1 && constants.contains(Expressions.FALSE)) {
			ArrayList<Expression> negatedNonConstants = Util.mapIntoArrayList(nonConstants, e -> Not.make(e));
			result = And.make(new ArrayList<Expression>(negatedNonConstants));
		}
		else {
			result = equality;
		}
	}
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:30,代碼來源:Equality.java

示例11: makeIntensionalSet

protected Expression makeIntensionalSet(Object label, Token scope, List<AntlrGrinderParser.ExprContext> scopeargs, 
		AntlrGrinderParser.ExprContext head, AntlrGrinderParser.ExprContext condition) {
	List<Expression> indexExpressionsList = Util.list();
	if (scope != null) {
		indexExpressionsList = expressionsList(scopeargs);
	}
	Expression headExpression      = visit(head);
	Expression conditionExpression = null;
	if (condition != null) {
		conditionExpression = Expressions.makeExpressionOnSyntaxTreeWithLabelAndSubTrees(IntensionalSet.CONDITION_LABEL, visit(condition));
	}

	Expression result = null;
	if (scope == null && conditionExpression == null) {
		// We need to construct an extensional set in this case
		if (label.equals(IntensionalSet.UNI_SET_LABEL)) {
			result = ExtensionalSets.makeUniSet(headExpression);
		}
		else {
			result = ExtensionalSets.makeMultiSet(Arrays.asList(headExpression));
		}
	}
	else {
		conditionExpression = conditionExpression == null? Expressions.TRUE : conditionExpression.get(0); // contains the "|";
		result = IntensionalSet.make(label, new ExtensionalIndexExpressionsSet(indexExpressionsList), headExpression, conditionExpression);
	}
	
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:29,代碼來源:ExpressionVisitor.java

示例12: updatePossibleLeaf

private static Expression updatePossibleLeaf(Expression possibleLeaf) {
	Expression result = possibleLeaf;
	if (!IfThenElse.isIfThenElse(possibleLeaf) 
			&& !Expressions.TRUE.equals(possibleLeaf) 
			&& !Expressions.FALSE.equals(possibleLeaf)) {
		if (Sets.isEmptySet(possibleLeaf)) {
			result = Expressions.TRUE;
		}
		else {
			result = Expressions.FALSE;
		}
	}
	
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:15,代碼來源:SetExpressionIsEqualToEmptySet.java

示例13: make

/** Make a "not" application on given expression. */
public static Expression make(Expression expression) {
	if (expression.equals(Expressions.TRUE)) {
		return Expressions.FALSE;
	}
	if (expression.equals(Expressions.FALSE)) {
		return Expressions.TRUE;
	}
	return Expressions.apply("not", expression);
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:10,代碼來源:Not.java

示例14: makeWithConstantSimplification

/**
 * Makes a disequality application on two terms possibly simplifying it (taking constants into account).
 */
public static Expression makeWithConstantSimplification(Expression term1, Expression term2, Context context) {
	Expression result;
	if (term1.equals(term2)) {
		result = Expressions.FALSE;
	}
	else if (context.isUniquelyNamedConstant(term1) && context.isUniquelyNamedConstant(term2)) {
		result = Expressions.TRUE;
	}
	else {
		result = make(term1, term2);
	}
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:16,代碼來源:Disequality.java

示例15: simplifyGivenDisequality

/**
 * Returns an expression equivalent to disequality (and perhaps simpler) given a disequality.
 */
public static Expression simplifyGivenDisequality(Expression disequality, Expression variable, Expression otherTerm) {
	Expression result;
	if (disequality.getArguments().contains(variable) && disequality.getArguments().contains(otherTerm)) {
		result = Expressions.TRUE;
	}
	else {
		result = disequality;
	}
	return result;
}
 
開發者ID:aic-sri-international,項目名稱:aic-expresso,代碼行數:13,代碼來源:Disequality.java


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