#include #include #include #include #include //////////////////////////////////////////////////////////////////////////////////////////////////// TEST_CASE("[simplification] Rules are simplified correctly", "[simplification]") { std::stringstream input; std::stringstream output; std::stringstream errors; anthem::output::Logger logger(output, errors); anthem::Context context(std::move(logger)); context.performSimplification = true; context.performCompletion = false; SECTION("example 1") { input << ":- in(I, S), in(J, S), in(I + J, S)."; anthem::translate("input", input, context); CHECK(output.str() == "((in(U1, U2) and in(U3, U2) and exists X1 (X1 in (U1 + U3) and in(X1, U2))) -> #false)\n"); } SECTION("example 2") { input << "covered(I) :- in(I, S)."; anthem::translate("input", input, context); CHECK(output.str() == "((V1 = U1 and in(U1, U2)) -> covered(V1))\n"); } SECTION("example 3") { input << ":- not covered(I), I = 1..n."; anthem::translate("input", input, context); CHECK(output.str() == "((not covered(U1) and U1 in (1..n)) -> #false)\n"); } SECTION("comparisons") { input << ":- M > N."; anthem::translate("input", input, context); CHECK(output.str() == "(U1 > U2 -> #false)\n"); } SECTION("biconditionals are replaced with implifactions with choice rules") { context.performCompletion = true; input << "{p(a)}."; anthem::translate("input", input, context); CHECK(output.str() == "forall V1 (p(V1) -> V1 = a)\n"); } SECTION("biconditionals are replaced with implifactions with complicated choice rules") { context.performCompletion = true; input << "{p(n + 5)}."; anthem::translate("input", input, context); CHECK(output.str() == "forall V1 (p(V1) -> V1 in (n + 5))\n"); } SECTION("biconditionals are not replaced with implifactions with nonchoice rules") { context.performCompletion = true; input << "p(a)."; anthem::translate("input", input, context); CHECK(output.str() == "forall V1 (p(V1) <-> V1 = a)\n"); } }