Browse Source

Ongoing refactoring work on ExplicitModelAdapter.

Former-commit-id: 1212f84aad
tempestpy_adaptions
dehnert 11 years ago
parent
commit
a08a403eec
  1. 248
      src/adapters/ExplicitModelAdapter.cpp
  2. 891
      src/adapters/ExplicitModelAdapter.h
  3. 32
      src/models/AtomicPropositionsLabeling.h
  4. 4
      src/storm.cpp

248
src/adapters/ExplicitModelAdapter.cpp

@ -22,10 +22,6 @@
#include <sstream> #include <sstream>
#include <ostream> #include <ostream>
#include "log4cplus/logger.h"
#include "log4cplus/loggingmacros.h"
extern log4cplus::Logger logger;
bool ExplicitModelAdapterOptionsRegistered = storm::settings::Settings::registerNewModule([] (storm::settings::Settings* instance) -> bool { bool ExplicitModelAdapterOptionsRegistered = storm::settings::Settings::registerNewModule([] (storm::settings::Settings* instance) -> bool {
instance->addOption(storm::settings::OptionBuilder("ExplicitModelAdapter", "constants", "", "Specifies the constant replacements to use in Explicit Models").addArgument(storm::settings::ArgumentBuilder::createStringArgument("constantString", "A comma separated list of constants and their value, e.g. a=1,b=2,c=3").setDefaultValueString("").build()).build()); instance->addOption(storm::settings::OptionBuilder("ExplicitModelAdapter", "constants", "", "Specifies the constant replacements to use in Explicit Models").addArgument(storm::settings::ArgumentBuilder::createStringArgument("constantString", "A comma separated list of constants and their value, e.g. a=1,b=2,c=3").setDefaultValueString("").build()).build());
return true; return true;
@ -34,159 +30,8 @@ bool ExplicitModelAdapterOptionsRegistered = storm::settings::Settings::register
namespace storm { namespace storm {
namespace adapters { namespace adapters {
void ExplicitModelAdapter::defineUndefinedConstants(storm::ir::Program& program, std::string const& constantDefinitionString) {
if (!constantDefinitionString.empty()) {
// Parse the string that defines the undefined constants of the model and make sure that it contains exactly
// one value for each undefined constant of the model.
std::vector<std::string> definitions;
boost::split(definitions, constantDefinitionString, boost::is_any_of(","));
for (auto& definition : definitions) {
boost::trim(definition);
// Check whether the token could be a legal constant definition.
uint_fast64_t positionOfAssignmentOperator = definition.find('=');
if (positionOfAssignmentOperator == std::string::npos) {
throw storm::exceptions::InvalidArgumentException() << "Illegal constant definition string: syntax error.";
}
// Now extract the variable name and the value from the string.
std::string constantName = definition.substr(0, positionOfAssignmentOperator);
boost::trim(constantName);
std::string value = definition.substr(positionOfAssignmentOperator + 1);
boost::trim(value);
// Check whether the constant is a legal undefined constant of the program and if so, of what type it is.
if (program.hasUndefinedBooleanConstant(constantName)) {
if (value == "true") {
program.getUndefinedBooleanConstantExpression(constantName)->define(true);
} else if (value == "false") {
program.getUndefinedBooleanConstantExpression(constantName)->define(false);
} else {
throw storm::exceptions::InvalidArgumentException() << "Illegal value for boolean constant: " << value << ".";
}
} else if (program.hasUndefinedIntegerConstant(constantName)) {
try {
int_fast64_t integerValue = std::stoi(value);
program.getUndefinedIntegerConstantExpression(constantName)->define(integerValue);
} catch (std::invalid_argument const&) {
throw storm::exceptions::InvalidArgumentException() << "Illegal value of integer constant: " << value << ".";
} catch (std::out_of_range const&) {
throw storm::exceptions::InvalidArgumentException() << "Illegal value of integer constant: " << value << " (value too big).";
}
} else if (program.hasUndefinedDoubleConstant(constantName)) {
try {
double doubleValue = std::stod(value);
program.getUndefinedDoubleConstantExpression(constantName)->define(doubleValue);
} catch (std::invalid_argument const&) {
throw storm::exceptions::InvalidArgumentException() << "Illegal value of double constant: " << value << ".";
} catch (std::out_of_range const&) {
throw storm::exceptions::InvalidArgumentException() << "Illegal value of double constant: " << value << " (value too big).";
}
} else {
throw storm::exceptions::InvalidArgumentException() << "Illegal constant definition string: unknown undefined constant " << constantName << ".";
}
}
}
}
void ExplicitModelAdapter::undefineUndefinedConstants(storm::ir::Program& program) {
for (auto nameExpressionPair : program.getBooleanUndefinedConstantExpressionsMap()) {
nameExpressionPair.second->undefine();
}
for (auto nameExpressionPair : program.getIntegerUndefinedConstantExpressionsMap()) {
nameExpressionPair.second->undefine();
}
for (auto nameExpressionPair : program.getDoubleUndefinedConstantExpressionsMap()) {
nameExpressionPair.second->undefine();
}
}
ExplicitModelAdapter::StateInformation ExplicitModelAdapter::exploreReachableStateSpace(storm::ir::Program const& program) {
StateInformation stateInformation;
// Initialize a queue, insert the starting state and explore the current state until there is no more reachable state.
return stateInformation;
}
ExplicitModelAdapter::ModelComponents ExplicitModelAdapter::buildModelComponents(storm::ir::Program const& program, std::string const& rewardModelName) {
ModelComponents modelComponents;
// Start by exploring the state space.
StateInformation stateInformation = exploreReachableStateSpace(program);
// Then build the transition matrix for the reachable states.
// Now build the state labeling.
// Finally, construct the state rewards.
return modelComponents;
}
std::shared_ptr<storm::models::AbstractModel<double>> ExplicitModelAdapter::translateProgram(storm::ir::Program program, std::string const& constantDefinitionString, std::string const& rewardModelName) {
// Start by defining the undefined constants in the model.
defineUndefinedConstants(program, constantDefinitionString);
ModelComponents modelComponents = buildModelComponents(program, rewardModelName);
std::shared_ptr<storm::models::AbstractModel<double>> result;
switch (program.getModelType()) {
case storm::ir::Program::DTMC:
result = std::shared_ptr<storm::models::AbstractModel<double>>(new storm::models::Dtmc<double>(std::move(modelComponents.transitionMatrix), std::move(modelComponents.stateLabeling), std::move(modelComponents.stateRewards), std::move(modelComponents.transitionRewardMatrix), std::move(modelComponents.choiceLabeling)));
break;
case storm::ir::Program::CTMC:
result = std::shared_ptr<storm::models::AbstractModel<double>>(new storm::models::Ctmc<double>(std::move(modelComponents.transitionMatrix), std::move(modelComponents.stateLabeling), std::move(modelComponents.stateRewards), std::move(modelComponents.transitionRewardMatrix), std::move(modelComponents.choiceLabeling)));
break;
break;
case storm::ir::Program::MDP:
result = std::shared_ptr<storm::models::AbstractModel<double>>(new storm::models::Mdp<double>(std::move(modelComponents.transitionMatrix), std::move(modelComponents.stateLabeling), std::move(modelComponents.nondeterministicChoiceIndices), std::move(modelComponents.stateRewards), std::move(modelComponents.transitionRewardMatrix), std::move(modelComponents.choiceLabeling)));
break;
case storm::ir::Program::CTMDP:
result = std::shared_ptr<storm::models::AbstractModel<double>>(new storm::models::Ctmdp<double>(std::move(modelComponents.transitionMatrix), std::move(modelComponents.stateLabeling), std::move(modelComponents.nondeterministicChoiceIndices), std::move(modelComponents.stateRewards), std::move(modelComponents.transitionRewardMatrix), std::move(modelComponents.choiceLabeling)));
break;
default:
LOG4CPLUS_ERROR(logger, "Error while creating model from probabilistic program: cannot handle this model type.");
throw storm::exceptions::WrongFormatException() << "Error while creating model from probabilistic program: cannot handle this model type.";
break;
}
// Undefine the constants so that the program can be used again somewhere else.
undefineUndefinedConstants(program);
return result;
}
void ExplicitModelAdapter::setValue(StateType* state, uint_fast64_t index, bool value) {
std::get<0>(*state)[index] = value;
}
void ExplicitModelAdapter::setValue(StateType* state, uint_fast64_t index, int_fast64_t value) {
std::get<1>(*state)[index] = value;
}
std::string ExplicitModelAdapter::toString(StateType const* state) {
std::stringstream ss;
for (unsigned int i = 0; i < state->first.size(); i++) ss << state->first[i] << "\t";
for (unsigned int i = 0; i < state->second.size(); i++) ss << state->second[i] << "\t";
return ss.str();
}
StateType* ExplicitModelAdapter::applyUpdate(storm::ir::Program const& program, StateType const* state, storm::ir::Update const& update) {
return applyUpdate(program, state, state, update);
}
StateType* ExplicitModelAdapter::applyUpdate(storm::ir::Program const& program, StateType const* state, StateType const* baseState, storm::ir::Update const& update) {
StateType* newState = new StateType(*state);
for (auto variableAssignmentPair : update.getBooleanAssignments()) {
setValue(newState, program.getGlobalIndexOfBooleanVariable(variableAssignmentPair.first), variableAssignmentPair.second.getExpression()->getValueAsBool(baseState));
}
for (auto variableAssignmentPair : update.getIntegerAssignments()) {
setValue(newState, program.getGlobalIndexOfIntegerVariable(variableAssignmentPair.first), variableAssignmentPair.second.getExpression()->getValueAsInt(baseState));
}
return newState;
}
// std::vector<double> ExplicitModelAdapter::getStateRewards(std::vector<storm::ir::StateReward> const& rewards) { // std::vector<double> ExplicitModelAdapter::getStateRewards(std::vector<storm::ir::StateReward> const& rewards) {
// std::vector<double> result(this->allStates.size()); // std::vector<double> result(this->allStates.size());
@ -227,48 +72,6 @@ namespace storm {
// return results; // return results;
// } // }
// void ExplicitModelAdapter::initializeVariables() {
// uint_fast64_t numberOfIntegerVariables = 0;
// uint_fast64_t numberOfBooleanVariables = 0;
//
// // Count number of variables.
// numberOfBooleanVariables += program.getNumberOfGlobalBooleanVariables();
// numberOfIntegerVariables += program.getNumberOfGlobalIntegerVariables();
// for (uint_fast64_t i = 0; i < program.getNumberOfModules(); ++i) {
// numberOfBooleanVariables += program.getModule(i).getNumberOfBooleanVariables();
// numberOfIntegerVariables += program.getModule(i).getNumberOfIntegerVariables();
// }
//
// this->booleanVariables.resize(numberOfBooleanVariables);
// this->integerVariables.resize(numberOfIntegerVariables);
//
// // Create variables.
// for (uint_fast64_t i = 0; i < program.getNumberOfGlobalBooleanVariables(); ++i) {
// storm::ir::BooleanVariable var = program.getGlobalBooleanVariable(i);
// this->booleanVariables[var.getGlobalIndex()] = var;
// this->booleanVariableToIndexMap[var.getName()] = var.getGlobalIndex();
// }
// for (uint_fast64_t i = 0; i < program.getNumberOfGlobalIntegerVariables(); ++i) {
// storm::ir::IntegerVariable var = program.getGlobalIntegerVariable(i);
// this->integerVariables[var.getGlobalIndex()] = var;
// this->integerVariableToIndexMap[var.getName()] = var.getGlobalIndex();
// }
// for (uint_fast64_t i = 0; i < program.getNumberOfModules(); ++i) {
// storm::ir::Module const& module = program.getModule(i);
//
// for (uint_fast64_t j = 0; j < module.getNumberOfBooleanVariables(); ++j) {
// storm::ir::BooleanVariable var = module.getBooleanVariable(j);
// this->booleanVariables[var.getGlobalIndex()] = var;
// this->booleanVariableToIndexMap[var.getName()] = var.getGlobalIndex();
// }
// for (uint_fast64_t j = 0; j < module.getNumberOfIntegerVariables(); ++j) {
// storm::ir::IntegerVariable var = module.getIntegerVariable(j);
// this->integerVariables[var.getGlobalIndex()] = var;
// this->integerVariableToIndexMap[var.getName()] = var.getGlobalIndex();
// }
// }
// }
// boost::optional<std::vector<std::list<storm::ir::Command>>> ExplicitModelAdapter::getActiveCommandsByAction(StateType const* state, std::string const& action) { // boost::optional<std::vector<std::list<storm::ir::Command>>> ExplicitModelAdapter::getActiveCommandsByAction(StateType const* state, std::string const& action) {
// boost::optional<std::vector<std::list<storm::ir::Command>>> result((std::vector<std::list<storm::ir::Command>>())); // boost::optional<std::vector<std::list<storm::ir::Command>>> result((std::vector<std::list<storm::ir::Command>>()));
// //
@ -303,57 +106,6 @@ namespace storm {
// return result; // return result;
// } // }
// static StateType* ExplicitModelAdapter::getInitialState() {
// StateType* initialState = new StateType();
// initialState->first.resize(this->booleanVariables.size());
// initialState->second.resize(this->integerVariables.size());
//
// // Start with boolean variables.
// for (uint_fast64_t i = 0; i < this->booleanVariables.size(); ++i) {
// // Check if an initial value is given
// if (this->booleanVariables[i].getInitialValue().get() == nullptr) {
// // If no initial value was given, we assume that the variable is initially false.
// std::get<0>(*initialState)[i] = false;
// } else {
// // Initial value was given.
// bool initialValue = this->booleanVariables[i].getInitialValue()->getValueAsBool(nullptr);
// std::get<0>(*initialState)[i] = initialValue;
// }
// }
//
// // Now process integer variables.
// for (uint_fast64_t i = 0; i < this->integerVariables.size(); ++i) {
// // Check if an initial value was given.
// if (this->integerVariables[i].getInitialValue().get() == nullptr) {
// // No initial value was given, so we assume that the variable initially has the least value it can take.
// std::get<1>(*initialState)[i] = this->integerVariables[i].getLowerBound()->getValueAsInt(nullptr);
// } else {
// // Initial value was given.
// int_fast64_t initialValue = this->integerVariables[i].getInitialValue()->getValueAsInt(nullptr);
// std::get<1>(*initialState)[i] = initialValue;
// }
// }
//
// LOG4CPLUS_DEBUG(logger, "Generated initial state.");
// return initialState;
// }
// static uint_fast64_t ExplicitModelAdapter::getOrAddStateIndex(StateType* state) {
// // Check, if the state was already registered.
// auto indexIt = this->stateToIndexMap.find(state);
//
// if (indexIt == this->stateToIndexMap.end()) {
// // The state has not been seen, yet, so add it to the list of all reachable states.
// allStates.push_back(state);
// stateToIndexMap[state] = allStates.size() - 1;
// return allStates.size() - 1;
// } else {
// // The state was already encountered. Delete the copy of the old state and return its index.
// delete state;
// return indexIt->second;
// }
// }
// void ExplicitModelAdapter::addUnlabeledTransitions(uint_fast64_t stateIndex, std::list<std::pair<std::pair<std::string, std::list<uint_fast64_t>>, std::map<uint_fast64_t, double>>>& transitionList) { // void ExplicitModelAdapter::addUnlabeledTransitions(uint_fast64_t stateIndex, std::list<std::pair<std::pair<std::string, std::list<uint_fast64_t>>, std::map<uint_fast64_t, double>>>& transitionList) {
// StateType const* state = this->allStates[stateIndex]; // StateType const* state = this->allStates[stateIndex];
// //

891
src/adapters/ExplicitModelAdapter.h
File diff suppressed because it is too large
View File

32
src/models/AtomicPropositionsLabeling.h

@ -89,6 +89,38 @@ public:
// Intentionally left empty. // Intentionally left empty.
} }
/*!
* Assignment operator that copies the contents of the right-hand-side to the current labeling.
*
* @param other The atomic propositions labeling to copy.
*/
AtomicPropositionsLabeling& operator=(AtomicPropositionsLabeling const& other) {
if (this != &other) {
this->stateCount = other.stateCount;
this->apCountMax = other.apCountMax;
this->apsCurrent = other.apsCurrent;
this->nameToLabelingMap = other.nameToLabelingMap;
this->singleLabelings = other.singleLabelings;
}
return *this;
}
/*!
* Assignment operator that moves the contents of the right-hand-side to the current labeling.
*
* @param other The atomic propositions labeling to move.
*/
AtomicPropositionsLabeling& operator=(AtomicPropositionsLabeling&& other) {
if (this != &other) {
this->stateCount = other.stateCount;
this->apCountMax = other.apCountMax;
this->apsCurrent = other.apsCurrent;
this->nameToLabelingMap = std::move(other.nameToLabelingMap);
this->singleLabelings = std::move(other.singleLabelings);
}
return *this;
}
/*! /*!
* (Empty) destructor. * (Empty) destructor.
*/ */

4
src/storm.cpp

@ -332,8 +332,8 @@ int main(const int argc, const char* argv[]) {
} else if (s->isSet("symbolic")) { } else if (s->isSet("symbolic")) {
std::string const& programFile = s->getOptionByLongName("symbolic").getArgument(0).getValueAsString(); std::string const& programFile = s->getOptionByLongName("symbolic").getArgument(0).getValueAsString();
std::string const& constants = s->getOptionByLongName("constants").getArgument(0).getValueAsString(); std::string const& constants = s->getOptionByLongName("constants").getArgument(0).getValueAsString();
std::shared_ptr<storm::models::AbstractModel<double>> model = storm::adapters::ExplicitModelAdapter::translateProgram(storm::parser::PrismParserFromFile(programFile), constants);
model->printModelInformationToStream(std::cout);
std::shared_ptr<storm::models::AbstractModel<double>> model = storm::adapters::ExplicitModelAdapter<double>::translateProgram(storm::parser::PrismParserFromFile(programFile), constants);
// model->printModelInformationToStream(std::cout);
// Enable the following lines to test the MinimalLabelSetGenerator. // Enable the following lines to test the MinimalLabelSetGenerator.
// if (model->getType() == storm::models::MDP) { // if (model->getType() == storm::models::MDP) {

Loading…
Cancel
Save