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 void logIterations(
bool converged,
bool terminate, uint64_t iterations)
const;
62 virtual uint64_t getMatrixRowCount()
const override;
63 virtual uint64_t getMatrixColumnCount()
const override;
65 NativeLinearEquationSolverMethod getMethod(
Environment const& env,
bool isExactMode)
const;
67 virtual bool solveEquationsSOR(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b, ValueType
const& omega)
const;
68 virtual bool solveEquationsJacobi(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
69 virtual bool solveEquationsWalkerChae(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
70 virtual bool solveEquationsPower(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
71 virtual bool solveEquationsSoundValueIteration(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
72 virtual bool solveEquationsOptimisticValueIteration(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
73 virtual bool solveEquationsIntervalIteration(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
74 virtual bool solveEquationsRationalSearch(
storm::Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const& b)
const;
76 void setUpViOperator()
const;
80 std::unique_ptr<storm::storage::SparseMatrix<ValueType>> localA;
86 mutable std::shared_ptr<storm::solver::helper::ValueIterationOperator<ValueType, true>> viOperator;
89 mutable std::unique_ptr<Multiplier<ValueType>> multiplier;
91 struct JacobiDecomposition {
95 std::vector<ValueType> DVector;
96 std::unique_ptr<storm::solver::Multiplier<ValueType>> multiplier;
98 mutable std::unique_ptr<JacobiDecomposition> jacobiDecomposition;
100 struct WalkerChaeData {
104 void computeNewB(std::vector<ValueType>
const& originalB);
105 void precomputeAuxiliaryData();
108 std::vector<ValueType> b;
110 std::unique_ptr<storm::solver::Multiplier<ValueType>> multiplier;
113 std::vector<ValueType> columnSums;
114 std::vector<ValueType> newX;
116 mutable std::unique_ptr<WalkerChaeData> walkerChaeData;