11template<
typename ValueType>
17template<
typename ValueType,
bool TrivialRowGrouping>
23 virtual void multiply(
Environment const& env, std::vector<ValueType>
const& x, std::vector<ValueType>
const* b,
24 std::vector<ValueType>& result)
const override;
25 virtual void multiplyGaussSeidel(
Environment const& env, std::vector<ValueType>& x, std::vector<ValueType>
const* b,
bool backwards =
true)
const override;
27 std::vector<ValueType>
const& x, std::vector<ValueType>
const* b, std::vector<ValueType>& result,
28 std::vector<uint_fast64_t>* choices =
nullptr)
const override;
30 std::vector<ValueType>& x, std::vector<ValueType>
const* b, std::vector<uint_fast64_t>* choices =
nullptr,
31 bool backwards =
true)
const override;
37 ViOpT& initialize()
const;
38 ViOpT& initialize(
bool backwards)
const;
42 mutable std::unique_ptr<ViOpT> viOperatorFwd, viOperatorBwd;
storm::storage::SparseMatrix< ValueType > const & matrix
virtual void multiplyAndReduceGaussSeidel(Environment const &env, OptimizationDirection const &dir, std::vector< uint64_t > const &rowGroupIndices, std::vector< ValueType > &x, std::vector< ValueType > const *b, std::vector< uint_fast64_t > *choices=nullptr, bool backwards=true) const override
virtual void multiplyGaussSeidel(Environment const &env, std::vector< ValueType > &x, std::vector< ValueType > const *b, bool backwards=true) const override
Performs a matrix-vector multiplication in gauss-seidel style.
virtual void multiplyAndReduce(Environment const &env, OptimizationDirection const &dir, std::vector< uint64_t > const &rowGroupIndices, std::vector< ValueType > const &x, std::vector< ValueType > const *b, std::vector< ValueType > &result, std::vector< uint_fast64_t > *choices=nullptr) const override
virtual ~ViOperatorMultiplier()=default
virtual void clearCache() const override
virtual void multiply(Environment const &env, std::vector< ValueType > const &x, std::vector< ValueType > const *b, std::vector< ValueType > &result) const override
Performs a matrix-vector multiplication x' = A*x + b.
This class represents the Value Iteration Operator (also known as Bellman operator).
A class that holds a possibly non-square matrix in the compressed row storage format.