Browse Source

added module config

added overwrite
some fixes
pull/3/head
Thomas Knoll 1 year ago
parent
commit
0d8b5bc0c2
  1. 7
      main.cpp
  2. 32
      util/ConfigYaml.cpp
  3. 30
      util/ConfigYaml.h
  4. 26
      util/Grid.cpp
  5. 1
      util/Grid.h
  6. 36
      util/PrismModulesPrinter.cpp
  7. 4
      util/PrismModulesPrinter.h

7
main.cpp

@ -169,7 +169,12 @@ int main(int argc, char* argv[]) {
if(ok) { if(ok) {
Grid grid(contentCells, backgroundCells, gridOptions, stateRewards); Grid grid(contentCells, backgroundCells, gridOptions, stateRewards);
//grid.printToPrism(std::cout, prism::ModelType::MDP); //grid.printToPrism(std::cout, prism::ModelType::MDP);
grid.printToPrism(file, configurations ,prism::ModelType::MDP);
std::stringstream ss;
// grid.printToPrism(file, configurations ,prism::ModelType::MDP);
grid.printToPrism(ss, configurations ,prism::ModelType::MDP);
std::string str = ss.str();
grid.applyOverwrites(str, configurations);
file << str;
} }
} catch(qi::expectation_failure<pos_iterator_t> const& e) { } catch(qi::expectation_failure<pos_iterator_t> const& e) {
std::cout << "expected: "; print_info(e.what_); std::cout << "expected: "; print_info(e.what_);

32
util/ConfigYaml.cpp

@ -24,6 +24,30 @@ std::ostream& operator << (std::ostream& os, const Module& module) {
return os; return os;
} }
std::string Label::createExpression() const {
if (overwrite_) {
return "label \"" + label_ + "\" = " + text_ + "; // Overwrite";
}
return "label \"" + label_ + "\" = " + text_ + ";";
}
std::string Formula::createExpression() const {
if (overwrite_) {
return "formula " + formula_ + " = " + content_ + "; // Overwrite";
}
return "formula " + formula_ + " = " + content_ + ";";
}
std::string Action::createExpression() const {
if (overwrite_) {
return action_ + "\t" + guard_ + "-> " + update_ + "; // Overwrite";
}
return "\t" + action_ + "\t" + guard_ + "-> " + update_ + ";";
}
YAML::Node YAML::convert<Module>::encode(const Module& rhs) { YAML::Node YAML::convert<Module>::encode(const Module& rhs) {
YAML::Node node; YAML::Node node;
@ -129,13 +153,15 @@ bool YAML::convert<Formula>::decode(const YAML::Node& node, Formula& rhs) {
const std::vector<Module> modules = config["modules"].as<std::vector<Module>>(); const std::vector<Module> modules = config["modules"].as<std::vector<Module>>();
for (auto& label : labels) { for (auto& label : labels) {
configuration.push_back({label.text_, label.label_, ConfigType::Label, label.overwrite_});
configuration.push_back({label.createExpression(), label.label_ , ConfigType::Label, label.overwrite_});
} }
for (auto& formula : formulas) { for (auto& formula : formulas) {
configuration.push_back({formula.content_, formula.formula_ , ConfigType::Formula, formula.overwrite_});
configuration.push_back({formula.createExpression(), formula.formula_ ,ConfigType::Formula, formula.overwrite_});
} }
for (auto& module : modules) { for (auto& module : modules) {
std::cout << module << std::endl;
for (auto& action : module.actions_) {
configuration.push_back({action.createExpression(), action.action_, ConfigType::Module, action.overwrite_, module.module_});
}
} }

30
util/ConfigYaml.h

@ -5,7 +5,6 @@
#include "yaml-cpp/yaml.h" #include "yaml-cpp/yaml.h"
typedef std::string expressions;
enum class ConfigType : char { enum class ConfigType : char {
Label = 'L', Label = 'L',
@ -15,20 +14,25 @@ enum class ConfigType : char {
struct Configuration struct Configuration
{ {
expressions expressions_;
std::string derivation_;
std::string module_ {};
std::string expression_{};
std::string identifier_{};
ConfigType type_ {ConfigType::Label}; ConfigType type_ {ConfigType::Label};
bool overwrite_;
bool overwrite_ {false};
Configuration() = default; Configuration() = default;
Configuration(std::string expression, std::string derivation, ConfigType type, bool overwrite = false) : expressions_(expression), derivation_(derivation), type_(type), overwrite_(overwrite) {}
Configuration(std::string expression
, std::string identifier
, ConfigType type
, bool overwrite = false
, std::string module = "") : expression_(expression), identifier_(identifier), type_(type), overwrite_(overwrite), module_{module} {}
~Configuration() = default; ~Configuration() = default;
Configuration(const Configuration&) = default; Configuration(const Configuration&) = default;
friend std::ostream& operator << (std::ostream& os, const Configuration& config) { friend std::ostream& operator << (std::ostream& os, const Configuration& config) {
os << "Configuration with Type: " << static_cast<char>(config.type_) << std::endl; os << "Configuration with Type: " << static_cast<char>(config.type_) << std::endl;
os << "\tExpression=" << config.expressions_ << std::endl;
return os << "\tDerviation=" << config.derivation_;
return os << "\tExpression=" << config.expression_ << std::endl;
} }
}; };
@ -40,7 +44,9 @@ struct Label {
public: public:
std::string text_; std::string text_;
std::string label_; std::string label_;
bool overwrite_;
bool overwrite_{false};
std::string createExpression() const;
friend std::ostream& operator <<(std::ostream &os, const Label& label); friend std::ostream& operator <<(std::ostream &os, const Label& label);
}; };
@ -51,7 +57,9 @@ struct Formula {
public: public:
std::string formula_; std::string formula_;
std::string content_; std::string content_;
bool overwrite_;
bool overwrite_ {false};
std::string createExpression() const;
friend std::ostream& operator << (std::ostream &os, const Formula& formula); friend std::ostream& operator << (std::ostream &os, const Formula& formula);
}; };
@ -61,7 +69,9 @@ struct Action {
std::string action_; std::string action_;
std::string guard_; std::string guard_;
std::string update_; std::string update_;
bool overwrite_;
bool overwrite_ {false};
std::string createExpression() const;
friend std::ostream& operator << (std::ostream& os, const Action& action); friend std::ostream& operator << (std::ostream& os, const Action& action);
}; };

26
util/Grid.cpp

@ -129,6 +129,30 @@ bool Grid::isBox(coordinates p) {
}) != boxes.end(); }) != boxes.end();
} }
void Grid::applyOverwrites(std::string& str, std::vector<Configuration>& configuration) {
for (auto& config : configuration) {
if (!config.overwrite_) {
continue;
}
std::cout << "Searching for " << config.identifier_ << std::endl;
size_t start_pos;
if (config.type_ == ConfigType::Formula) {
start_pos = str.find("formula " + config.identifier_);
} else if (config.type_ == ConfigType::Label) {
start_pos = str.find("label " + config.identifier_);
} else if (config.type_ == ConfigType::Module) {
start_pos = str.find(config.identifier_);
}
size_t end_pos = str.find(';', start_pos) + 1;
std::string expression = config.expression_;
str.replace(start_pos, end_pos - start_pos , expression);
}
}
void Grid::printToPrism(std::ostream& os, std::vector<Configuration>& configuration ,const prism::ModelType& modelType) { void Grid::printToPrism(std::ostream& os, std::vector<Configuration>& configuration ,const prism::ModelType& modelType) {
cells northRestriction; cells northRestriction;
cells eastRestriction; cells eastRestriction;
@ -151,7 +175,7 @@ void Grid::printToPrism(std::ostream& os, std::vector<Configuration>& configurat
if(isBlocked(c.getWest())) westRestriction.push_back(c); if(isBlocked(c.getWest())) westRestriction.push_back(c);
} }
prism::PrismModulesPrinter printer(modelType, agentNameAndPositionMap.size(), gridOptions.enforceOneWays);
prism::PrismModulesPrinter printer(modelType, agentNameAndPositionMap.size(), configuration, gridOptions.enforceOneWays);
printer.printModel(os, modelType); printer.printModel(os, modelType);
if(modelType == prism::ModelType::SMG) { if(modelType == prism::ModelType::SMG) {
printer.printGlobalMoveVariable(os, agentNameAndPositionMap.size()); printer.printGlobalMoveVariable(os, agentNameAndPositionMap.size());

1
util/Grid.h

@ -30,6 +30,7 @@ class Grid {
bool isKey(coordinates p); bool isKey(coordinates p);
bool isBox(coordinates p); bool isBox(coordinates p);
void printToPrism(std::ostream &os, std::vector<Configuration>& configuration, const prism::ModelType& modelType); void printToPrism(std::ostream &os, std::vector<Configuration>& configuration, const prism::ModelType& modelType);
void applyOverwrites(std::string& str, std::vector<Configuration>& configuration);
std::array<bool, 8> getWalkableDirOf8Neighborhood(cell c); std::array<bool, 8> getWalkableDirOf8Neighborhood(cell c);

36
util/PrismModulesPrinter.cpp

@ -5,8 +5,8 @@
namespace prism { namespace prism {
PrismModulesPrinter::PrismModulesPrinter(const ModelType &modelType, const size_t &numberOfPlayer, const bool enforceOneWays)
: modelType(modelType), numberOfPlayer(numberOfPlayer), enforceOneWays(enforceOneWays) {
PrismModulesPrinter::PrismModulesPrinter(const ModelType &modelType, const size_t &numberOfPlayer, std::vector<Configuration> config, const bool enforceOneWays)
: modelType(modelType), numberOfPlayer(numberOfPlayer), enforceOneWays(enforceOneWays), configuration(config) {
} }
std::ostream& PrismModulesPrinter::printModel(std::ostream &os, const ModelType &modelType) { std::ostream& PrismModulesPrinter::printModel(std::ostream &os, const ModelType &modelType) {
@ -222,18 +222,12 @@ namespace prism {
os << "\n// Configuration\n"; os << "\n// Configuration\n";
for (auto& configuration : configurations) { for (auto& configuration : configurations) {
if (configuration.type_ == ConfigType::Label) {
os << "label \"" << configuration.derivation_ << "\" = ";
}
else if (configuration.type_ == ConfigType::Formula) {
os << "formula " << configuration.derivation_ << " = ";
}
for (auto& expr : configuration.expressions_) {
os << expr;
std::cout << configuration.overwrite_ << std::endl;
if (configuration.overwrite_ || configuration.type_ == ConfigType::Module) {
continue;
} }
os << ";\n";
os << configuration.expression_ << std::endl;
} }
return os; return os;
@ -362,7 +356,25 @@ namespace prism {
printMovementActions(os, agentName, agentIndex, agentWithView, probability); printMovementActions(os, agentName, agentIndex, agentWithView, probability);
} }
printDoneActions(os, agentName, agentIndex); printDoneActions(os, agentName, agentIndex);
printConfiguredActions(os, agentName);
os << "\n";
return os;
}
std::ostream& PrismModulesPrinter::printConfiguredActions(std::ostream &os, const AgentName &agentName) {
os << "\t//Configuration \n";
for (auto& config : configuration) {
if (config.type_ == ConfigType::Module && !config.overwrite_ && agentName == config.module_) {
os << config.expression_ ;
}
}
os << "\n"; os << "\n";
return os; return os;
} }

4
util/PrismModulesPrinter.h

@ -9,7 +9,7 @@
namespace prism { namespace prism {
class PrismModulesPrinter { class PrismModulesPrinter {
public: public:
PrismModulesPrinter(const ModelType &modelType, const size_t &numberOfPlayer, const bool enforceOneWays = false);
PrismModulesPrinter(const ModelType &modelType, const size_t &numberOfPlayer, std::vector<Configuration> config ,const bool enforceOneWays = false);
std::ostream& printRestrictionFormula(std::ostream& os, const AgentName &agentName, const std::string &direction, const cells &cells); std::ostream& printRestrictionFormula(std::ostream& os, const AgentName &agentName, const std::string &direction, const cells &cells);
std::ostream& printIsOnSlipperyFormula(std::ostream& os, const AgentName &agentName, const std::vector<std::reference_wrapper<cells>> &slipperyCollection, const cells &slipperyNorth, const cells &slipperyEast, const cells &slipperySouth, const cells &slipperyWest); std::ostream& printIsOnSlipperyFormula(std::ostream& os, const AgentName &agentName, const std::vector<std::reference_wrapper<cells>> &slipperyCollection, const cells &slipperyNorth, const cells &slipperyEast, const cells &slipperySouth, const cells &slipperyWest);
@ -78,6 +78,7 @@ namespace prism {
std::ostream& printRewards(std::ostream &os, const AgentName &agentName, const std::map<coordinates, float> &stateRewards, const cells &lava, const cells &goals, const std::map<Color, cells> &backgroundTiles); std::ostream& printRewards(std::ostream &os, const AgentName &agentName, const std::map<coordinates, float> &stateRewards, const cells &lava, const cells &goals, const std::map<Color, cells> &backgroundTiles);
std::ostream& printConfiguration(std::ostream &os, const std::vector<Configuration>& configurations); std::ostream& printConfiguration(std::ostream &os, const std::vector<Configuration>& configurations);
std::ostream& printConfiguredActions(std::ostream &os, const AgentName &agentName);
std::string moveGuard(const size_t &agentIndex); std::string moveGuard(const size_t &agentIndex);
std::string moveUpdate(const size_t &agentIndex); std::string moveUpdate(const size_t &agentIndex);
@ -90,5 +91,6 @@ namespace prism {
ModelType const& modelType; ModelType const& modelType;
const size_t numberOfPlayer; const size_t numberOfPlayer;
bool enforceOneWays; bool enforceOneWays;
std::vector<Configuration> configuration;
}; };
} }
Loading…
Cancel
Save