#include "src/modelchecker/propositional/SymbolicPropositionalModelChecker.h" #include "src/storage/dd/Add.h" #include "src/storage/dd/DdManager.h" #include "src/models/symbolic/Dtmc.h" #include "src/models/symbolic/Ctmc.h" #include "src/models/symbolic/Mdp.h" #include "src/models/symbolic/StandardRewardModel.h" #include "src/modelchecker/results/SymbolicQualitativeCheckResult.h" #include "src/logic/FragmentSpecification.h" #include "src/utility/macros.h" #include "src/exceptions/InvalidPropertyException.h" namespace storm { namespace modelchecker { template SymbolicPropositionalModelChecker::SymbolicPropositionalModelChecker(storm::models::symbolic::Model const& model) : model(model) { // Intentionally left empty. } template bool SymbolicPropositionalModelChecker::canHandle(CheckTask const& checkTask) const { storm::logic::Formula const& formula = checkTask.getFormula(); return formula.isInFragment(storm::logic::propositional()); } template std::unique_ptr SymbolicPropositionalModelChecker::checkBooleanLiteralFormula(CheckTask const& checkTask) { storm::logic::BooleanLiteralFormula const& stateFormula = checkTask.getFormula(); if (stateFormula.isTrueFormula()) { return std::unique_ptr(new SymbolicQualitativeCheckResult(model.getReachableStates(), model.getReachableStates())); } else { return std::unique_ptr(new SymbolicQualitativeCheckResult(model.getReachableStates(), model.getManager().getBddZero())); } } template std::unique_ptr SymbolicPropositionalModelChecker::checkAtomicLabelFormula(CheckTask const& checkTask) { storm::logic::AtomicLabelFormula const& stateFormula = checkTask.getFormula(); STORM_LOG_THROW(model.hasLabel(stateFormula.getLabel()), storm::exceptions::InvalidPropertyException, "The property refers to unknown label '" << stateFormula.getLabel() << "'."); return std::unique_ptr(new SymbolicQualitativeCheckResult(model.getReachableStates(), model.getStates(stateFormula.getLabel()))); } template std::unique_ptr SymbolicPropositionalModelChecker::checkAtomicExpressionFormula(CheckTask const& checkTask) { storm::logic::AtomicExpressionFormula const& stateFormula = checkTask.getFormula(); return std::unique_ptr(new SymbolicQualitativeCheckResult(model.getReachableStates(), model.getStates(stateFormula.getExpression()))); } template storm::models::symbolic::Model const& SymbolicPropositionalModelChecker::getModel() const { return model; } template template ModelType const& SymbolicPropositionalModelChecker::getModelAs() const { return dynamic_cast(model); } // Explicitly instantiate the template class. template storm::models::symbolic::Dtmc const& SymbolicPropositionalModelChecker::getModelAs() const; template storm::models::symbolic::Ctmc const& SymbolicPropositionalModelChecker::getModelAs() const; template storm::models::symbolic::Mdp const& SymbolicPropositionalModelChecker::getModelAs() const; template class SymbolicPropositionalModelChecker; template storm::models::symbolic::Dtmc const& SymbolicPropositionalModelChecker::getModelAs() const; template storm::models::symbolic::Ctmc const& SymbolicPropositionalModelChecker::getModelAs() const; template storm::models::symbolic::Mdp const& SymbolicPropositionalModelChecker::getModelAs() const; template class SymbolicPropositionalModelChecker; } }