From 1f4552c0465bfd8eb91fb87516539ad9dc4b74fb Mon Sep 17 00:00:00 2001 From: TimQu Date: Thu, 16 Feb 2017 23:32:43 +0100 Subject: [PATCH] Fixed check results of hybrid multi objective model checking --- .../pcaa/SparsePcaaParetoQuery.cpp | 4 +- .../prctl/HybridMdpPrctlModelChecker.cpp | 30 ++++++++- .../modelchecker/results/CheckResult.cpp | 63 +++++++++++++------ src/storm/modelchecker/results/CheckResult.h | 35 +++++++---- .../ExplicitParetoCurveCheckResult.cpp | 58 +++++++++++++++++ .../results/ExplicitParetoCurveCheckResult.h | 39 ++++++++++++ .../results/ParetoCurveCheckResult.cpp | 30 ++------- .../results/ParetoCurveCheckResult.h | 26 +++----- .../SymbolicParetoCurveCheckResult.cpp | 57 +++++++++++++++++ .../results/SymbolicParetoCurveCheckResult.h | 41 ++++++++++++ src/storm/solver/SolverSelectionOptions.cpp | 2 + 11 files changed, 306 insertions(+), 79 deletions(-) create mode 100644 src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.cpp create mode 100644 src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.h create mode 100644 src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.cpp create mode 100644 src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.h diff --git a/src/storm/modelchecker/multiobjective/pcaa/SparsePcaaParetoQuery.cpp b/src/storm/modelchecker/multiobjective/pcaa/SparsePcaaParetoQuery.cpp index 639589592..93337995d 100644 --- a/src/storm/modelchecker/multiobjective/pcaa/SparsePcaaParetoQuery.cpp +++ b/src/storm/modelchecker/multiobjective/pcaa/SparsePcaaParetoQuery.cpp @@ -4,7 +4,7 @@ #include "storm/models/sparse/Mdp.h" #include "storm/models/sparse/MarkovAutomaton.h" #include "storm/models/sparse/StandardRewardModel.h" -#include "storm/modelchecker/results/ParetoCurveCheckResult.h" +#include "storm/modelchecker/results/ExplicitParetoCurveCheckResult.h" #include "storm/utility/constants.h" #include "storm/utility/vector.h" #include "storm/settings/SettingsManager.h" @@ -43,7 +43,7 @@ namespace storm { for(auto const& vertex : vertices) { paretoOptimalPoints.push_back(storm::utility::vector::convertNumericVector(this->transformPointToOriginalModel(vertex))); } - return std::unique_ptr(new ParetoCurveCheckResult(this->originalModel.getInitialStates().getNextSetIndex(0), + return std::unique_ptr(new ExplicitParetoCurveCheckResult(this->originalModel.getInitialStates().getNextSetIndex(0), std::move(paretoOptimalPoints), this->transformPolytopeToOriginalModel(this->underApproximation)->template convertNumberRepresentation(), this->transformPolytopeToOriginalModel(this->overApproximation)->template convertNumberRepresentation())); diff --git a/src/storm/modelchecker/prctl/HybridMdpPrctlModelChecker.cpp b/src/storm/modelchecker/prctl/HybridMdpPrctlModelChecker.cpp index d42d81251..d42de45dd 100644 --- a/src/storm/modelchecker/prctl/HybridMdpPrctlModelChecker.cpp +++ b/src/storm/modelchecker/prctl/HybridMdpPrctlModelChecker.cpp @@ -5,8 +5,14 @@ #include "storm/models/symbolic/Mdp.h" #include "storm/models/symbolic/StandardRewardModel.h" +#include "storm/storage/dd/DdManager.h" + #include "storm/modelchecker/results/SymbolicQualitativeCheckResult.h" #include "storm/modelchecker/results/SymbolicQuantitativeCheckResult.h" +#include "storm/modelchecker/results/SymbolicParetoCurveCheckResult.h" +#include "storm/modelchecker/results/ExplicitQualitativeCheckResult.h" +#include "storm/modelchecker/results/ExplicitQuantitativeCheckResult.h" +#include "storm/modelchecker/results/ExplicitParetoCurveCheckResult.h" #include "storm/logic/FragmentSpecification.h" @@ -21,6 +27,7 @@ #include "storm/exceptions/InvalidStateException.h" #include "storm/exceptions/InvalidPropertyException.h" +#include "storm/exceptions/UnexpectedException.h" namespace storm { namespace modelchecker { @@ -41,7 +48,8 @@ namespace storm { return true; } else { // Check whether we consider a multi-objective formula - // For multi-objective model checking, each state requires an individual scheduler (in contrast to single-objective model checking). Let's exclude that all states are considered. + // For multi-objective model checking, each state requires an individual scheduler (in contrast to single-objective model checking). Let's exclude that multiple states are relevant + if(this->getModel().getInitialStates().getNonZeroCount() > 1) return false; if(!checkTask.isOnlyInitialStatesRelevantSet()) return false; return formula.isInFragment(storm::logic::multiObjective().setCumulativeRewardFormulasAllowed(true)); } @@ -118,7 +126,25 @@ namespace storm { template std::unique_ptr HybridMdpPrctlModelChecker::checkMultiObjectiveFormula(CheckTask const& checkTask) { auto sparseModel = storm::transformer::SymbolicMdpToSparseMdpTransformer::translate(this->getModel()); - return multiobjective::performPcaa(*sparseModel, checkTask.getFormula()); + std::unique_ptr explicitResult = multiobjective::performPcaa(*sparseModel, checkTask.getFormula()); + + // Convert the explicit result + if(explicitResult->isExplicitQualitativeCheckResult()) { + if(explicitResult->asExplicitQualitativeCheckResult()[*sparseModel->getInitialStates().begin()]) { + return std::unique_ptr(new storm::modelchecker::SymbolicQualitativeCheckResult(this->getModel().getReachableStates(), this->getModel().getInitialStates(), this->getModel().getManager().getBddOne())); + } else { + return std::unique_ptr(new storm::modelchecker::SymbolicQualitativeCheckResult(this->getModel().getReachableStates(), this->getModel().getInitialStates(), this->getModel().getManager().getBddZero())); + } + } else if(explicitResult->isExplicitQuantitativeCheckResult()) { + ValueType const& res = explicitResult->template asExplicitQuantitativeCheckResult()[*sparseModel->getInitialStates().begin()]; + return std::unique_ptr(new storm::modelchecker::SymbolicQuantitativeCheckResult(this->getModel().getReachableStates(), this->getModel().getInitialStates(), this->getModel().getManager().template getConstant(res))); + } else if(explicitResult->isExplicitParetoCurveCheckResult()) { + ExplicitParetoCurveCheckResult const& paretoResult = explicitResult->template asExplicitParetoCurveCheckResult(); + return std::unique_ptr(new storm::modelchecker::SymbolicParetoCurveCheckResult(this->getModel().getInitialStates(), paretoResult.getPoints(), paretoResult.getUnderApproximation(), paretoResult.getOverApproximation())); + } else { + STORM_LOG_THROW(false, storm::exceptions::UnexpectedException, "The obtained checkresult has an unexpected type."); + return nullptr; + } } template class HybridMdpPrctlModelChecker>; diff --git a/src/storm/modelchecker/results/CheckResult.cpp b/src/storm/modelchecker/results/CheckResult.cpp index 210ca3b59..44cedb816 100644 --- a/src/storm/modelchecker/results/CheckResult.cpp +++ b/src/storm/modelchecker/results/CheckResult.cpp @@ -5,10 +5,11 @@ #include "storm/modelchecker/results/ExplicitQualitativeCheckResult.h" #include "storm/modelchecker/results/ExplicitQuantitativeCheckResult.h" +#include "storm/modelchecker/results/ExplicitParetoCurveCheckResult.h" #include "storm/modelchecker/results/SymbolicQualitativeCheckResult.h" #include "storm/modelchecker/results/SymbolicQuantitativeCheckResult.h" +#include "storm/modelchecker/results/SymbolicParetoCurveCheckResult.h" #include "storm/modelchecker/results/HybridQuantitativeCheckResult.h" -#include "storm/modelchecker/results/ParetoCurveCheckResult.h" #include "storm/utility/macros.h" #include "storm/exceptions/InvalidOperationException.h" @@ -34,7 +35,11 @@ namespace storm { bool CheckResult::isQualitative() const { return false; } - + + bool CheckResult::isParetoCurveCheckResult() const { + return false; + } + bool CheckResult::isResultForAllStates() const { return false; } @@ -51,7 +56,11 @@ namespace storm { bool CheckResult::isExplicitQuantitativeCheckResult() const { return false; } - + + bool CheckResult::isExplicitParetoCurveCheckResult() const { + return false; + } + bool CheckResult::isSymbolicQualitativeCheckResult() const { return false; } @@ -59,12 +68,12 @@ namespace storm { bool CheckResult::isSymbolicQuantitativeCheckResult() const { return false; } - - bool CheckResult::isHybridQuantitativeCheckResult() const { + + bool CheckResult::isSymbolicParetoCurveCheckResult() const { return false; } - - bool CheckResult::isParetoCurveCheckResult() const { + + bool CheckResult::isHybridQuantitativeCheckResult() const { return false; } @@ -85,6 +94,16 @@ namespace storm { ExplicitQuantitativeCheckResult const& CheckResult::asExplicitQuantitativeCheckResult() const { return dynamic_cast const&>(*this); } + + template + ExplicitParetoCurveCheckResult& CheckResult::asExplicitParetoCurveCheckResult() { + return dynamic_cast&>(*this); + } + + template + ExplicitParetoCurveCheckResult const& CheckResult::asExplicitParetoCurveCheckResult() const { + return dynamic_cast const&>(*this); + } QualitativeCheckResult& CheckResult::asQualitativeCheckResult() { return dynamic_cast(*this); @@ -124,25 +143,29 @@ namespace storm { HybridQuantitativeCheckResult const& CheckResult::asHybridQuantitativeCheckResult() const { return dynamic_cast const&>(*this); } - - template - ParetoCurveCheckResult& CheckResult::asParetoCurveCheckResult() { - return dynamic_cast&>(*this); + + template + SymbolicParetoCurveCheckResult& CheckResult::asSymbolicParetoCurveCheckResult() { + return dynamic_cast&>(*this); } - - template - ParetoCurveCheckResult const& CheckResult::asParetoCurveCheckResult() const { - return dynamic_cast const&>(*this); + + template + SymbolicParetoCurveCheckResult const& CheckResult::asSymbolicParetoCurveCheckResult() const { + return dynamic_cast const&>(*this); } // Explicitly instantiate the template functions. template ExplicitQuantitativeCheckResult& CheckResult::asExplicitQuantitativeCheckResult(); template ExplicitQuantitativeCheckResult const& CheckResult::asExplicitQuantitativeCheckResult() const; + template ExplicitParetoCurveCheckResult& CheckResult::asExplicitParetoCurveCheckResult(); + template ExplicitParetoCurveCheckResult const& CheckResult::asExplicitParetoCurveCheckResult() const; template SymbolicQualitativeCheckResult& CheckResult::asSymbolicQualitativeCheckResult(); template SymbolicQualitativeCheckResult const& CheckResult::asSymbolicQualitativeCheckResult() const; template SymbolicQuantitativeCheckResult& CheckResult::asSymbolicQuantitativeCheckResult(); template SymbolicQuantitativeCheckResult const& CheckResult::asSymbolicQuantitativeCheckResult() const; + template SymbolicParetoCurveCheckResult& CheckResult::asSymbolicParetoCurveCheckResult(); + template SymbolicParetoCurveCheckResult const& CheckResult::asSymbolicParetoCurveCheckResult() const; template HybridQuantitativeCheckResult& CheckResult::asHybridQuantitativeCheckResult(); template HybridQuantitativeCheckResult const& CheckResult::asHybridQuantitativeCheckResult() const; @@ -150,11 +173,11 @@ namespace storm { template SymbolicQualitativeCheckResult const& CheckResult::asSymbolicQualitativeCheckResult() const; template SymbolicQuantitativeCheckResult& CheckResult::asSymbolicQuantitativeCheckResult(); template SymbolicQuantitativeCheckResult const& CheckResult::asSymbolicQuantitativeCheckResult() const; + template SymbolicParetoCurveCheckResult& CheckResult::asSymbolicParetoCurveCheckResult(); + template SymbolicParetoCurveCheckResult const& CheckResult::asSymbolicParetoCurveCheckResult() const; template HybridQuantitativeCheckResult& CheckResult::asHybridQuantitativeCheckResult(); template HybridQuantitativeCheckResult const& CheckResult::asHybridQuantitativeCheckResult() const; - - template ParetoCurveCheckResult& CheckResult::asParetoCurveCheckResult(); - template ParetoCurveCheckResult const& CheckResult::asParetoCurveCheckResult() const; + #ifdef STORM_HAVE_CARL template ExplicitQuantitativeCheckResult& CheckResult::asExplicitQuantitativeCheckResult(); @@ -163,8 +186,8 @@ namespace storm { template ExplicitQuantitativeCheckResult& CheckResult::asExplicitQuantitativeCheckResult(); template ExplicitQuantitativeCheckResult const& CheckResult::asExplicitQuantitativeCheckResult() const; - template ParetoCurveCheckResult& CheckResult::asParetoCurveCheckResult(); - template ParetoCurveCheckResult const& CheckResult::asParetoCurveCheckResult() const; + template ExplicitParetoCurveCheckResult& CheckResult::asExplicitParetoCurveCheckResult(); + template ExplicitParetoCurveCheckResult const& CheckResult::asExplicitParetoCurveCheckResult() const; #endif } } diff --git a/src/storm/modelchecker/results/CheckResult.h b/src/storm/modelchecker/results/CheckResult.h index 6cf39669d..2cff249c9 100644 --- a/src/storm/modelchecker/results/CheckResult.h +++ b/src/storm/modelchecker/results/CheckResult.h @@ -18,18 +18,21 @@ namespace storm { template class ExplicitQuantitativeCheckResult; + template + class ExplicitParetoCurveCheckResult; + template class SymbolicQualitativeCheckResult; - + template class SymbolicQuantitativeCheckResult; - + template class HybridQuantitativeCheckResult; - - template - class ParetoCurveCheckResult; - + + template + class SymbolicParetoCurveCheckResult; + // The base class of all check results. class CheckResult { public: @@ -49,12 +52,14 @@ namespace storm { virtual bool isHybrid() const; virtual bool isQuantitative() const; virtual bool isQualitative() const; + virtual bool isParetoCurveCheckResult() const; virtual bool isExplicitQualitativeCheckResult() const; virtual bool isExplicitQuantitativeCheckResult() const; + virtual bool isExplicitParetoCurveCheckResult() const; virtual bool isSymbolicQualitativeCheckResult() const; virtual bool isSymbolicQuantitativeCheckResult() const; + virtual bool isSymbolicParetoCurveCheckResult() const; virtual bool isHybridQuantitativeCheckResult() const; - virtual bool isParetoCurveCheckResult() const; virtual bool isResultForAllStates() const; QualitativeCheckResult& asQualitativeCheckResult(); @@ -78,6 +83,12 @@ namespace storm { template ExplicitQuantitativeCheckResult const& asExplicitQuantitativeCheckResult() const; + + template + ExplicitParetoCurveCheckResult& asExplicitParetoCurveCheckResult(); + + template + ExplicitParetoCurveCheckResult const& asExplicitParetoCurveCheckResult() const; template SymbolicQualitativeCheckResult& asSymbolicQualitativeCheckResult(); @@ -97,11 +108,11 @@ namespace storm { template HybridQuantitativeCheckResult const& asHybridQuantitativeCheckResult() const; - template - ParetoCurveCheckResult& asParetoCurveCheckResult(); - - template - ParetoCurveCheckResult const& asParetoCurveCheckResult() const; + template + SymbolicParetoCurveCheckResult& asSymbolicParetoCurveCheckResult(); + + template + SymbolicParetoCurveCheckResult const& asSymbolicParetoCurveCheckResult() const; virtual std::ostream& writeToStream(std::ostream& out) const = 0; }; diff --git a/src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.cpp b/src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.cpp new file mode 100644 index 000000000..9294cd627 --- /dev/null +++ b/src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.cpp @@ -0,0 +1,58 @@ + +#include "storm/modelchecker/results/ExplicitParetoCurveCheckResult.h" + +#include "storm/adapters/CarlAdapter.h" +#include "storm/modelchecker/results/ExplicitQualitativeCheckResult.h" +#include "storm/utility/macros.h" +#include "storm/utility/vector.h" + +#include "storm/exceptions/InvalidOperationException.h" + +namespace storm { + namespace modelchecker { + template + ExplicitParetoCurveCheckResult::ExplicitParetoCurveCheckResult() { + // Intentionally left empty. + } + + template + ExplicitParetoCurveCheckResult::ExplicitParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector::point_type> const& points, typename ParetoCurveCheckResult::polytope_type const& underApproximation, typename ParetoCurveCheckResult::polytope_type const& overApproximation) : ParetoCurveCheckResult(points, underApproximation, overApproximation), state(state) { + // Intentionally left empty. + } + + template + ExplicitParetoCurveCheckResult::ExplicitParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector::point_type>&& points, typename ParetoCurveCheckResult::polytope_type&& underApproximation, typename ParetoCurveCheckResult::polytope_type&& overApproximation) : ParetoCurveCheckResult(points, underApproximation, overApproximation), state(state) { + // Intentionally left empty. + } + + template + bool ExplicitParetoCurveCheckResult::isExplicitParetoCurveCheckResult() const { + return true; + } + + template + bool ExplicitParetoCurveCheckResult::isExplicit() const { + return true; + } + + template + void ExplicitParetoCurveCheckResult::filter(QualitativeCheckResult const& filter) { + STORM_LOG_THROW(filter.isExplicitQualitativeCheckResult(), storm::exceptions::InvalidOperationException, "Cannot filter explicit check result with non-explicit filter."); + STORM_LOG_THROW(filter.isResultForAllStates(), storm::exceptions::InvalidOperationException, "Cannot filter check result with non-complete filter."); + ExplicitQualitativeCheckResult const& explicitFilter = filter.asExplicitQualitativeCheckResult(); + ExplicitQualitativeCheckResult::vector_type const& filterTruthValues = explicitFilter.getTruthValuesVector(); + + STORM_LOG_THROW(filterTruthValues.getNumberOfSetBits() == 1 && filterTruthValues.get(state), storm::exceptions::InvalidOperationException, "The check result fails to contain some results referred to by the filter."); + } + + template + storm::storage::sparse::state_type const& ExplicitParetoCurveCheckResult:: getState() const { + return state; + } + + template class ExplicitParetoCurveCheckResult; +#ifdef STORM_HAVE_CARL + template class ExplicitParetoCurveCheckResult; +#endif + } +} diff --git a/src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.h b/src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.h new file mode 100644 index 000000000..251102f01 --- /dev/null +++ b/src/storm/modelchecker/results/ExplicitParetoCurveCheckResult.h @@ -0,0 +1,39 @@ +#ifndef STORM_MODELCHECKER_EXPLICITPARETOCURVECHECKRESULT_H_ +#define STORM_MODELCHECKER_EXPLICITPARETOCURVECHECKRESULT_H_ + +#include + +#include "storm/modelchecker/results/ParetoCurveCheckResult.h" +#include "storm/storage/sparse/StateType.h" + +namespace storm { + namespace modelchecker { + template + class ExplicitParetoCurveCheckResult : public ParetoCurveCheckResult { + public: + + ExplicitParetoCurveCheckResult(); + ExplicitParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector::point_type> const& points, typename ParetoCurveCheckResult::polytope_type const& underApproximation, typename ParetoCurveCheckResult::polytope_type const& overApproximation); + ExplicitParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector::point_type>&& points, typename ParetoCurveCheckResult::polytope_type&& underApproximation, typename ParetoCurveCheckResult::polytope_type&& overApproximation); + + ExplicitParetoCurveCheckResult(ExplicitParetoCurveCheckResult const& other) = default; + ExplicitParetoCurveCheckResult& operator=(ExplicitParetoCurveCheckResult const& other) = default; + ExplicitParetoCurveCheckResult(ExplicitParetoCurveCheckResult&& other) = default; + ExplicitParetoCurveCheckResult& operator=(ExplicitParetoCurveCheckResult&& other) = default; + virtual ~ExplicitParetoCurveCheckResult() = default; + + virtual bool isExplicitParetoCurveCheckResult() const override; + virtual bool isExplicit() const override; + + virtual void filter(QualitativeCheckResult const& filter) override; + + storm::storage::sparse::state_type const& getState() const; + + private: + // The state of the checked model to which the result applies + storm::storage::sparse::state_type state; + }; + } +} + +#endif /* STORM_MODELCHECKER_EXPLICITPARETOCURVECHECKRESULT_H_ */ diff --git a/src/storm/modelchecker/results/ParetoCurveCheckResult.cpp b/src/storm/modelchecker/results/ParetoCurveCheckResult.cpp index d4aa5ca64..a76857576 100644 --- a/src/storm/modelchecker/results/ParetoCurveCheckResult.cpp +++ b/src/storm/modelchecker/results/ParetoCurveCheckResult.cpp @@ -1,49 +1,31 @@ #include "storm/modelchecker/results/ParetoCurveCheckResult.h" #include "storm/adapters/CarlAdapter.h" -#include "storm/modelchecker/results/ExplicitQualitativeCheckResult.h" -#include "storm/utility/macros.h" #include "storm/utility/vector.h" -#include "storm/exceptions/InvalidOperationException.h" - namespace storm { namespace modelchecker { + template ParetoCurveCheckResult::ParetoCurveCheckResult() { // Intentionally left empty. } - + template - ParetoCurveCheckResult::ParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector const& points, polytope_type const& underApproximation, polytope_type const& overApproximation) : state(state), points(points), underApproximation(underApproximation), overApproximation(overApproximation) { + ParetoCurveCheckResult::ParetoCurveCheckResult(std::vector const& points, polytope_type const& underApproximation, polytope_type const& overApproximation) : points(points), underApproximation(underApproximation), overApproximation(overApproximation) { // Intentionally left empty. } - + template - ParetoCurveCheckResult::ParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector&& points, polytope_type&& underApproximation, polytope_type&& overApproximation) : state(state), points(points), underApproximation(underApproximation), overApproximation(overApproximation) { + ParetoCurveCheckResult::ParetoCurveCheckResult(std::vector&& points, polytope_type&& underApproximation, polytope_type&& overApproximation) : points(points), underApproximation(underApproximation), overApproximation(overApproximation) { // Intentionally left empty. } - + template bool ParetoCurveCheckResult::isParetoCurveCheckResult() const { return true; } - template - void ParetoCurveCheckResult::filter(QualitativeCheckResult const& filter) { - STORM_LOG_THROW(filter.isExplicitQualitativeCheckResult(), storm::exceptions::InvalidOperationException, "Cannot filter explicit check result with non-explicit filter."); - STORM_LOG_THROW(filter.isResultForAllStates(), storm::exceptions::InvalidOperationException, "Cannot filter check result with non-complete filter."); - ExplicitQualitativeCheckResult const& explicitFilter = filter.asExplicitQualitativeCheckResult(); - ExplicitQualitativeCheckResult::vector_type const& filterTruthValues = explicitFilter.getTruthValuesVector(); - - STORM_LOG_THROW(filterTruthValues.getNumberOfSetBits() == 1 && filterTruthValues.get(state), storm::exceptions::InvalidOperationException, "The check result fails to contain some results referred to by the filter."); - } - - template - storm::storage::sparse::state_type const& ParetoCurveCheckResult:: getState() const { - return state; - } - template std::vector::point_type> const& ParetoCurveCheckResult::getPoints() const { return points; diff --git a/src/storm/modelchecker/results/ParetoCurveCheckResult.h b/src/storm/modelchecker/results/ParetoCurveCheckResult.h index 3a2618b3d..5f0979f44 100644 --- a/src/storm/modelchecker/results/ParetoCurveCheckResult.h +++ b/src/storm/modelchecker/results/ParetoCurveCheckResult.h @@ -4,8 +4,6 @@ #include #include "storm/modelchecker/results/CheckResult.h" -#include "storm/utility/OsDetection.h" -#include "storm/storage/sparse/StateType.h" #include "storm/storage/geometry/Polytope.h" namespace storm { @@ -15,32 +13,22 @@ namespace storm { public: typedef std::vector point_type; typedef std::shared_ptr> polytope_type; - + ParetoCurveCheckResult(); - ParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector const& points, polytope_type const& underApproximation, polytope_type const& overApproximation); - ParetoCurveCheckResult(storm::storage::sparse::state_type const& state, std::vector&& points, polytope_type&& underApproximation, polytope_type&& overApproximation); - - ParetoCurveCheckResult(ParetoCurveCheckResult const& other) = default; - ParetoCurveCheckResult& operator=(ParetoCurveCheckResult const& other) = default; - ParetoCurveCheckResult(ParetoCurveCheckResult&& other) = default; - ParetoCurveCheckResult& operator=(ParetoCurveCheckResult&& other) = default; - virtual ~ParetoCurveCheckResult() = default; - + virtual bool isParetoCurveCheckResult() const override; - virtual void filter(QualitativeCheckResult const& filter) override; - - storm::storage::sparse::state_type const& getState() const; std::vector const& getPoints() const; polytope_type const& getUnderApproximation() const; polytope_type const& getOverApproximation() const; virtual std::ostream& writeToStream(std::ostream& out) const override; - private: - // The state of the checked model to which the result applies - storm::storage::sparse::state_type state; - + protected: + ParetoCurveCheckResult(std::vector const& points, polytope_type const& underApproximation, polytope_type const& overApproximation); + ParetoCurveCheckResult(std::vector&& points, polytope_type&& underApproximation, polytope_type&& overApproximation); + + // The pareto optimal points that have been found. std::vector points; diff --git a/src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.cpp b/src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.cpp new file mode 100644 index 000000000..868116adf --- /dev/null +++ b/src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.cpp @@ -0,0 +1,57 @@ + +#include "storm/modelchecker/results/SymbolicParetoCurveCheckResult.h" + +#include "storm/adapters/CarlAdapter.h" +#include "storm/modelchecker/results/SymbolicQualitativeCheckResult.h" +#include "storm/utility/macros.h" +#include "storm/storage/dd/DdManager.h" + +#include "storm/exceptions/InvalidOperationException.h" + +namespace storm { + namespace modelchecker { + template + SymbolicParetoCurveCheckResult::SymbolicParetoCurveCheckResult() { + // Intentionally left empty. + } + + template + SymbolicParetoCurveCheckResult::SymbolicParetoCurveCheckResult(storm::dd::Bdd const& state, std::vector::point_type> const& points, typename ParetoCurveCheckResult::polytope_type const& underApproximation, typename ParetoCurveCheckResult::polytope_type const& overApproximation) : ParetoCurveCheckResult(points, underApproximation, overApproximation), state(state) { + STORM_LOG_THROW(this->state.getNonZeroCount() == 1, storm::exceptions::InvalidOperationException, "ParetoCheckResults are only relevant for a single state."); + } + + template + SymbolicParetoCurveCheckResult::SymbolicParetoCurveCheckResult(storm::dd::Bdd const& state, std::vector::point_type>&& points, typename ParetoCurveCheckResult::polytope_type&& underApproximation, typename ParetoCurveCheckResult::polytope_type&& overApproximation) : ParetoCurveCheckResult(points, underApproximation, overApproximation), state(state) { + STORM_LOG_THROW(this->state.getNonZeroCount() == 1, storm::exceptions::InvalidOperationException, "ParetoCheckResults are only relevant for a single state."); + } + + template + bool SymbolicParetoCurveCheckResult::isSymbolicParetoCurveCheckResult() const { + return true; + } + + template + bool SymbolicParetoCurveCheckResult::isSymbolic() const { + return true; + } + + template + void SymbolicParetoCurveCheckResult::filter(QualitativeCheckResult const& filter) { + STORM_LOG_THROW(filter.isSymbolicQualitativeCheckResult(), storm::exceptions::InvalidOperationException, "Cannot filter Symbolic check result with non-Symbolic filter."); + STORM_LOG_THROW(filter.isResultForAllStates(), storm::exceptions::InvalidOperationException, "Cannot filter check result with non-complete filter."); + SymbolicQualitativeCheckResult const& symbolicFilter = filter.template asSymbolicQualitativeCheckResult(); + + storm::dd::Bdd const& filterTruthValues = symbolicFilter.getTruthValuesVector(); + + STORM_LOG_THROW(filterTruthValues.getNonZeroCount() == 1 && !(filterTruthValues && state).isZero(), storm::exceptions::InvalidOperationException, "The check result fails to contain some results referred to by the filter."); + } + + template + storm::dd::Bdd const& SymbolicParetoCurveCheckResult::getState() const { + return state; + } + + template class SymbolicParetoCurveCheckResult; + template class SymbolicParetoCurveCheckResult; + } +} diff --git a/src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.h b/src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.h new file mode 100644 index 000000000..edda08abf --- /dev/null +++ b/src/storm/modelchecker/results/SymbolicParetoCurveCheckResult.h @@ -0,0 +1,41 @@ +#ifndef STORM_MODELCHECKER_SYMBOLICPARETOCURVECHECKRESULT_H_ +#define STORM_MODELCHECKER_SYMBOLICPARETOCURVECHECKRESULT_H_ + +#include + +#include "storm/modelchecker/results/ParetoCurveCheckResult.h" +#include "storm/storage/dd/DdType.h" +#include "storm/storage/dd/Bdd.h" + + +namespace storm { + namespace modelchecker { + template + class SymbolicParetoCurveCheckResult : public ParetoCurveCheckResult { + public: + + SymbolicParetoCurveCheckResult(); + SymbolicParetoCurveCheckResult(storm::dd::Bdd const& state, std::vector::point_type> const& points, typename ParetoCurveCheckResult::polytope_type const& underApproximation, typename ParetoCurveCheckResult::polytope_type const& overApproximation); + SymbolicParetoCurveCheckResult(storm::dd::Bdd const& state, std::vector::point_type>&& points, typename ParetoCurveCheckResult::polytope_type&& underApproximation, typename ParetoCurveCheckResult::polytope_type&& overApproximation); + + SymbolicParetoCurveCheckResult(SymbolicParetoCurveCheckResult const& other) = default; + SymbolicParetoCurveCheckResult& operator=(SymbolicParetoCurveCheckResult const& other) = default; + SymbolicParetoCurveCheckResult(SymbolicParetoCurveCheckResult&& other) = default; + SymbolicParetoCurveCheckResult& operator=(SymbolicParetoCurveCheckResult&& other) = default; + virtual ~SymbolicParetoCurveCheckResult() = default; + + virtual bool isSymbolicParetoCurveCheckResult() const override; + virtual bool isSymbolic() const override; + + virtual void filter(QualitativeCheckResult const& filter) override; + + storm::dd::Bdd const& getState() const; + + private: + // The state of the checked model to which the result applies + storm::dd::Bdd state; + }; + } +} + +#endif /* STORM_MODELCHECKER_SYMBOLICPARETOCURVECHECKRESULT_H_ */ diff --git a/src/storm/solver/SolverSelectionOptions.cpp b/src/storm/solver/SolverSelectionOptions.cpp index 125ed2461..fe42f299a 100644 --- a/src/storm/solver/SolverSelectionOptions.cpp +++ b/src/storm/solver/SolverSelectionOptions.cpp @@ -21,6 +21,8 @@ namespace storm { return "Gurobi"; case LpSolverType::Glpk: return "Glpk"; + case LpSolverType::Z3: + return "Z3"; } return "invalid"; }