diff --git a/src/cli/entrypoints.h b/src/cli/entrypoints.h index f541ef4d2..bcbf8cdfa 100644 --- a/src/cli/entrypoints.h +++ b/src/cli/entrypoints.h @@ -3,7 +3,6 @@ #include "src/utility/storm.h" - namespace storm { namespace cli { @@ -84,14 +83,40 @@ namespace storm { } } } - + +#define BRANCH_ON_MODELTYPE(result, model, value_type, dd_type, function, ...) \ + if (model->isSymbolicModel()) { \ + if (model->isOfType(storm::models::ModelType::Dtmc)) { \ + result = function>(model->as>(), __VA_ARGS__); \ + } else if (model->isOfType(storm::models::ModelType::Ctmc)) { \ + result = function>(model->as>(), __VA_ARGS__); \ + } else if (model->isOfType(storm::models::ModelType::Mdp)) { \ + result = function>(model->as>(), __VA_ARGS__); \ + } else { \ + STORM_LOG_ASSERT(false, "Unknown model type."); \ + } \ + } else { \ + STORM_LOG_ASSERT(model->isSparseModel(), "Unknown model type."); \ + if (model->isOfType(storm::models::ModelType::Dtmc)) { \ + result = function>(model->as>(), __VA_ARGS__); \ + } else if (model->isOfType(storm::models::ModelType::Ctmc)) { \ + result = function>(model->as>(), __VA_ARGS__); \ + } else if (model->isOfType(storm::models::ModelType::Mdp)) { \ + result = function>(model->as>(), __VA_ARGS__); \ + } else if (model->isOfType(storm::models::ModelType::MarkovAutomaton)) { \ + result = function>(model->as>(), __VA_ARGS__); \ + } else { \ + STORM_LOG_ASSERT(false, "Unknown model type."); \ + } \ + } + template void buildAndCheckSymbolicModel(storm::prism::Program const& program, std::vector> const& formulas) { std::shared_ptr model = buildSymbolicModel(program, formulas); STORM_LOG_THROW(model != nullptr, storm::exceptions::InvalidStateException, "Model could not be constructed for an unknown reason."); // Preprocess the model if needed. - model = preprocessModel(model, formulas); + BRANCH_ON_MODELTYPE(model, model, ValueType, storm::dd::DdType::CUDD, preprocessModel, formulas); // Print some information about the model. model->printModelInformationToStream(std::cout); @@ -127,7 +152,7 @@ namespace storm { std::shared_ptr model = buildExplicitModel(settings.getTransitionFilename(), settings.getLabelingFilename(), settings.isStateRewardsSet() ? settings.getStateRewardsFilename() : boost::optional(), settings.isTransitionRewardsSet() ? settings.getTransitionRewardsFilename() : boost::optional(), settings.isChoiceLabelingSet() ? settings.getChoiceLabelingFilename() : boost::optional()); // Preprocess the model if needed. - model = preprocessModel(model, formulas); + BRANCH_ON_MODELTYPE(model, model, ValueType, storm::dd::DdType::CUDD, preprocessModel, formulas); // Print some information about the model. model->printModelInformationToStream(std::cout); diff --git a/src/models/ModelBase.cpp b/src/models/ModelBase.cpp index 1eff87d18..b79d7a81f 100644 --- a/src/models/ModelBase.cpp +++ b/src/models/ModelBase.cpp @@ -13,5 +13,9 @@ namespace storm { bool ModelBase::isSymbolicModel() const { return false; } + + bool ModelBase::isOfType(storm::models::ModelType const& modelType) const { + return this->getType() == modelType; + } } } \ No newline at end of file diff --git a/src/models/ModelBase.h b/src/models/ModelBase.h index 4bbe31b64..d118e1516 100644 --- a/src/models/ModelBase.h +++ b/src/models/ModelBase.h @@ -89,6 +89,14 @@ namespace storm { */ virtual bool isSymbolicModel() const; + /*! + * Checks whether the model is of the given type. + * + * @param modelType The model type to check for. + * @return True iff the model is of the given type. + */ + bool isOfType(storm::models::ModelType const& modelType) const; + private: // The type of the model. ModelType modelType; diff --git a/src/utility/storm.h b/src/utility/storm.h index c7fe8581d..38e78f364 100644 --- a/src/utility/storm.h +++ b/src/utility/storm.h @@ -30,6 +30,7 @@ #include "src/models/ModelBase.h" #include "src/models/sparse/Model.h" #include "src/models/sparse/StandardRewardModel.h" +#include "src/models/sparse/MarkovAutomaton.h" #include "src/models/symbolic/Model.h" #include "src/models/symbolic/StandardRewardModel.h" @@ -80,8 +81,6 @@ namespace storm { std::vector> parseFormulasForExplicit(std::string const& inputString); std::vector> parseFormulasForProgram(std::string const& inputString, storm::prism::Program const& program); - - template std::shared_ptr buildSymbolicModel(storm::prism::Program const& program, std::vector> const& formulas) { std::shared_ptr result(nullptr); @@ -111,7 +110,6 @@ namespace storm { result = storm::builder::DdPrismModelBuilder::translateProgram(program, options); } - // Then, build the model from the symbolic description. return result; } @@ -263,7 +261,6 @@ namespace storm { return result; } - #endif template