Implemented translation of conditional PDDL effects.

This commit is contained in:
Patrick Lühne 2017-06-28 00:28:36 +02:00
parent 0caef2e81c
commit d82ae8544b
Signed by: patrick
GPG Key ID: 05F3611E97A70ABF
4 changed files with 181 additions and 18 deletions

View File

@ -0,0 +1,110 @@
#ifndef __PLASP__PDDL__TRANSLATION__CONDITIONAL_EFFECT_H
#define __PLASP__PDDL__TRANSLATION__CONDITIONAL_EFFECT_H
#include <colorlog/Formatting.h>
#include <pddlparse/NormalizedAST.h>
#include <plasp/TranslatorException.h>
#include <plasp/pddl/translation/Predicate.h>
#include <plasp/pddl/translation/Primitives.h>
#include <plasp/pddl/translation/Variables.h>
#include <plasp/pddl/translation/VariableStack.h>
namespace plasp
{
namespace pddl
{
////////////////////////////////////////////////////////////////////////////////////////////////////
//
// ConditionalEffect
//
////////////////////////////////////////////////////////////////////////////////////////////////////
template<typename PrintObjectName>
inline void translateConditionalEffect(colorlog::ColorStream &outputStream,
const ::pddl::normalizedAST::ConditionalEffect &conditionalEffect,
PrintObjectName printObjectName, VariableStack &variableStack,
size_t &numberOfConditionalEffects)
{
const auto handlePredicate =
[&](const ::pddl::normalizedAST::PredicatePointer &predicate, bool isPositive = true)
{
outputStream << std::endl << colorlog::Function("postcondition") << "(";
printObjectName();
outputStream
<< ", " << colorlog::Keyword("effect") << "("
<< colorlog::Number<size_t>(numberOfConditionalEffects) << ")"
<< ", ";
translatePredicateToVariable(outputStream, *predicate, isPositive);
outputStream << ") :- " << colorlog::Function("action") << "(";
printObjectName();
outputStream << ")";
if (!variableStack.layers.empty())
for (const auto &layer : variableStack.layers)
{
if (!layer->empty())
outputStream << ", ";
translateVariablesForRuleBody(outputStream, *layer);
}
outputStream << ".";
};
const auto handleNegatedPredicate =
[&](const ::pddl::normalizedAST::PredicatePointer &predicate)
{
handlePredicate(predicate, false);
};
const auto handleDerivedPredicate =
[&](const ::pddl::normalizedAST::DerivedPredicatePointer &, bool = true)
{
// TODO: refactor as to exclude derived predicates from the Effect variant
throw TranslatorException("derived predicates should not appear in effects, please report to the bug tracker");
};
const auto handleNegatedDerivedPredicate =
[&](const ::pddl::normalizedAST::DerivedPredicatePointer &derivedPredicate)
{
handleDerivedPredicate(derivedPredicate, false);
};
const auto handleAtomicFormula =
[&](const ::pddl::normalizedAST::AtomicFormula &atomicFormula)
{
atomicFormula.match(handlePredicate, handleDerivedPredicate);
};
const auto handleNot =
[&](const ::pddl::normalizedAST::NotPointer<::pddl::normalizedAST::AtomicFormula> &not_)
{
not_->argument.match(handleNegatedPredicate, handleNegatedDerivedPredicate);
};
const auto handleLiteral =
[&](const ::pddl::normalizedAST::Literal &literal)
{
literal.match(handleAtomicFormula, handleNot);
};
const auto handleAnd =
[&](const ::pddl::normalizedAST::AndPointer<::pddl::normalizedAST::Literal> &and_)
{
for (const auto &argument : and_->arguments)
handleLiteral(argument);
};
conditionalEffect.match(handleAnd, handleLiteral);
}
////////////////////////////////////////////////////////////////////////////////////////////////////
}
}
#endif

View File

@ -7,6 +7,8 @@
#include <plasp/TranslatorException.h> #include <plasp/TranslatorException.h>
#include <plasp/pddl/translation/ConditionalEffect.h>
#include <plasp/pddl/translation/Precondition.h>
#include <plasp/pddl/translation/Predicate.h> #include <plasp/pddl/translation/Predicate.h>
#include <plasp/pddl/translation/Primitives.h> #include <plasp/pddl/translation/Primitives.h>
#include <plasp/pddl/translation/Variables.h> #include <plasp/pddl/translation/Variables.h>
@ -24,7 +26,9 @@ namespace pddl
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////
template<typename PrintObjectName> template<typename PrintObjectName>
inline void translateEffect(colorlog::ColorStream &outputStream, const ::pddl::normalizedAST::Effect &effect, const std::string &objectType, PrintObjectName printObjectName, VariableStack &variableStack) inline void translateEffect(colorlog::ColorStream &outputStream,
const ::pddl::normalizedAST::Effect &effect, PrintObjectName printObjectName,
VariableStack &variableStack, size_t &numberOfConditionalEffects)
{ {
const auto handlePredicate = const auto handlePredicate =
[&](const ::pddl::normalizedAST::PredicatePointer &predicate, bool isPositive = true) [&](const ::pddl::normalizedAST::PredicatePointer &predicate, bool isPositive = true)
@ -36,7 +40,7 @@ inline void translateEffect(colorlog::ColorStream &outputStream, const ::pddl::n
<< colorlog::Reserved("unconditional") << ")" << colorlog::Reserved("unconditional") << ")"
<< ", "; << ", ";
translatePredicateToVariable(outputStream, *predicate, isPositive); translatePredicateToVariable(outputStream, *predicate, isPositive);
outputStream << ") :- " << colorlog::Function(objectType.c_str()) << "("; outputStream << ") :- " << colorlog::Function("action") << "(";
printObjectName(); printObjectName();
outputStream << ")"; outputStream << ")";
@ -93,7 +97,8 @@ inline void translateEffect(colorlog::ColorStream &outputStream, const ::pddl::n
[&](const ::pddl::normalizedAST::AndPointer<::pddl::normalizedAST::Effect> &and_) [&](const ::pddl::normalizedAST::AndPointer<::pddl::normalizedAST::Effect> &and_)
{ {
for (const auto &argument : and_->arguments) for (const auto &argument : and_->arguments)
translateEffect(outputStream, argument, objectType, printObjectName, variableStack); translateEffect(outputStream, argument, printObjectName, variableStack,
numberOfConditionalEffects);
}; };
const auto handleForAll = const auto handleForAll =
@ -101,15 +106,46 @@ inline void translateEffect(colorlog::ColorStream &outputStream, const ::pddl::n
{ {
variableStack.push(&forAll->parameters); variableStack.push(&forAll->parameters);
translateEffect(outputStream, forAll->argument, objectType, printObjectName, variableStack); translateEffect(outputStream, forAll->argument, printObjectName,
variableStack, numberOfConditionalEffects);
variableStack.pop(); variableStack.pop();
}; };
const auto handleWhen = const auto handleWhen =
[&](const ::pddl::normalizedAST::WhenPointer<::pddl::normalizedAST::Precondition, ::pddl::normalizedAST::ConditionalEffect> &) [&](const ::pddl::normalizedAST::WhenPointer<::pddl::normalizedAST::Precondition,
::pddl::normalizedAST::ConditionalEffect> &when)
{ {
throw TranslatorException("“when” expressions not yet supported by translator"); numberOfConditionalEffects++;
const auto printConditionalEffectIdentifier =
[&]()
{
outputStream << colorlog::Keyword("effect") << "("
<< colorlog::Number<size_t>(numberOfConditionalEffects) << ")";
};
const auto printPreconditionRuleBody =
[&]()
{
outputStream << " :- " << colorlog::Function("action") << "(";
printObjectName();
outputStream << ")";
for (const auto &layer : variableStack.layers)
{
if (!layer->empty())
outputStream << ", ";
translateVariablesForRuleBody(outputStream, *layer);
}
};
translatePrecondition(outputStream, when->argumentLeft,
printConditionalEffectIdentifier, printPreconditionRuleBody);
translateConditionalEffect(outputStream, when->argumentRight, printObjectName,
variableStack, numberOfConditionalEffects);
}; };
effect.match(handleAnd, handleForAll, handleLiteral, handleWhen); effect.match(handleAnd, handleForAll, handleLiteral, handleWhen);
@ -118,11 +154,14 @@ inline void translateEffect(colorlog::ColorStream &outputStream, const ::pddl::n
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////
template<typename PrintObjectName> template<typename PrintObjectName>
inline void translateEffect(colorlog::ColorStream &outputStream, const ::pddl::normalizedAST::Effect &effect, const std::string &objectType, PrintObjectName printObjectName) inline void translateEffect(colorlog::ColorStream &outputStream,
const ::pddl::normalizedAST::Effect &effect, PrintObjectName printObjectName,
size_t &numberOfConditionalEffects)
{ {
VariableStack variableStack; VariableStack variableStack;
translateEffect(outputStream, effect, objectType, printObjectName, variableStack); translateEffect(outputStream, effect, printObjectName, variableStack,
numberOfConditionalEffects);
} }
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////

View File

@ -22,8 +22,10 @@ namespace pddl
// //
//////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////
template<typename PrintObjectName> template<typename PrintObjectName, typename PrintRuleBody>
inline void translatePrecondition(colorlog::ColorStream &outputStream, const ::pddl::normalizedAST::Precondition &precondition, const std::string &objectType, PrintObjectName printObjectName) inline void translatePrecondition(colorlog::ColorStream &outputStream,
const ::pddl::normalizedAST::Precondition &precondition, PrintObjectName printObjectName,
PrintRuleBody printRuleBody)
{ {
const auto handlePredicate = const auto handlePredicate =
[&](const ::pddl::normalizedAST::PredicatePointer &predicate, bool isPositive = true) [&](const ::pddl::normalizedAST::PredicatePointer &predicate, bool isPositive = true)
@ -32,9 +34,9 @@ inline void translatePrecondition(colorlog::ColorStream &outputStream, const ::p
printObjectName(); printObjectName();
outputStream << ", "; outputStream << ", ";
translatePredicateToVariable(outputStream, *predicate, isPositive); translatePredicateToVariable(outputStream, *predicate, isPositive);
outputStream << ") :- " << colorlog::Function(objectType.c_str()) << "("; outputStream << ")";
printObjectName(); printRuleBody();
outputStream << ")."; outputStream << ".";
}; };
const auto handleNegatedPredicate = const auto handleNegatedPredicate =
@ -50,9 +52,9 @@ inline void translatePrecondition(colorlog::ColorStream &outputStream, const ::p
printObjectName(); printObjectName();
outputStream << ", "; outputStream << ", ";
translateDerivedPredicateToVariable(outputStream, *derivedPredicate, isPositive); translateDerivedPredicateToVariable(outputStream, *derivedPredicate, isPositive);
outputStream << ") :- " << colorlog::Function(objectType.c_str()) << "("; outputStream << ")";
printObjectName(); printRuleBody();
outputStream << ")."; outputStream << ".";
}; };
const auto handleNegatedDerivedPredicate = const auto handleNegatedDerivedPredicate =

View File

@ -300,6 +300,8 @@ void TranslatorASP::translateActions() const
const auto &actions = m_description.domain->actions; const auto &actions = m_description.domain->actions;
size_t numberOfConditionalEffects{0};
for (const auto &action : actions) for (const auto &action : actions)
{ {
const auto printActionName = const auto printActionName =
@ -318,6 +320,14 @@ void TranslatorASP::translateActions() const
m_outputStream << "))"; m_outputStream << "))";
}; };
const auto printPreconditionRuleBody =
[&]()
{
m_outputStream << " :- " << colorlog::Function("action") << "(";
printActionName();
m_outputStream << ")";
};
m_outputStream << std::endl; m_outputStream << std::endl;
// Name // Name
@ -335,11 +345,13 @@ void TranslatorASP::translateActions() const
// Precondition // Precondition
if (action->precondition) if (action->precondition)
translatePrecondition(m_outputStream, action->precondition.value(), "action", printActionName); translatePrecondition(m_outputStream, action->precondition.value(), printActionName,
printPreconditionRuleBody);
// Effect // Effect
if (action->effect) if (action->effect)
translateEffect(m_outputStream, action->effect.value(), "action", printActionName); translateEffect(m_outputStream, action->effect.value(), printActionName,
numberOfConditionalEffects);
m_outputStream << std::endl; m_outputStream << std::endl;
} }