Browse Source

Implemented policy extraction for value iteration

Former-commit-id: 604b4667b8
tempestpy_adaptions
TimQu 9 years ago
parent
commit
6ddddd8cfa
  1. 3
      src/modelchecker/region/ApproximationModel.cpp
  2. 5
      src/solver/GmmxxMinMaxLinearEquationSolver.cpp
  3. 2
      src/solver/MinMaxLinearEquationSolver.cpp
  4. 12
      src/solver/MinMaxLinearEquationSolver.h
  5. 5
      src/solver/NativeMinMaxLinearEquationSolver.cpp
  6. 1
      src/utility/solver.cpp

3
src/modelchecker/region/ApproximationModel.cpp

@ -350,7 +350,10 @@ namespace storm {
void ApproximationModel<storm::models::sparse::Dtmc<storm::RationalFunction>, double>::invokeSolver(bool computeLowerBounds){ void ApproximationModel<storm::models::sparse::Dtmc<storm::RationalFunction>, double>::invokeSolver(bool computeLowerBounds){
storm::solver::SolveGoal goal(computeLowerBounds); storm::solver::SolveGoal goal(computeLowerBounds);
std::unique_ptr<storm::solver::MinMaxLinearEquationSolver<double>> solver = storm::solver::configureMinMaxLinearEquationSolver(goal, storm::utility::solver::MinMaxLinearEquationSolverFactory<double>(), this->matrixData.matrix); std::unique_ptr<storm::solver::MinMaxLinearEquationSolver<double>> solver = storm::solver::configureMinMaxLinearEquationSolver(goal, storm::utility::solver::MinMaxLinearEquationSolverFactory<double>(), this->matrixData.matrix);
solver->setPolicyTracking();
solver->solveEquationSystem(this->eqSysResult, this->vectorData.vector); solver->solveEquationSystem(this->eqSysResult, this->vectorData.vector);
std::vector<std::size_t> policy(solver->getPolicy());
std::cout << "Policy: " << policy.size() << " entries. [0]=" << policy[0] << " [20]=" << policy[20] << std::endl;
} }
template<> template<>

5
src/solver/GmmxxMinMaxLinearEquationSolver.cpp

@ -89,6 +89,11 @@ namespace storm {
if (!multiplyResultMemoryProvided) { if (!multiplyResultMemoryProvided) {
delete multiplyResult; delete multiplyResult;
} }
if(this->trackPolicy){
this->policy = this->computePolicy(x,b);
}
} else { } else {
// We will use Policy Iteration to solve the given system. // We will use Policy Iteration to solve the given system.
// We first guess an initial choice resolution which will be refined after each iteration. // We first guess an initial choice resolution which will be refined after each iteration.

2
src/solver/MinMaxLinearEquationSolver.cpp

@ -24,7 +24,7 @@ namespace storm {
} }
std::vector<storm::storage::sparse::state_type> AbstractMinMaxLinearEquationSolver::getPolicy() const { std::vector<storm::storage::sparse::state_type> AbstractMinMaxLinearEquationSolver::getPolicy() const {
STORM_LOG_THROW(!useValueIteration, storm::exceptions::NotImplementedException, "Getting policies after value iteration is not yet supported!");
assert(!policy.empty());
return policy; return policy;
} }
} }

12
src/solver/MinMaxLinearEquationSolver.h

@ -8,6 +8,7 @@
#include "src/storage/sparse/StateType.h" #include "src/storage/sparse/StateType.h"
#include "AllowEarlyTerminationCondition.h" #include "AllowEarlyTerminationCondition.h"
#include "OptimizationDirection.h" #include "OptimizationDirection.h"
#include "src/utility/vector.h"
namespace storm { namespace storm {
namespace storage { namespace storage {
@ -140,6 +141,17 @@ namespace storm {
protected: protected:
std::vector<storm::storage::sparse::state_type> computePolicy(std::vector<ValueType>& x, std::vector<ValueType> const& b) const{
std::vector<ValueType> xPrime(this->A.getRowCount());
this->A.multiplyVectorWithMatrix(x, xPrime);
storm::utility::vector::addVectors(xPrime, b, xPrime);
std::vector<storm::storage::sparse::state_type> policy(x.size());
std::vector<ValueType> reduced(x.size());
storm::utility::vector::reduceVectorMinOrMax(convert(this->direction), xPrime, reduced, this->A.getRowGroupIndices(), &(policy));
return policy;
}
storm::storage::SparseMatrix<ValueType> const& A; storm::storage::SparseMatrix<ValueType> const& A;
std::unique_ptr<AllowEarlyTerminationCondition<ValueType>> earlyTermination; std::unique_ptr<AllowEarlyTerminationCondition<ValueType>> earlyTermination;

5
src/solver/NativeMinMaxLinearEquationSolver.cpp

@ -90,6 +90,11 @@ namespace storm {
if (!multiplyResultMemoryProvided) { if (!multiplyResultMemoryProvided) {
delete multiplyResult; delete multiplyResult;
} }
if(this->trackPolicy){
this->policy = this->computePolicy(x,b);
}
} else { } else {
// We will use Policy Iteration to solve the given system. // We will use Policy Iteration to solve the given system.
// We first guess an initial choice resolution which will be refined after each iteration. // We first guess an initial choice resolution which will be refined after each iteration.

1
src/utility/solver.cpp

@ -123,6 +123,7 @@ namespace storm {
case storm::solver::EquationSolverType::Topological: case storm::solver::EquationSolverType::Topological:
{ {
STORM_LOG_THROW(prefTech != storm::solver::MinMaxTechniqueSelection::PolicyIteration, storm::exceptions::NotImplementedException, "Policy iteration for topological solver is not supported."); STORM_LOG_THROW(prefTech != storm::solver::MinMaxTechniqueSelection::PolicyIteration, storm::exceptions::NotImplementedException, "Policy iteration for topological solver is not supported.");
STORM_LOG_THROW(!trackPolicy , storm::exceptions::NotImplementedException, "Policy extraction for Topological solver not supported.");
p1.reset(new storm::solver::TopologicalMinMaxLinearEquationSolver<ValueType>(matrix)); p1.reset(new storm::solver::TopologicalMinMaxLinearEquationSolver<ValueType>(matrix));
break; break;
} }

Loading…
Cancel
Save