use of com.sri.ai.grinder.sgdpllt.tester.TheoryTestingSupport in project aic-expresso by aic-sri-international.
the class SummationOnDifferenceArithmeticAndPolynomialStepSolverTest method polynomialBodyTest.
@Test
public void polynomialBodyTest() {
TheoryTestingSupport theoryTestingSupport = TheoryTestingSupport.make(makeRandom(), new DifferenceArithmeticTheory(true, true));
Context context = theoryTestingSupport.makeContextWithTestingInformation();
Expression variable;
String constraintString;
Expression body;
Expression expected;
variable = parse("I");
body = parse("I^2 - I + 1");
constraintString = "true";
expected = parse("25");
runTest(variable, constraintString, body, expected, context);
constraintString = "I != 3";
expected = parse("18");
runTest(variable, constraintString, body, expected, context);
constraintString = "I < 3";
expected = parse("5");
runTest(variable, constraintString, body, expected, context);
constraintString = "false";
expected = parse("0");
runTest(variable, constraintString, body, expected, context);
constraintString = "I > 3 and I < 3";
expected = parse("0");
runTest(variable, constraintString, body, expected, context);
constraintString = "I > 1 and I < 3 and I != 2";
expected = parse("0");
runTest(variable, constraintString, body, expected, context);
}
use of com.sri.ai.grinder.sgdpllt.tester.TheoryTestingSupport in project aic-expresso by aic-sri-international.
the class ValuesOfSingleVariableDifferenceArithmeticConstraintStepSolverTest method test.
@Test
public void test() {
TheoryTestingSupport theoryTestingSupport = TheoryTestingSupport.make(makeRandom(), new DifferenceArithmeticTheory(true, true));
theoryTestingSupport.setVariableNamesAndTypesForTesting(map("I", new IntegerInterval(0, 4), "J", new IntegerInterval(0, 4), "K", new IntegerInterval(0, 4)));
Context context = theoryTestingSupport.makeContextWithTestingInformation();
Expression variable;
String constraintString;
Expression expected;
variable = parse("I");
constraintString = "true";
expected = parse("aboveAndUpTo(-1, 4)");
runTest(variable, constraintString, expected, context);
variable = parse("I");
constraintString = "false";
expected = parse("{}");
runTest(variable, constraintString, expected, context);
variable = parse("I");
constraintString = "I < 3 and J > I";
expected = parse("if 3 > J then if 0 < J then aboveAndUpTo(-1, J - 1) else {} else aboveAndUpTo(-1, 2)");
runTest(variable, constraintString, expected, context);
variable = parse("I");
constraintString = "I < 3 and J > I and I != 2";
expected = parse("if 3 > J then if 0 < J then aboveAndUpTo(-1, J - 1) else {} else aboveAndUpTo(-1, 2) - { 2 }");
runTest(variable, constraintString, expected, context);
variable = parse("I");
constraintString = "I < 3 and J > I and I != 2 and I != K";
expected = parse("if 3 > J then if 0 < J then if K + 1 <= J then aboveAndUpTo(-1, J - 1) - { K } else aboveAndUpTo(-1, J - 1) else {} else if K <= 2 then if 2 = K then aboveAndUpTo(-1, 2) - { K } else aboveAndUpTo(-1, 2) - { 2, K } else aboveAndUpTo(-1, 2) - { 2 }");
runTest(variable, constraintString, expected, context);
}
use of com.sri.ai.grinder.sgdpllt.tester.TheoryTestingSupport in project aic-expresso by aic-sri-international.
the class AbstractEqualityConstraintTest method testSatisfiabilitySpecialCases.
@Test
public void testSatisfiabilitySpecialCases() {
String conjunction;
// looks unsatisfiable for type size 5, but it is not
conjunction = "X != a and X != b and X != c and X != Y and X != Z";
TheoryTestingSupport theoryTestingSupport = makeTheoryTestingSupport();
Constraint constraint = new SingleVariableEqualityConstraint(parse("X"), false, theoryTestingSupport.getTheory());
Context context = theoryTestingSupport.makeContextWithTestingInformation();
constraint = constraint.conjoinWithConjunctiveClause(parse(conjunction), context);
// satisfiable if either Y or Z is equal to a, b, c, or each other.
Assert.assertNotEquals(null, constraint);
}
use of com.sri.ai.grinder.sgdpllt.tester.TheoryTestingSupport in project aic-expresso by aic-sri-international.
the class AbstractEqualityConstraintTest method runCompleteSatisfiabilityTest.
/**
* @param conjunction
* @param expected
*/
private void runCompleteSatisfiabilityTest(String conjunction, Expression expected, TheoryTestingSupport theoryTestingSupport) {
Context context = theoryTestingSupport.makeContextWithTestingInformation();
Constraint constraint = new CompleteMultiVariableContext(theoryTestingSupport.getTheory(), context);
for (Expression literal : And.getConjuncts(parse(conjunction))) {
constraint = constraint.conjoin(literal, context);
if (constraint.isContradiction()) {
break;
}
}
if (expected == null && !constraint.isContradiction()) {
throw new AssertionError("Expected null but was <" + constraint + ">");
} else if (expected != null && constraint.isContradiction()) {
throw new AssertionError("Expected <" + expected + "> but was null");
} else if (expected != null && !constraint.isContradiction() && !expected.equals(constraint)) {
Simplifier interpreter = (e, c) -> theoryTestingSupport.getTheory().evaluate(e, c);
// Simplifier interpreter = new Evaluator(theoryTestingSupport.getTheory());
Expression equivalenceDefinition = apply(EQUIVALENCE, expected, constraint);
Expression universallyQuantified = universallyQuantifyFreeVariables(equivalenceDefinition, context);
Expression equivalent = interpreter.apply(universallyQuantified, context);
if (equivalent.equals(FALSE)) {
throw new Error("Expected <" + expected + "> but got <" + constraint + ">, which is not equivalent either");
}
}
}
use of com.sri.ai.grinder.sgdpllt.tester.TheoryTestingSupport in project aic-expresso by aic-sri-international.
the class LinearRealArithmeticTheoryTest method testSummation.
@Test
public void testSummation() {
TheoryTestingSupport theoryTestingSupport = TheoryTestingSupport.make(makeRandom(), new LinearRealArithmeticTheory(true, true));
Context context = theoryTestingSupport.makeContextWithTestingInformation();
Simplifier simplifier = (e, c) -> theoryTestingSupport.getTheory().simplify(e, c);
Expression variable;
String constraintString;
String bodyString;
Expression expected;
variable = parse("X");
constraintString = "true";
bodyString = "1";
expected = parse("4");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < 3 and X != 2";
bodyString = "1";
expected = parse("3");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < Y and X != 2";
bodyString = "1";
expected = parse("if Y > 0 then Y else 0");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < 3 and X != 2";
bodyString = "Y";
expected = parse("3*Y");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < 3 and X != 2";
bodyString = "X";
expected = parse("4.5");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < 3 and X != 2 and X = 2";
bodyString = "Y";
expected = parse("0");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < Y and X != 2";
bodyString = "X";
expected = parse("if Y > 0 then 0.5*Y^2 else 0");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < Y and X != 2";
bodyString = "Y";
expected = parse("if Y > 0 then Y^2 else 0");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
variable = parse("X");
constraintString = "X < Y and X != 2";
bodyString = "X + Y";
expected = parse("if Y > 0 then 1.5*Y^2 else 0");
runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
// variable = parse("X");
// constraintString = "X < Y and X != 2";
// bodyString = "X^2 + Y";
// expected = parse("if Y > 0 then 0.333333333*Y^3 + Y^2 else 0");
// runSummationTest(variable, constraintString, bodyString, expected, simplifier, context);
}
Aggregations