Browse Source

Some sanity checks regarding linear equation solver requirements

tempestpy_adaptions
TimQu 7 years ago
parent
commit
3898931540
  1. 5
      src/storm/modelchecker/csl/helper/SparseCtmcCslHelper.cpp
  2. 12
      src/storm/modelchecker/prctl/helper/HybridDtmcPrctlHelper.cpp
  3. 11
      src/storm/modelchecker/prctl/helper/SparseDtmcPrctlHelper.cpp

5
src/storm/modelchecker/csl/helper/SparseCtmcCslHelper.cpp

@ -23,6 +23,7 @@
#include "storm/exceptions/InvalidStateException.h" #include "storm/exceptions/InvalidStateException.h"
#include "storm/exceptions/InvalidPropertyException.h" #include "storm/exceptions/InvalidPropertyException.h"
#include "storm/exceptions/FormatUnsupportedBySolverException.h" #include "storm/exceptions/FormatUnsupportedBySolverException.h"
#include "storm/exceptions/UncheckedRequirementException.h"
namespace storm { namespace storm {
namespace modelchecker { namespace modelchecker {
@ -490,6 +491,8 @@ namespace storm {
bsccEquationSystem = builder.build(); bsccEquationSystem = builder.build();
{ {
// Check solver requirements
STORM_LOG_THROW(linearEquationSolverFactory.getRequirements(env).empty(), storm::exceptions::UncheckedRequirementException, "At least one requirement of the linear equation solver could not be matched.");
// Check whether we have the right input format for the solver. // Check whether we have the right input format for the solver.
STORM_LOG_THROW(linearEquationSolverFactory.getEquationProblemFormat(env) == storm::solver::LinearEquationSolverProblemFormat::EquationSystem, storm::exceptions::FormatUnsupportedBySolverException, "The selected solver does not support the required format."); STORM_LOG_THROW(linearEquationSolverFactory.getEquationProblemFormat(env) == storm::solver::LinearEquationSolverProblemFormat::EquationSystem, storm::exceptions::FormatUnsupportedBySolverException, "The selected solver does not support the required format.");
std::unique_ptr<storm::solver::LinearEquationSolver<ValueType>> solver = linearEquationSolverFactory.create(env, std::move(bsccEquationSystem)); std::unique_ptr<storm::solver::LinearEquationSolver<ValueType>> solver = linearEquationSolverFactory.create(env, std::move(bsccEquationSystem));
@ -560,6 +563,8 @@ namespace storm {
rewardSolution = std::vector<ValueType>(rewardEquationSystemMatrix.getColumnCount(), one); rewardSolution = std::vector<ValueType>(rewardEquationSystemMatrix.getColumnCount(), one);
{ {
// Check solver requirements
STORM_LOG_THROW(linearEquationSolverFactory.getRequirements(env).empty(), storm::exceptions::UncheckedRequirementException, "At least one requirement of the linear equation solver could not be matched.");
// Check whether we have the right input format for the solver. // Check whether we have the right input format for the solver.
STORM_LOG_THROW(linearEquationSolverFactory.getEquationProblemFormat(env) == storm::solver::LinearEquationSolverProblemFormat::EquationSystem, storm::exceptions::FormatUnsupportedBySolverException, "The selected solver does not support the required format."); STORM_LOG_THROW(linearEquationSolverFactory.getEquationProblemFormat(env) == storm::solver::LinearEquationSolverProblemFormat::EquationSystem, storm::exceptions::FormatUnsupportedBySolverException, "The selected solver does not support the required format.");
std::unique_ptr<storm::solver::LinearEquationSolver<ValueType>> solver = linearEquationSolverFactory.create(env, std::move(rewardEquationSystemMatrix)); std::unique_ptr<storm::solver::LinearEquationSolver<ValueType>> solver = linearEquationSolverFactory.create(env, std::move(rewardEquationSystemMatrix));

12
src/storm/modelchecker/prctl/helper/HybridDtmcPrctlHelper.cpp

@ -62,6 +62,11 @@ namespace storm {
storm::dd::Add<DdType, ValueType> subvector = submatrix * prob1StatesAsColumn; storm::dd::Add<DdType, ValueType> subvector = submatrix * prob1StatesAsColumn;
subvector = subvector.sumAbstract(model.getColumnVariables()); subvector = subvector.sumAbstract(model.getColumnVariables());
auto req = linearEquationSolverFactory.getRequirements(env);
req.clearLowerBounds();
req.clearUpperBounds();
STORM_LOG_THROW(req.empty(), storm::exceptions::UncheckedRequirementException, "At least one requirement of the linear equation solver could not be matched.");
// Check whether we need to create an equation system. // Check whether we need to create an equation system.
bool convertToEquationSystem = linearEquationSolverFactory.getEquationProblemFormat(env) == storm::solver::LinearEquationSolverProblemFormat::EquationSystem; bool convertToEquationSystem = linearEquationSolverFactory.getEquationProblemFormat(env) == storm::solver::LinearEquationSolverProblemFormat::EquationSystem;
@ -246,9 +251,10 @@ namespace storm {
storm::dd::Add<DdType, ValueType> subvector = rewardModel.getTotalRewardVector(maybeStatesAdd, submatrix, model.getColumnVariables()); storm::dd::Add<DdType, ValueType> subvector = rewardModel.getTotalRewardVector(maybeStatesAdd, submatrix, model.getColumnVariables());
// Check the requirements of a linear equation solver // Check the requirements of a linear equation solver
// We might need to compute upper reward bounds for which the oneStepTargetProbabilities are needed.
boost::optional<storm::dd::Add<DdType, ValueType>> oneStepTargetProbs;
auto req = linearEquationSolverFactory.getRequirements(env); auto req = linearEquationSolverFactory.getRequirements(env);
req.clearLowerBounds(); req.clearLowerBounds();
boost::optional<storm::dd::Add<DdType, ValueType>> oneStepTargetProbs;
if (req.requiresUpperBounds()) { if (req.requiresUpperBounds()) {
storm::dd::Add<DdType, ValueType> targetStatesAsColumn = targetStates.template toAdd<ValueType>(); storm::dd::Add<DdType, ValueType> targetStatesAsColumn = targetStates.template toAdd<ValueType>();
targetStatesAsColumn = targetStatesAsColumn.swapVariables(model.getRowColumnMetaVariablePairs()); targetStatesAsColumn = targetStatesAsColumn.swapVariables(model.getRowColumnMetaVariablePairs());
@ -275,9 +281,11 @@ namespace storm {
storm::storage::SparseMatrix<ValueType> explicitSubmatrix = submatrix.toMatrix(odd, odd); storm::storage::SparseMatrix<ValueType> explicitSubmatrix = submatrix.toMatrix(odd, odd);
std::vector<ValueType> b = subvector.toVector(odd); std::vector<ValueType> b = subvector.toVector(odd);
// Create the upper bounds vector if one was requested
// Create the upper bounds vector if one was requested.
boost::optional<std::vector<ValueType>> upperBounds; boost::optional<std::vector<ValueType>> upperBounds;
if (oneStepTargetProbs) { if (oneStepTargetProbs) {
// FIXME: This will fail if we already converted the matrix to the equation problem format.
STORM_LOG_ASSERT(!convertToEquationSystem, "Upper reward bounds required, but the matrix is in the wrong format for the computation.");
upperBounds = computeUpperRewardBounds(explicitSubmatrix, b, oneStepTargetProbs->toVector(odd)); upperBounds = computeUpperRewardBounds(explicitSubmatrix, b, oneStepTargetProbs->toVector(odd));
} }

11
src/storm/modelchecker/prctl/helper/SparseDtmcPrctlHelper.cpp

@ -273,11 +273,6 @@ namespace storm {
// In this case we have to compute the reward values for the remaining states. // In this case we have to compute the reward values for the remaining states.
// We can eliminate the rows and columns from the original transition probability matrix. // We can eliminate the rows and columns from the original transition probability matrix.
storm::storage::SparseMatrix<ValueType> submatrix = transitionMatrix.getSubmatrix(true, maybeStates, maybeStates, convertToEquationSystem); storm::storage::SparseMatrix<ValueType> submatrix = transitionMatrix.getSubmatrix(true, maybeStates, maybeStates, convertToEquationSystem);
if (convertToEquationSystem) {
// Converting the matrix from the fixpoint notation to the form needed for the equation
// system. That is, we go from x = A*x + b to (I-A)x = b.
submatrix.convertToEquationSystem();
}
// Initialize the x vector with the hint (if available) or with 1 for each element. // Initialize the x vector with the hint (if available) or with 1 for each element.
// This is the initial guess for the iterative solvers. // This is the initial guess for the iterative solvers.
@ -300,6 +295,12 @@ namespace storm {
} }
STORM_LOG_THROW(requirements.empty(), storm::exceptions::UncheckedRequirementException, "There are unchecked requirements of the solver."); STORM_LOG_THROW(requirements.empty(), storm::exceptions::UncheckedRequirementException, "There are unchecked requirements of the solver.");
// If necessary, convert the matrix from the fixpoint notation to the form needed for the equation system.
if (convertToEquationSystem) {
// go from x = A*x + b to (I-A)x = b.
submatrix.convertToEquationSystem();
}
// Create the solver. // Create the solver.
goal.restrictRelevantValues(maybeStates); goal.restrictRelevantValues(maybeStates);
std::unique_ptr<storm::solver::LinearEquationSolver<ValueType>> solver = storm::solver::configureLinearEquationSolver(env, std::move(goal), linearEquationSolverFactory, std::move(submatrix)); std::unique_ptr<storm::solver::LinearEquationSolver<ValueType>> solver = storm::solver::configureLinearEquationSolver(env, std::move(goal), linearEquationSolverFactory, std::move(submatrix));

Loading…
Cancel
Save