Storm
A Modern Probabilistic Model Checker
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
MinMaxEquationSolverSettings.cpp
Go to the documentation of this file.
2
6
9
10namespace storm {
11namespace settings {
12namespace modules {
13
14const std::string MinMaxEquationSolverSettings::moduleName = "minmax";
15const std::string solvingMethodOptionName = "method";
16const std::string maximalIterationsOptionName = "maxiter";
17const std::string maximalIterationsOptionShortName = "i";
18const std::string precisionOptionName = "precision";
19const std::string absoluteOptionName = "absolute";
21const std::string forceUniqueSolutionRequirementOptionName = "force-require-unique";
22const std::string lpEqualityForUniqueActionsOptionName = "lp-eq-unique-actions";
23const std::string lpUseNonTrivialBoundsOptionName = "lp-use-nontrivial-bounds";
24const std::string lpOptimizeOnlyInitialStateOptionName = "lp-objective-type";
25
27 std::vector<std::string> minMaxSolvingTechniques = {"vi", "value-iteration",
28 "pi", "policy-iteration",
29 "lp", "linear-programming",
30 "rs", "ratsearch",
31 "ii", "interval-iteration",
32 "svi", "sound-value-iteration",
33 "ovi", "optimistic-value-iteration",
34 "topological", "vi-to-pi",
35 "vi-to-lp", "acyclic"};
36 this->addOption(
37 storm::settings::OptionBuilder(moduleName, solvingMethodOptionName, false, "Sets which min/max linear equation solving technique is preferred.")
38 .setIsAdvanced()
39 .addArgument(storm::settings::ArgumentBuilder::createStringArgument("name", "The name of a min/max linear equation solving technique.")
41 .setDefaultValueString("topological")
42 .build())
43 .build());
44
46 "The maximal number of iterations to perform before iterative solving is aborted.")
48 .setIsAdvanced()
49 .addArgument(storm::settings::ArgumentBuilder::createUnsignedIntegerArgument("count", "The maximal iteration count.").build())
50 .build());
51
52 this->addOption(storm::settings::OptionBuilder(moduleName, precisionOptionName, false, "The precision used for detecting convergence of iterative methods.")
53 .setIsAdvanced()
54 .addArgument(storm::settings::ArgumentBuilder::createDoubleArgument("value", "The precision to achieve.")
57 .build())
58 .build());
59
61 "Sets whether the relative or the absolute error is considered for detecting convergence.")
62 .setIsAdvanced()
63 .build());
64
65 std::vector<std::string> multiplicationStyles = {"gaussseidel", "regular", "gs", "r"};
67 "Sets which method multiplication style to prefer for value iteration.")
68 .setIsAdvanced()
69 .addArgument(storm::settings::ArgumentBuilder::createStringArgument("name", "The name of a multiplication style.")
71 .setDefaultValueString("gaussseidel")
72 .build())
73 .build());
74
76 "Enforces end component collapsing for MinMax equation systems so that their solution becomes unique. May "
77 "simplify solving but causes some overhead.")
78 .setIsAdvanced()
79 .build());
80
82 "If set, enforce equality in the LP encoding for actions with a unique state.")
83 .setIsAdvanced()
84 .build());
85
86 this->addOption(storm::settings::OptionBuilder(moduleName, lpUseNonTrivialBoundsOptionName, false, "If set, use nontrivial bounds in the LP encoding")
87 .setIsAdvanced()
88 .build());
89
90 std::vector<std::string> optimizationObjectiveTypes = {"all", "onlyinitial"};
91 this->addOption(
93 .setIsAdvanced()
94 .addArgument(storm::settings::ArgumentBuilder::createStringArgument("optimization-type", "What kind of optimization objective to prefer.")
97 .build())
98 .build());
99}
100
102 std::string minMaxEquationSolvingTechnique = this->getOption(solvingMethodOptionName).getArgumentByName("name").getValueAsString();
103 if (minMaxEquationSolvingTechnique == "value-iteration" || minMaxEquationSolvingTechnique == "vi") {
104 return storm::solver::MinMaxMethod::ValueIteration;
105 } else if (minMaxEquationSolvingTechnique == "policy-iteration" || minMaxEquationSolvingTechnique == "pi") {
106 return storm::solver::MinMaxMethod::PolicyIteration;
107 } else if (minMaxEquationSolvingTechnique == "linear-programming" || minMaxEquationSolvingTechnique == "lp") {
108 return storm::solver::MinMaxMethod::LinearProgramming;
109 } else if (minMaxEquationSolvingTechnique == "ratsearch" || minMaxEquationSolvingTechnique == "rs") {
110 return storm::solver::MinMaxMethod::RationalSearch;
111 } else if (minMaxEquationSolvingTechnique == "interval-iteration" || minMaxEquationSolvingTechnique == "ii") {
112 return storm::solver::MinMaxMethod::IntervalIteration;
113 } else if (minMaxEquationSolvingTechnique == "sound-value-iteration" || minMaxEquationSolvingTechnique == "svi") {
114 return storm::solver::MinMaxMethod::SoundValueIteration;
115 } else if (minMaxEquationSolvingTechnique == "optimistic-value-iteration" || minMaxEquationSolvingTechnique == "ovi") {
116 return storm::solver::MinMaxMethod::OptimisticValueIteration;
117 } else if (minMaxEquationSolvingTechnique == "topological") {
118 return storm::solver::MinMaxMethod::Topological;
119 } else if (minMaxEquationSolvingTechnique == "vi-to-pi") {
120 return storm::solver::MinMaxMethod::ViToPi;
121 } else if (minMaxEquationSolvingTechnique == "vi-to-lp") {
122 return storm::solver::MinMaxMethod::ViToLp;
123 } else if (minMaxEquationSolvingTechnique == "acyclic") {
124 return storm::solver::MinMaxMethod::Acyclic;
125 }
126
127 STORM_LOG_THROW(false, storm::exceptions::IllegalArgumentValueException,
128 "Unknown min/max equation solving technique '" << minMaxEquationSolvingTechnique << "'.");
129}
130
132 return !this->getOption(solvingMethodOptionName).getArgumentByName("name").getHasBeenSet() ||
133 this->getOption(solvingMethodOptionName).getArgumentByName("name").wasSetFromDefaultValue();
134}
135
137 return this->getOption(solvingMethodOptionName).getHasOptionBeenSet();
138}
139
141 return this->getOption(maximalIterationsOptionName).getHasOptionBeenSet();
142}
143
147
149 return this->getOption(precisionOptionName).getHasOptionBeenSet();
150}
151
153 return this->getOption(precisionOptionName).getArgumentByName("value").getValueAsDouble();
154}
155
157 return this->getOption(absoluteOptionName).getHasOptionBeenSet();
158}
159
164
166 std::string multiplicationStyleString = this->getOption(valueIterationMultiplicationStyleOptionName).getArgumentByName("name").getValueAsString();
167 if (multiplicationStyleString == "gaussseidel" || multiplicationStyleString == "gs") {
169 } else if (multiplicationStyleString == "regular" || multiplicationStyleString == "r") {
171 }
172 STORM_LOG_THROW(false, storm::exceptions::IllegalArgumentValueException, "Unknown multiplication style '" << multiplicationStyleString << "'.");
173}
174
176 return this->getOption(forceUniqueSolutionRequirementOptionName).getHasOptionBeenSet();
177}
178
180 return this->getOption(lpOptimizeOnlyInitialStateOptionName).getArgumentByName("optimization-type").getValueAsString() == "onlyinitial";
181}
182
184 return this->getOption(lpUseNonTrivialBoundsOptionName).getHasOptionBeenSet();
185}
186
188 return this->getOption(lpEqualityForUniqueActionsOptionName).getHasOptionBeenSet();
189}
190
191} // namespace modules
192} // namespace settings
193} // namespace storm
virtual std::string getValueAsString() const =0
Retrieves the value of this argument as a string.
virtual uint_fast64_t getValueAsUnsignedInteger() const =0
Retrieves the value of this argument as an unsigned integer.
virtual bool getHasBeenSet() const
Retrieves whether the argument has been set.
virtual double getValueAsDouble() const =0
Retrieves the value of this argument as a double.
virtual bool wasSetFromDefaultValue() const =0
static ArgumentBuilder createUnsignedIntegerArgument(std::string const &name, std::string const &description)
Creates an unsigned integer argument with the given parameters.
static ArgumentBuilder createDoubleArgument(std::string const &name, std::string const &description)
Creates a double argument with the given parameters.
static ArgumentBuilder createStringArgument(std::string const &name, std::string const &description)
Creates a string argument with the given parameters.
static std::shared_ptr< ArgumentValidator< double > > createDoubleRangeValidatorExcluding(double lowerBound, double upperBound)
static std::shared_ptr< ArgumentValidator< std::string > > createMultipleChoiceValidator(std::vector< std::string > const &choices)
This class provides the interface to create an option...
ArgumentBase const & getArgumentByName(std::string const &argumentName) const
Returns a reference to the argument with the specified long name.
Definition Option.cpp:79
bool getHasOptionBeenSet() const
Retrieves whether the option has been set.
Definition Option.cpp:125
bool getLpUseOnlyInitialStateAsObjective() const
Retrieves whether only initial states should occur in the optimization objective.
bool getLpUseNonTrivialBounds() const
Retrieves whether additional bounds should be used when constructing the LP.
bool isMinMaxEquationSolvingMethodSetFromDefaultValue() const
Retrieves whether the min/max equation solving method is set from its default value.
bool isConvergenceCriterionSet() const
Retrieves whether the convergence criterion has been set.
uint_fast64_t getMaximalIterationCount() const
Retrieves the maximal number of iterations to perform until giving up on converging.
bool isMaximalIterationCountSet() const
Retrieves whether the maximal iteration count has been set.
bool isMinMaxEquationSolvingMethodSet() const
Retrieves whether a min/max equation solving technique has been set.
double getPrecision() const
Retrieves the precision that is used for detecting convergence.
ConvergenceCriterion getConvergenceCriterion() const
Retrieves the selected convergence criterion.
bool getLpUseEqualityForTrivialActions() const
Retrieves whether equality should be enforced where possible.
bool isPrecisionSet() const
Retrieves whether the precision has been set.
storm::solver::MultiplicationStyle getValueIterationMultiplicationStyle() const
Retrieves the multiplication style to use in the min-max methods.
storm::solver::MinMaxMethod getMinMaxEquationSolvingMethod() const
Retrieves the selected min/max equation solving method.
This is the base class of the settings for a particular module.
void addOption(std::shared_ptr< Option > const &option)
Adds and registers the given option.
Option & getOption(std::string const &longName)
Retrieves the option with the given long name.
#define STORM_LOG_THROW(cond, exception, message)
Definition macros.h:30
const std::string forceUniqueSolutionRequirementOptionName
const std::string lpOptimizeOnlyInitialStateOptionName
const std::string valueIterationMultiplicationStyleOptionName
const std::string lpEqualityForUniqueActionsOptionName
SettingsType const & getModule()
Get module.
LabParser.cpp.
Definition cli.cpp:18