Browse Source

merge -- but code is not working atm

tempestpy_adaptions
Sebastian Junges 5 years ago
parent
commit
4418422ea8
  1. 2
      src/storm-pomdp/analysis/MemlessStrategySearchQualitative.cpp
  2. 79
      src/storm-pomdp/analysis/MemlessStrategySearchQualitative.h
  3. 6
      src/storm-pomdp/modelchecker/ApproximatePOMDPModelchecker.cpp
  4. 3
      src/storm/adapters/Z3ExpressionAdapter.cpp
  5. 4
      src/storm/solver/SmtSolver.h
  6. 5
      src/storm/solver/SmtlibSmtSolver.cpp
  7. 2
      src/storm/solver/SmtlibSmtSolver.h
  8. 11
      src/storm/solver/Z3SmtSolver.cpp
  9. 1
      src/storm/solver/Z3SmtSolver.h

2
src/storm-pomdp/analysis/MemlessStrategySearchQualitative.cpp

@ -61,7 +61,7 @@ namespace storm {
smtSolver->add(!pathVars[state][0]); smtSolver->add(!pathVars[state][0]);
} }
if (surelyReachSinkStates.at(state)) {
if (surelyReachSinkStates.get(state)) {
smtSolver->add(!reachVars[state]); smtSolver->add(!reachVars[state]);
} }
else { else {

79
src/storm-pomdp/analysis/MemlessStrategySearchQualitative.h

@ -0,0 +1,79 @@
#include <vector>
#include "storm/storage/expressions/Expressions.h"
#include "storm/solver/SmtSolver.h"
#include "storm/models/sparse/Pomdp.h"
#include "storm/utility/solver.h"
namespace storm {
namespace pomdp {
template<typename ValueType>
class MemlessStrategySearchQualitative {
// Implements an extension to the Chatterjee, Chmelik, Davies (AAAI-16) paper.
public:
MemlessStrategySearchQualitative(storm::models::sparse::Pomdp<ValueType> const& pomdp,
std::set<uint32_t> const& targetObservationSet,
std::shared_ptr<storm::utility::solver::SmtSolverFactory>& smtSolverFactory) :
pomdp(pomdp),
targetObservations(targetObservationSet) {
this->expressionManager = std::make_shared<storm::expressions::ExpressionManager>();
smtSolver = smtSolverFactory->create(*expressionManager);
}
void setSurelyReachSinkStates(storm::storage::BitVector const& surelyReachSink) {
surelyReachSinkStates = surelyReachSink;
}
void analyze(uint64_t k) {
if (k < maxK) {
initialize(k);
}
std::cout << smtSolver->getSmtLibString() << std::endl;
for (uint64_t state : pomdp.getInitialStates()) {
smtSolver->add(reachVars[state]);
}
auto result = smtSolver->check();
switch(result) {
case storm::solver::SmtSolver::CheckResult::Sat:
std::cout << std::endl << "Satisfying assignment: " << std::endl << smtSolver->getModelAsValuation().toString(true) << std::endl;
case storm::solver::SmtSolver::CheckResult::Unsat:
// std::cout << std::endl << "Unsatisfiability core: {" << std::endl;
// for (auto const& expr : solver->getUnsatCore()) {
// std::cout << "\t " << expr << std::endl;
// }
// std::cout << "}" << std::endl;
default:
std::cout<< "oops." << std::endl;
// STORM_LOG_THROW(false, storm::exceptions::UnexpectedException, "SMT solver yielded an unexpected result");
}
//std::cout << "get model:" << std::endl;
//std::cout << smtSolver->getModel().toString() << std::endl;
}
private:
void initialize(uint64_t k);
std::unique_ptr<storm::solver::SmtSolver> smtSolver;
storm::models::sparse::Pomdp<ValueType> const& pomdp;
std::shared_ptr<storm::expressions::ExpressionManager> expressionManager;
uint64_t maxK = -1;
std::set<uint32_t> targetObservations;
storm::storage::BitVector surelyReachSinkStates;
std::vector<std::vector<uint64_t>> statesPerObservation;
std::vector<std::vector<storm::expressions::Expression>> actionSelectionVars; // A_{z,a}
std::vector<storm::expressions::Expression> reachVars;
std::vector<std::vector<storm::expressions::Expression>> pathVars;
};
}
}

6
src/storm-pomdp/modelchecker/ApproximatePOMDPModelchecker.cpp

@ -10,6 +10,7 @@
#include "storm/modelchecker/results/CheckResult.h" #include "storm/modelchecker/results/CheckResult.h"
#include "storm/modelchecker/results/ExplicitQualitativeCheckResult.h" #include "storm/modelchecker/results/ExplicitQualitativeCheckResult.h"
#include "storm/modelchecker/results/ExplicitQuantitativeCheckResult.h" #include "storm/modelchecker/results/ExplicitQuantitativeCheckResult.h"
#include "storm/models/sparse/StandardRewardModel.h"
#include "storm/api/properties.h" #include "storm/api/properties.h"
#include "storm/api/export.h" #include "storm/api/export.h"
#include "storm-parsers/api/storm-parsers.h" #include "storm-parsers/api/storm-parsers.h"
@ -548,7 +549,8 @@ namespace storm {
template<typename ValueType, typename RewardModelType> template<typename ValueType, typename RewardModelType>
std::unique_ptr<POMDPCheckResult<ValueType>> std::unique_ptr<POMDPCheckResult<ValueType>>
ApproximatePOMDPModelchecker<ValueType, RewardModelType>::computeReachabilityReward(storm::models::sparse::Pomdp<ValueType, RewardModelType> const &pomdp, ApproximatePOMDPModelchecker<ValueType, RewardModelType>::computeReachabilityReward(storm::models::sparse::Pomdp<ValueType, RewardModelType> const &pomdp,
std::set<uint32_t> const &targetObservations, bool min, uint64_t gridResolution) {
std::set<uint32_t> const &targetObservations, bool min,
uint64_t gridResolution) {
return computeReachability(pomdp, targetObservations, min, gridResolution, true); return computeReachability(pomdp, targetObservations, min, gridResolution, true);
} }
@ -1088,8 +1090,6 @@ namespace storm {
class ApproximatePOMDPModelchecker<double>; class ApproximatePOMDPModelchecker<double>;
#ifdef STORM_HAVE_CARL #ifdef STORM_HAVE_CARL
//template class ApproximatePOMDPModelchecker<storm::RationalFunction>;
template template
class ApproximatePOMDPModelchecker<storm::RationalNumber>; class ApproximatePOMDPModelchecker<storm::RationalNumber>;

3
src/storm/adapters/Z3ExpressionAdapter.cpp

@ -37,8 +37,7 @@ namespace storm {
result = result && assertion; result = result && assertion;
} }
additionalAssertions.clear(); additionalAssertions.clear();
return result;
return result.simplify();
} }
z3::expr Z3ExpressionAdapter::translateExpression(storm::expressions::Variable const& variable) { z3::expr Z3ExpressionAdapter::translateExpression(storm::expressions::Variable const& variable) {

4
src/storm/solver/SmtSolver.h

@ -24,6 +24,8 @@ namespace storm {
//! possible check results //! possible check results
enum class CheckResult { Sat, Unsat, Unknown }; enum class CheckResult { Sat, Unsat, Unknown };
/*! /*!
* The base class for all model references. They are used to provide a lightweight method of accessing the * The base class for all model references. They are used to provide a lightweight method of accessing the
* models the solver generates (that is, without constructing other objects). * models the solver generates (that is, without constructing other objects).
@ -49,6 +51,8 @@ namespace storm {
*/ */
storm::expressions::ExpressionManager const& getManager() const; storm::expressions::ExpressionManager const& getManager() const;
virtual std::string toString() const = 0;
private: private:
// The expression manager responsible for the variables whose value can be requested via this model // The expression manager responsible for the variables whose value can be requested via this model
// reference. // reference.

5
src/storm/solver/SmtlibSmtSolver.cpp

@ -40,6 +40,11 @@ namespace storm {
STORM_LOG_THROW(false, storm::exceptions::NotImplementedException, "functionality not (yet) implemented"); STORM_LOG_THROW(false, storm::exceptions::NotImplementedException, "functionality not (yet) implemented");
} }
std::string SmtlibSmtSolver::SmtlibModelReference::toString() const {
STORM_LOG_THROW(false, storm::exceptions::NotImplementedException, "functionality not (yet) implemented");
}
SmtlibSmtSolver::SmtlibSmtSolver(storm::expressions::ExpressionManager& manager, bool useCarlExpressions) : SmtSolver(manager), isCommandFileOpen(false), expressionAdapter(nullptr), useCarlExpressions(useCarlExpressions) { SmtlibSmtSolver::SmtlibSmtSolver(storm::expressions::ExpressionManager& manager, bool useCarlExpressions) : SmtSolver(manager), isCommandFileOpen(false), expressionAdapter(nullptr), useCarlExpressions(useCarlExpressions) {
#ifndef STORM_HAVE_CARL #ifndef STORM_HAVE_CARL
STORM_LOG_THROW(!useCarlExpressions, storm::exceptions::IllegalArgumentException, "Tried to use carl expressions but storm is not linked with CARL"); STORM_LOG_THROW(!useCarlExpressions, storm::exceptions::IllegalArgumentException, "Tried to use carl expressions but storm is not linked with CARL");

2
src/storm/solver/SmtlibSmtSolver.h

@ -26,7 +26,7 @@ namespace storm {
virtual bool getBooleanValue(storm::expressions::Variable const& variable) const override; virtual bool getBooleanValue(storm::expressions::Variable const& variable) const override;
virtual int_fast64_t getIntegerValue(storm::expressions::Variable const& variable) const override; virtual int_fast64_t getIntegerValue(storm::expressions::Variable const& variable) const override;
virtual double getRationalValue(storm::expressions::Variable const& variable) const override; virtual double getRationalValue(storm::expressions::Variable const& variable) const override;
virtual std::string toString() const override;
}; };
public: public:

11
src/storm/solver/Z3SmtSolver.cpp

@ -45,6 +45,17 @@ namespace storm {
#endif #endif
} }
std::string Z3SmtSolver::Z3ModelReference::toString() const {
#ifdef STORM_HAVE_Z3
std::stringstream sstr;
sstr << model;
return sstr.str();
#else
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "Storm is compiled without Z3 support.");
#endif
}
Z3SmtSolver::Z3SmtSolver(storm::expressions::ExpressionManager& manager) : SmtSolver(manager) Z3SmtSolver::Z3SmtSolver(storm::expressions::ExpressionManager& manager) : SmtSolver(manager)
#ifdef STORM_HAVE_Z3 #ifdef STORM_HAVE_Z3
, context(nullptr), solver(nullptr), expressionAdapter(nullptr), lastCheckAssumptions(false), lastResult(CheckResult::Unknown) , context(nullptr), solver(nullptr), expressionAdapter(nullptr), lastCheckAssumptions(false), lastResult(CheckResult::Unknown)

1
src/storm/solver/Z3SmtSolver.h

@ -22,6 +22,7 @@ namespace storm {
virtual bool getBooleanValue(storm::expressions::Variable const& variable) const override; virtual bool getBooleanValue(storm::expressions::Variable const& variable) const override;
virtual int_fast64_t getIntegerValue(storm::expressions::Variable const& variable) const override; virtual int_fast64_t getIntegerValue(storm::expressions::Variable const& variable) const override;
virtual double getRationalValue(storm::expressions::Variable const& variable) const override; virtual double getRationalValue(storm::expressions::Variable const& variable) const override;
virtual std::string toString() const override;
private: private:
#ifdef STORM_HAVE_Z3 #ifdef STORM_HAVE_Z3

Loading…
Cancel
Save