use of com.sri.ai.grinder.theory.equality.EqualityTheory in project aic-expresso by aic-sri-international.
the class Tests method main.
public void main(String[] args) {
// Theory initialization
theory = new CompoundTheory(new EqualityTheory(false, true), new DifferenceArithmeticTheory(false, false), new LinearRealArithmeticTheory(false, false), new TupleTheory(), new PropositionalTheory());
context = new TrueContext(theory);
context = context.extendWithSymbolsAndTypes("A", "Boolean");
// Testing BFS Expander
println("Testing BFS.");
testingBFS();
// // Testing on standard output (output results on screen)
// println("Testing and printing on screen.");
// testingAndPrintingOnScreen();
println("Running main test.");
runTest();
}
use of com.sri.ai.grinder.theory.equality.EqualityTheory in project aic-expresso by aic-sri-international.
the class SampleCommonInterpreterTest method setUp.
@Before
public void setUp() {
// Make tests repeatable
random = new Random(1);
context = new TrueContext(new CompoundTheory(new DifferenceArithmeticTheory(false, false), new LinearRealArithmeticTheory(false, false), new EqualityTheory(false, false), new PropositionalTheory()));
}
use of com.sri.ai.grinder.theory.equality.EqualityTheory in project aic-expresso by aic-sri-international.
the class BoundsTest method declareTheoryContextAndSetOfFactors.
@Before
public void declareTheoryContextAndSetOfFactors() {
ExpressoConfiguration.setDisplayNumericsExactlyForSymbols(true);
extensionalBound = new DefaultExtensionalBound();
intensionalBound = new DefaultIntensionalBound();
theory = new CompoundTheory(new EqualityTheory(false, true), new DifferenceArithmeticTheory(false, false), new LinearRealArithmeticTheory(false, false), new TupleTheory(), new PropositionalTheory());
context = new TrueContext(theory);
context = context.extendWithSymbolsAndTypes("X", "Boolean");
context = context.extendWithSymbolsAndTypes("Y", "Boolean");
context = context.extendWithSymbolsAndTypes("A", "Boolean");
context = context.extendWithSymbolsAndTypes("B", "Boolean");
context = context.extendWithSymbolsAndTypes("C", "1..5");
// context = context.extendWithSymbolsAndTypes("D","{1,3,4,8}");
// Set of functions
Expression phi1 = parse("if X = true then 1 else if Y = true then 2 else 3");
Expression phi2 = parse("if A = true then if Y = true then 4 else 5 else 6");
Expression phi3 = parse("if X = true then 7 else if B = true then 8 else 9");
Expression phi4 = parse("if B = true then 10 else if A = true then 11 else 12");
Expression phi5 = parse("if C < 4 then 10 else if C = 4 then 11 else 12");
/*
* This is how we create a non empty extensional bound
*/
setOfFactors = new DefaultExtensionalBound(arrayList(phi1, phi2, phi3, phi4, phi5));
// Set of numbers
setOfNumbers = new DefaultExtensionalBound(arrayList(ONE, TWO));
Set<Expression> factor = new HashSet<Expression>();
model = new Model(factor);
model.context = model.context.extendWithSymbolsAndTypes("A", "Boolean");
model.context = model.context.extendWithSymbolsAndTypes("B", "Boolean");
model.context = model.context.extendWithSymbolsAndTypes("Q", "Boolean");
model.context = model.context.extendWithSymbolsAndTypes("C", "1..4");
model.context = model.context.extendWithSymbolsAndTypes("D", "6..9");
intensionalSetOfFactors1 = new DefaultIntensionalBound(arrayList(parse("A' in Boolean"), parse("C' in 1..5")), parse("if C = C' then if A = A' then 1 else 4 else 0"), TRUE);
intensionalSetOfFactors2 = DefaultIntensionalBound.simplex(arrayList(parse("A")), model);
intensionalSetOfFactors3 = DefaultIntensionalBound.simplex(arrayList(parse("C"), parse("B")), model);
}
use of com.sri.ai.grinder.theory.equality.EqualityTheory in project aic-expresso by aic-sri-international.
the class ExpressionStepSolverToLiteralSplitterStepSolverAdapterTest method testEqualityTheoryWithPropagationOfAllLiteralsWhenBoundWithRandomDisjunctiveFormulas.
@Test
public void testEqualityTheoryWithPropagationOfAllLiteralsWhenBoundWithRandomDisjunctiveFormulas() {
TheoryTestingSupport theoryTestingSupport = TheoryTestingSupport.make(makeRandom(), new EqualityTheory(true, true));
extendTestingVariables("X", theoryTestingSupport, "S", "T", "U", "V", "W");
runRandomDisjunctiveFormulasTest(theoryTestingSupport);
}
use of com.sri.ai.grinder.theory.equality.EqualityTheory in project aic-expresso by aic-sri-international.
the class ExpressionStepSolverToLiteralSplitterStepSolverAdapterTest method testEqualityTheoryWithoutPropagationOfAllLiteralsWhenBoundWithRandomDisjunctiveFormulas.
@Test
public void testEqualityTheoryWithoutPropagationOfAllLiteralsWhenBoundWithRandomDisjunctiveFormulas() {
TheoryTestingSupport theoryTestingSupport = TheoryTestingSupport.make(makeRandom(), new EqualityTheory(true, false));
extendTestingVariables("X", theoryTestingSupport, "S", "T", "U", "V", "W");
runRandomDisjunctiveFormulasTest(theoryTestingSupport);
}
Aggregations