Browse Source

fixes in reach expression parsing for expected reward

Former-commit-id: d9f5e887d8 [formerly 02cea9bff2]
Former-commit-id: dd387c2595
tempestpy_adaptions
sjunges 8 years ago
parent
commit
1fd89f3922
  1. 4
      src/parser/JaniParser.cpp
  2. 34
      src/storage/jani/JSONExporter.cpp
  3. 10
      src/storage/jani/JSONExporter.h

4
src/parser/JaniParser.cpp

@ -223,7 +223,7 @@ namespace storm {
} }
std::shared_ptr<storm::logic::Formula const> reach; std::shared_ptr<storm::logic::Formula const> reach;
if (propertyStructure.count("reach") > 0) { if (propertyStructure.count("reach") > 0) {
reach = parseFormula(propertyStructure.at("reach"), time ? storm::logic::FormulaContext::Time : storm::logic::FormulaContext::Reward, "Reach-expression of operator " + opString);
reach = std::make_shared<storm::logic::EventuallyFormula>(parseFormula(propertyStructure.at("reach"), time ? storm::logic::FormulaContext::Time : storm::logic::FormulaContext::Reward, "Reach-expression of operator " + opString));
} else { } else {
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "Total reward is currently not supported"); STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "Total reward is currently not supported");
} }
@ -425,6 +425,8 @@ namespace storm {
} else { } else {
STORM_LOG_THROW(false, storm::exceptions::InvalidJaniException, "Unknown operator " << opString); STORM_LOG_THROW(false, storm::exceptions::InvalidJaniException, "Unknown operator " << opString);
} }
} else {
STORM_LOG_THROW(false, storm::exceptions::InvalidJaniException, "Looking for operator for formula " << propertyStructure.dump() << ", but did not find one");
} }
} }

34
src/storage/jani/JSONExporter.cpp

@ -139,8 +139,8 @@ namespace storm {
return iDecl; return iDecl;
} }
modernjson::json FormulaToJaniJson::translate(storm::logic::Formula const& formula, bool continuousTime) {
FormulaToJaniJson translator(continuousTime);
modernjson::json FormulaToJaniJson::translate(storm::logic::Formula const& formula, storm::jani::Model const& model) {
FormulaToJaniJson translator(model);
return boost::any_cast<modernjson::json>(formula.accept(translator)); return boost::any_cast<modernjson::json>(formula.accept(translator));
} }
@ -334,35 +334,37 @@ namespace storm {
boost::any FormulaToJaniJson::visit(storm::logic::RewardOperatorFormula const& f, boost::any const& data) const { boost::any FormulaToJaniJson::visit(storm::logic::RewardOperatorFormula const& f, boost::any const& data) const {
modernjson::json opDecl; modernjson::json opDecl;
std::vector<std::string> accvec; std::vector<std::string> accvec;
if(continuous) {
accvec.push_back("time");
} else {
if(model.isDiscreteTimeModel()) {
accvec.push_back("steps"); accvec.push_back("steps");
} else {
accvec.push_back("time");
} }
if(f.hasBound()) { if(f.hasBound()) {
auto bound = f.getBound(); auto bound = f.getBound();
opDecl["op"] = comparisonTypeToJani(bound.comparisonType); opDecl["op"] = comparisonTypeToJani(bound.comparisonType);
if(f.hasOptimalityType()) { if(f.hasOptimalityType()) {
opDecl["left"]["op"] = f.getOptimalityType() == storm::solver::OptimizationDirection::Minimize ? "Emin" : "Emax"; opDecl["left"]["op"] = f.getOptimalityType() == storm::solver::OptimizationDirection::Minimize ? "Emin" : "Emax";
opDecl["left"]["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().accept(*this, boost::none));
opDecl["left"]["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().asEventuallyFormula().getSubformula().accept(*this, boost::none));
} else { } else {
opDecl["left"]["op"] = (bound.comparisonType == storm::logic::ComparisonType::Less || bound.comparisonType == storm::logic::ComparisonType::LessEqual) ? "Emax" : "Emin"; opDecl["left"]["op"] = (bound.comparisonType == storm::logic::ComparisonType::Less || bound.comparisonType == storm::logic::ComparisonType::LessEqual) ? "Emax" : "Emin";
opDecl["left"]["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().accept(*this, boost::none));
opDecl["left"]["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().asEventuallyFormula().getSubformula().accept(*this, boost::none));
} }
opDecl["left"]["exp"] = f.hasRewardModelName() ? f.getRewardModelName() : "DEFAULT";
STORM_LOG_THROW(f.hasRewardModelName(), storm::exceptions::NotSupportedException, "Reward name has to be specified for Jani-conversion");
opDecl["left"]["exp"] = f.getRewardModelName();
opDecl["left"]["accumulate"] = modernjson::json(accvec); opDecl["left"]["accumulate"] = modernjson::json(accvec);
opDecl["right"] = numberToJson(bound.threshold); opDecl["right"] = numberToJson(bound.threshold);
} else { } else {
if(f.hasOptimalityType()) { if(f.hasOptimalityType()) {
opDecl["op"] = f.getOptimalityType() == storm::solver::OptimizationDirection::Minimize ? "Emin" : "Emax"; opDecl["op"] = f.getOptimalityType() == storm::solver::OptimizationDirection::Minimize ? "Emin" : "Emax";
opDecl["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().accept(*this, boost::none));
opDecl["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().asEventuallyFormula().getSubformula().accept(*this, boost::none));
} else { } else {
// TODO add checks // TODO add checks
opDecl["op"] = "Emin"; opDecl["op"] = "Emin";
opDecl["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().accept(*this, boost::none));
opDecl["reach"] = boost::any_cast<modernjson::json>(f.getSubformula().asEventuallyFormula().getSubformula().accept(*this, boost::none));
} }
opDecl["exp"] = f.hasRewardModelName() ? f.getRewardModelName() : "DEFAULT";
STORM_LOG_THROW(f.hasRewardModelName(), storm::exceptions::NotSupportedException, "Reward name has to be specified for Jani-conversion");
opDecl["exp"] = f.getRewardModelName();
opDecl["accumulate"] = modernjson::json(accvec); opDecl["accumulate"] = modernjson::json(accvec);
} }
return opDecl; return opDecl;
@ -520,7 +522,7 @@ namespace storm {
} }
JsonExporter exporter; JsonExporter exporter;
exporter.convertModel(janiModel); exporter.convertModel(janiModel);
exporter.convertProperties(formulas, !janiModel.isDiscreteTimeModel());
exporter.convertProperties(formulas, janiModel);
os << exporter.finalize().dump(4) << std::endl; os << exporter.finalize().dump(4) << std::endl;
} }
@ -732,23 +734,23 @@ namespace storm {
} }
} }
modernjson::json convertFilterExpression(storm::jani::FilterExpression const& fe, bool continuousModel) {
modernjson::json convertFilterExpression(storm::jani::FilterExpression const& fe, storm::jani::Model const& model) {
modernjson::json propDecl; modernjson::json propDecl;
propDecl["states"]["op"] = "initial"; propDecl["states"]["op"] = "initial";
propDecl["op"] = "filter"; propDecl["op"] = "filter";
propDecl["fun"] = janiFilterTypeString(fe.getFilterType()); propDecl["fun"] = janiFilterTypeString(fe.getFilterType());
propDecl["values"] = FormulaToJaniJson::translate(*fe.getFormula(), continuousModel);
propDecl["values"] = FormulaToJaniJson::translate(*fe.getFormula(), model);
return propDecl; return propDecl;
} }
void JsonExporter::convertProperties( std::vector<std::shared_ptr<storm::logic::Formula const>> const& formulas, bool continuousModel) {
void JsonExporter::convertProperties( std::vector<std::shared_ptr<storm::logic::Formula const>> const& formulas, storm::jani::Model const& model) {
std::vector<modernjson::json> properties; std::vector<modernjson::json> properties;
uint64_t index = 0; uint64_t index = 0;
for(auto const& f : formulas) { for(auto const& f : formulas) {
modernjson::json propDecl; modernjson::json propDecl;
propDecl["name"] = "prop" + std::to_string(index); propDecl["name"] = "prop" + std::to_string(index);
propDecl["expression"] = convertFilterExpression(storm::jani::FilterExpression(f), continuousModel);
propDecl["expression"] = convertFilterExpression(storm::jani::FilterExpression(f), model);
++index; ++index;
properties.push_back(propDecl); properties.push_back(propDecl);
} }

10
src/storage/jani/JSONExporter.h

@ -33,9 +33,9 @@ namespace storm {
}; };
class FormulaToJaniJson : public storm::logic::FormulaVisitor { class FormulaToJaniJson : public storm::logic::FormulaVisitor {
public: public:
static modernjson::json translate(storm::logic::Formula const& formula, bool continuousTime);
static modernjson::json translate(storm::logic::Formula const& formula, storm::jani::Model const& modeln);
virtual boost::any visit(storm::logic::AtomicExpressionFormula const& f, boost::any const& data) const; virtual boost::any visit(storm::logic::AtomicExpressionFormula const& f, boost::any const& data) const;
virtual boost::any visit(storm::logic::AtomicLabelFormula const& f, boost::any const& data) const; virtual boost::any visit(storm::logic::AtomicLabelFormula const& f, boost::any const& data) const;
virtual boost::any visit(storm::logic::BinaryBooleanStateFormula const& f, boost::any const& data) const; virtual boost::any visit(storm::logic::BinaryBooleanStateFormula const& f, boost::any const& data) const;
@ -56,8 +56,8 @@ namespace storm {
virtual boost::any visit(storm::logic::UntilFormula const& f, boost::any const& data) const; virtual boost::any visit(storm::logic::UntilFormula const& f, boost::any const& data) const;
private: private:
FormulaToJaniJson(bool continuousModel) : continuous(continuousModel) { }
bool continuous;
FormulaToJaniJson(storm::jani::Model const& model) : model(model) { }
storm::jani::Model const& model;
}; };
class JsonExporter { class JsonExporter {
@ -69,7 +69,7 @@ namespace storm {
private: private:
void convertModel(storm::jani::Model const& model); void convertModel(storm::jani::Model const& model);
void convertProperties(std::vector<std::shared_ptr<storm::logic::Formula const>> const& formulas, bool timeContinuousModel);
void convertProperties(std::vector<std::shared_ptr<storm::logic::Formula const>> const& formulas, storm::jani::Model const& model);
void appendVariableDeclaration(storm::jani::Variable const& variable); void appendVariableDeclaration(storm::jani::Variable const& variable);
modernjson::json finalize() { modernjson::json finalize() {

Loading…
Cancel
Save