43 struct PowerIterationResult {
44 PowerIterationResult(uint64_t iterations,
SolverStatus status) : iterations(iterations), status(status) {
52 template<
typename ValueTypePrime>
55 PowerIterationResult performPowerIteration(
Environment const& env, std::vector<ValueType>*& currentX, std::vector<ValueType>*& newX,
56 std::vector<ValueType>
const& b, ValueType
const& precision,
bool relative,
SolverGuarantee const& guarantee,
57 uint64_t currentIterations, uint64_t maxIterations,
60 virtual uint64_t getMatrixRowCount()
const override;
61 virtual uint64_t getMatrixColumnCount()
const override;
63 NativeLinearEquationSolverMethod getMethod(
Environment const& env,
bool isExactMode)
const;
65 virtual bool solveEquationsSOR(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b, ValueType
const& omega)
const;
66 virtual bool solveEquationsJacobi(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
67 virtual bool solveEquationsWalkerChae(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
68 virtual bool solveEquationsPower(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
69 virtual bool solveEquationsSoundValueIteration(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
70 virtual bool solveEquationsOptimisticValueIteration(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
71 virtual bool solveEquationsGuessingValueIteration(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
72 virtual bool solveEquationsIntervalIteration(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
73 virtual bool solveEquationsRationalSearch(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
75 void setUpViOperator()
const;
79 std::unique_ptr<storm::storage::SparseMatrix<ValueType>> localA;
85 mutable std::shared_ptr<storm::solver::helper::ValueIterationOperator<ValueType, true>> viOperator;
88 mutable std::unique_ptr<Multiplier<ValueType>> multiplier;
90 struct JacobiDecomposition {
94 std::vector<ValueType> DVector;
95 std::unique_ptr<storm::solver::Multiplier<ValueType>> multiplier;
97 mutable std::unique_ptr<JacobiDecomposition> jacobiDecomposition;
99 struct WalkerChaeData {
103 void computeNewB(std::vector<ValueType>
const& originalB);
104 void precomputeAuxiliaryData();
107 std::vector<ValueType> b;
109 std::unique_ptr<storm::solver::Multiplier<ValueType>> multiplier;
112 std::vector<ValueType> columnSums;
113 std::vector<ValueType> newX;
115 mutable std::unique_ptr<WalkerChaeData> walkerChaeData;