Browse Source

Made sampling for MDPs correct again

Former-commit-id: 7917200f4e
tempestpy_adaptions
TimQu 9 years ago
parent
commit
a723cfca14
  1. 4
      src/modelchecker/region/SamplingModel.cpp

4
src/modelchecker/region/SamplingModel.cpp

@ -252,6 +252,10 @@ namespace storm {
template<> template<>
void SamplingModel<storm::models::sparse::Mdp<storm::RationalFunction>, double>::invokeSolver(){ void SamplingModel<storm::models::sparse::Mdp<storm::RationalFunction>, double>::invokeSolver(){
std::unique_ptr<storm::solver::MinMaxLinearEquationSolver<double>> solver = storm::solver::configureMinMaxLinearEquationSolver(this->solveGoal, storm::utility::solver::MinMaxLinearEquationSolverFactory<double>(), this->matrixData.matrix); std::unique_ptr<storm::solver::MinMaxLinearEquationSolver<double>> solver = storm::solver::configureMinMaxLinearEquationSolver(this->solveGoal, storm::utility::solver::MinMaxLinearEquationSolverFactory<double>(), this->matrixData.matrix);
if(!this->solveGoal.minimize()){
//The value iteration method is not correct if the value is maximized and the initial x-vector is not <= the actual probability/reward.
this->eqSysResult.assign(this->eqSysResult.size(), storm::utility::zero<double>());
}
solver->solveEquationSystem(this->eqSysResult, this->vectorData.vector); solver->solveEquationSystem(this->eqSysResult, this->vectorData.vector);
} }

Loading…
Cancel
Save