Storm 1.11.1.1
A Modern Probabilistic Model Checker
Loading...
Searching...
No Matches
SymbolicLinearEquationSolver.h
Go to the documentation of this file.
1#pragma once
2
3#include <set>
4#include <vector>
5
12
13namespace storm {
14
15class Environment;
16
17namespace dd {
18template<storm::dd::DdType Type, typename ValueType>
19class Add;
20
21template<storm::dd::DdType Type>
22class Bdd;
23} // namespace dd
24
25namespace solver {
26
31template<storm::dd::DdType DdType, typename ValueType = double>
32class SymbolicLinearEquationSolver : public SymbolicEquationSolver<DdType, ValueType> {
33 public:
35 virtual ~SymbolicLinearEquationSolver() = default;
36
49 std::set<storm::expressions::Variable> const& rowMetaVariables,
50 std::set<storm::expressions::Variable> const& columnMetaVariables,
51 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> const& rowColumnMetaVariablePairs);
52
64 SymbolicLinearEquationSolver(storm::dd::Bdd<DdType> const& allRows, std::set<storm::expressions::Variable> const& rowMetaVariables,
65 std::set<storm::expressions::Variable> const& columnMetaVariables,
66 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> const& rowColumnMetaVariablePairs);
67
78 storm::dd::Add<DdType, ValueType> const& b) const = 0;
79
92 uint_fast64_t n = 1) const;
93
99
105
107 virtual void setData(storm::dd::Bdd<DdType> const& allRows, std::set<storm::expressions::Variable> const& rowMetaVariables,
108 std::set<storm::expressions::Variable> const& columnMetaVariables,
109 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> const& rowColumnMetaVariablePairs);
110
111 protected:
112 // The matrix defining the coefficients of the linear equation system.
114
115 // The row variables.
116 std::set<storm::expressions::Variable> rowMetaVariables;
117
118 // The column variables.
119 std::set<storm::expressions::Variable> columnMetaVariables;
120
121 // The pairs of meta variables used for renaming.
122 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> rowColumnMetaVariablePairs;
123};
124
125template<storm::dd::DdType DdType, typename ValueType>
127 public:
129
130 std::unique_ptr<storm::solver::SymbolicLinearEquationSolver<DdType, ValueType>> create(
131 Environment const& env, storm::dd::Bdd<DdType> const& allRows, std::set<storm::expressions::Variable> const& rowMetaVariables,
132 std::set<storm::expressions::Variable> const& columnMetaVariables,
133 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> const& rowColumnMetaVariablePairs) const;
134
135 std::unique_ptr<storm::solver::SymbolicLinearEquationSolver<DdType, ValueType>> create(
136 Environment const& env, storm::dd::Add<DdType, ValueType> const& A, storm::dd::Bdd<DdType> const& allRows,
137 std::set<storm::expressions::Variable> const& rowMetaVariables, std::set<storm::expressions::Variable> const& columnMetaVariables,
138 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> const& rowColumnMetaVariablePairs) const;
139
142
143 virtual std::unique_ptr<storm::solver::SymbolicLinearEquationSolver<DdType, ValueType>> create(Environment const& env) const = 0;
144};
145
146template<storm::dd::DdType DdType, typename ValueType>
148 public:
149 using SymbolicLinearEquationSolverFactory<DdType, ValueType>::create;
150
151 virtual std::unique_ptr<storm::solver::SymbolicLinearEquationSolver<DdType, ValueType>> create(Environment const& env) const override;
152};
153
154} // namespace solver
155} // namespace storm
virtual std::unique_ptr< storm::solver::SymbolicLinearEquationSolver< DdType, ValueType > > create(Environment const &env) const override
std::unique_ptr< storm::solver::SymbolicLinearEquationSolver< DdType, ValueType > > create(Environment const &env, storm::dd::Bdd< DdType > const &allRows, std::set< storm::expressions::Variable > const &rowMetaVariables, std::set< storm::expressions::Variable > const &columnMetaVariables, std::vector< std::pair< storm::expressions::Variable, storm::expressions::Variable > > const &rowColumnMetaVariablePairs) const
virtual std::unique_ptr< storm::solver::SymbolicLinearEquationSolver< DdType, ValueType > > create(Environment const &env) const =0
LinearEquationSolverRequirements getRequirements(Environment const &env) const
LinearEquationSolverProblemFormat getEquationProblemFormat(Environment const &env) const
An interface that represents an abstract symbolic linear equation solver.
virtual void setData(storm::dd::Bdd< DdType > const &allRows, std::set< storm::expressions::Variable > const &rowMetaVariables, std::set< storm::expressions::Variable > const &columnMetaVariables, std::vector< std::pair< storm::expressions::Variable, storm::expressions::Variable > > const &rowColumnMetaVariablePairs)
std::set< storm::expressions::Variable > columnMetaVariables
std::set< storm::expressions::Variable > rowMetaVariables
virtual storm::dd::Add< DdType, ValueType > multiply(storm::dd::Add< DdType, ValueType > const &x, storm::dd::Add< DdType, ValueType > const *b=nullptr, uint_fast64_t n=1) const
Performs repeated matrix-vector multiplication, using x[0] = x and x[i + 1] = A*x[i] + b.
std::vector< std::pair< storm::expressions::Variable, storm::expressions::Variable > > rowColumnMetaVariablePairs
virtual storm::dd::Add< DdType, ValueType > solveEquations(Environment const &env, storm::dd::Add< DdType, ValueType > const &x, storm::dd::Add< DdType, ValueType > const &b) const =0
Solves the equation system A*x = b.
virtual LinearEquationSolverProblemFormat getEquationProblemFormat(Environment const &env) const
Retrieves the format in which this solver expects to solve equations.
void setMatrix(storm::dd::Add< DdType, ValueType > const &newA)
virtual LinearEquationSolverRequirements getRequirements(Environment const &env) const
Retrieves the requirements of the solver under the current settings.