1#include "storm-config.h"
13class DoubleViEnvironment {
16 static const bool isExact =
false;
25class DoubleViRegMultEnvironment {
28 static const bool isExact =
false;
38class DoubleSoundViEnvironment {
41 static const bool isExact =
false;
51class DoubleIntervalIterationEnvironment {
54 static const bool isExact =
false;
64class DoubleGuessingViEnvironment {
67 static const bool isExact =
false;
77class DoubleOptimisticViEnvironment {
80 static const bool isExact =
false;
90class DoubleTopologicalViEnvironment {
93 static const bool isExact =
false;
103class DoublePIEnvironment {
106 static const bool isExact =
false;
117class RationalPIEnvironment {
120 static const bool isExact =
true;
127class RationalRationalSearchEnvironment {
130 static const bool isExact =
true;
138template<
typename TestType>
139class MinMaxLinearEquationSolverTest :
public ::testing::Test {
141 typedef typename TestType::ValueType
ValueType;
142 MinMaxLinearEquationSolverTest() : _environment(TestType::createEnvironment()) {}
150 return storm::utility::convertNumber<ValueType>(input);
157typedef ::testing::Types<DoubleViEnvironment, DoubleViRegMultEnvironment, DoubleSoundViEnvironment, DoubleIntervalIterationEnvironment,
158 DoubleOptimisticViEnvironment, DoubleGuessingViEnvironment, DoubleTopologicalViEnvironment, DoublePIEnvironment, RationalPIEnvironment,
159 RationalRationalSearchEnvironment>
164TYPED_TEST(MinMaxLinearEquationSolverTest, SolveEquations) {
165 typedef typename TestFixture::ValueType
ValueType;
168 ASSERT_NO_THROW(builder.newRowGroup(0));
169 ASSERT_NO_THROW(builder.addNextValue(0, 0, this->parseNumber(
"0.9")));
172 ASSERT_NO_THROW(A = builder.build(2));
174 std::vector<ValueType> x(1);
178 auto solver = factory.create(this->env(), A);
179 solver->setHasUniqueSolution(
true);
180 solver->setHasNoEndComponents(
true);
185 ASSERT_NO_THROW(solver->solveEquations(this->env(), storm::OptimizationDirection::Minimize, x, b));
186 EXPECT_NEAR(x[0], this->
parseNumber(
"0.5"), this->precision());
188 ASSERT_NO_THROW(solver->solveEquations(this->env(), storm::OptimizationDirection::Maximize, x, b));
189 EXPECT_NEAR(x[0], this->
parseNumber(
"0.99"), this->precision());
SolverEnvironment & solver()
void setMultiplicationStyle(storm::solver::MultiplicationStyle value)
storm::RationalNumber const & getPrecision() const
void setPrecision(storm::RationalNumber value)
void setMethod(storm::solver::MinMaxMethod value, bool isSetFromDefault=false)
void setMethod(storm::solver::NativeLinearEquationSolverMethod value)
TopologicalSolverEnvironment & topological()
void setLinearEquationSolverType(storm::solver::EquationSolverType const &value, bool isSetFromDefault=false)
MinMaxSolverEnvironment & minMax()
void setForceSoundness(bool value)
void setLinearEquationSolverPrecision(boost::optional< storm::RationalNumber > const &newPrecision, boost::optional< bool > const &relativePrecision=boost::none)
NativeSolverEnvironment & native()
void setUnderlyingMinMaxMethod(storm::solver::MinMaxMethod value)
bool hasEnabledRequirement() const
A class that can be used to build a sparse matrix by adding value by value.
A class that holds a possibly non-square matrix in the compressed row storage format.
SFTBDDChecker::ValueType ValueType
NumberType parseNumber(std::string const &value)
Parse number from string.
TYPED_TEST(GraphTestAR, SymbolicProb01StochasticGameDieSmall)
TYPED_TEST_SUITE(GraphTestAR, TestingTypes,)
::testing::Types< Cudd, Sylvan > TestingTypes