65template<storm::OptimizationDirection Dir,
bool Relative, storm::OptimizationDirection RobustDir>
67 uint64_t& numIterations, SolutionType
const& precision,
71 std::vector<SolutionType>* operand1{&operand};
72 std::vector<SolutionType>* operand2{&operand};
74 operand2 = &viOperator->allocateAuxiliaryVector(operand.size());
76 bool resultInAuxVector{
false};
80 bool applyResult = viOperator->template applyRobust<RobustDir>(*operand1, *operand2, offsets, backend);
83 }
else if (iterationCallback) {
84 status = iterationCallback(status);
87 std::swap(operand1, operand2);
88 resultInAuxVector = !resultInAuxVector;
92 if (resultInAuxVector) {
94 std::swap(*operand1, *operand2);
96 viOperator->freeAuxiliaryVector();
104 uint64_t& numIterations, SolutionType
const& precision,
108 return VI<Dir, Relative, invert(Dir)>(operand, offsets, numIterations, precision, iterationCallback, mult);
110 return VI<Dir, Relative, Dir>(operand, offsets, numIterations, precision, iterationCallback, mult);
116 uint64_t& numIterations,
bool relative, SolutionType
const& precision,
117 std::optional<storm::OptimizationDirection>
const& dir,
120 STORM_LOG_ASSERT(TrivialRowGrouping || dir.has_value(),
"no optimization direction given!");
121 if (!dir.has_value() ||
maximize(*dir)) {
123 return VI<storm::OptimizationDirection::Maximize, true>(operand, offsets, numIterations, precision, iterationCallback, mult, robust);
125 return VI<storm::OptimizationDirection::Maximize, false>(operand, offsets, numIterations, precision, iterationCallback, mult, robust);
129 return VI<storm::OptimizationDirection::Minimize, true>(operand, offsets, numIterations, precision, iterationCallback, mult, robust);
131 return VI<storm::OptimizationDirection::Minimize, false>(operand, offsets, numIterations, precision, iterationCallback, mult, robust);
138 bool relative, SolutionType
const& precision,
139 std::optional<storm::OptimizationDirection>
const& dir,
142 uint64_t numIterations = 0;
143 return VI(operand, offsets, numIterations, relative, precision, dir, iterationCallback, mult, robust);
SolverStatus VI(std::vector< SolutionType > &operand, std::vector< ValueType > const &offsets, uint64_t &numIterations, SolutionType const &precision, std::function< SolverStatus(SolverStatus const &)> const &iterationCallback={}, MultiplicationStyle mult=MultiplicationStyle::GaussSeidel) const