Implemented prenex normalization.
This commit is contained in:
@@ -173,13 +173,11 @@ TEST(PDDLNormalizationTests, SimplifyNestedForAll)
|
||||
auto f1 = expressions::ForAllPointer(new expressions::ForAll);
|
||||
auto f2 = expressions::ForAllPointer(new expressions::ForAll);
|
||||
|
||||
auto d = expressions::DummyPointer(new expressions::Dummy("a"));
|
||||
|
||||
f1->variables() = {v1, v2, v3};
|
||||
f2->variables() = {v4, v5, v6};
|
||||
|
||||
f1->setArgument(f2);
|
||||
f2->setArgument(d);
|
||||
f2->setArgument(new expressions::Dummy("a"));
|
||||
|
||||
std::stringstream output;
|
||||
f1->normalized()->print(output);
|
||||
@@ -201,16 +199,47 @@ TEST(PDDLNormalizationTests, SimplifyNestedExists)
|
||||
auto e1 = expressions::ExistsPointer(new expressions::Exists);
|
||||
auto e2 = expressions::ExistsPointer(new expressions::Exists);
|
||||
|
||||
auto d = expressions::DummyPointer(new expressions::Dummy("a"));
|
||||
|
||||
e1->variables() = {v1, v2, v3};
|
||||
e2->variables() = {v4, v5, v6};
|
||||
|
||||
e1->setArgument(e2);
|
||||
e2->setArgument(d);
|
||||
e2->setArgument(new expressions::Dummy("a"));
|
||||
|
||||
std::stringstream output;
|
||||
e1->normalized()->print(output);
|
||||
|
||||
ASSERT_EQ(output.str(), "(exists (?x ?y ?z ?u ?v ?w) (a))");
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
TEST(PDDLNormalizationTests, Prenex)
|
||||
{
|
||||
auto a = expressions::AndPointer(new expressions::And);
|
||||
auto f1 = expressions::ForAllPointer(new expressions::ForAll);
|
||||
auto o = expressions::OrPointer(new expressions::Or);
|
||||
auto e = expressions::ExistsPointer(new expressions::Exists);
|
||||
auto f2 = expressions::ForAllPointer(new expressions::ForAll);
|
||||
|
||||
auto v1 = expressions::VariablePointer(new expressions::Variable("x"));
|
||||
auto v2 = expressions::VariablePointer(new expressions::Variable("y"));
|
||||
auto v3 = expressions::VariablePointer(new expressions::Variable("z"));
|
||||
|
||||
a->addArgument(new expressions::Dummy("a"));
|
||||
a->addArgument(f1);
|
||||
f1->variables() = {v1};
|
||||
f1->setArgument(o);
|
||||
o->addArgument(e);
|
||||
e->variables() = {v3};
|
||||
e->setArgument(new expressions::Dummy("b"));
|
||||
o->addArgument(f2);
|
||||
f2->variables() = {v2};
|
||||
f2->setArgument(new expressions::Dummy("c"));
|
||||
|
||||
auto normalized = a->reduced()->negationNormalized()->prenex();
|
||||
|
||||
std::stringstream output;
|
||||
normalized->print(output);
|
||||
|
||||
ASSERT_EQ(output.str(), "(forall (?x) (exists (?z) (forall (?y) (and (a) (or (b) (c))))))");
|
||||
}
|
||||
|
Reference in New Issue
Block a user