1#include "storm-config.h"
13class DoubleSVIEnvironment {
25class RationalPiEnvironment {
35template<
typename TestType>
36class SparseDtmcParameterLiftingMonotonicityTest :
public ::testing::Test {
38 typedef typename TestType::ValueType
ValueType;
39 SparseDtmcParameterLiftingMonotonicityTest() : _environment(TestType::createEnvironment()) {}
45 bool useMonotonicity) {
50 virtual void SetUp() {
52 GTEST_SKIP() <<
"Z3 not available.";
54 carl::VariablePool::getInstance().clear();
56 virtual void TearDown() {
57 carl::VariablePool::getInstance().clear();
64typedef ::testing::Types<DoubleSVIEnvironment, RationalPiEnvironment>
TestingTypes;
68TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Brp_Prob_Mon_LEQ) {
69 typedef typename TestFixture::ValueType
ValueType;
71 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/brp16_2.pm";
72 std::string formulaAsString =
"P<=0.84 [F s=5 ]";
73 std::string constantsAsString =
"";
78 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
80 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
85 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
87 formulas[0] = simplifier.getSimplifiedFormula();
91 if (storm::settings::getModule<storm::settings::modules::BisimulationSettings>().isWeakBisimulationSet()) {
94 model = storm::api::performBisimulationMinimization<storm::RationalFunction>(model, formulas, bisimType)
100 modelParameters.insert(rewParameters.begin(), rewParameters.end());
105 auto order = monRes.begin()->first;
106 ASSERT_EQ(order->getNumberOfAddedStates(), model->getTransitionMatrix().getColumnCount());
107 ASSERT_TRUE(order->getDoneBuilding());
109 std::make_shared<storm::analysis::LocalMonotonicityResult<storm::RationalFunctionVariable>>(monRes.begin()->second.first, order->getNumberOfStates());
116 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.7<=pL<=0.9,0.75<=pK<=0.95", modelParameters);
120 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.4<=pL<=0.65,0.75<=pK<=0.95", modelParameters);
124 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=pL<=0.73,0.2<=pK<=0.715", modelParameters);
129TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Brp_Prob_Mon_GEQ) {
130 typedef typename TestFixture::ValueType
ValueType;
132 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/brp16_2.pm";
133 std::string formulaAsString =
"P>=0.84 [F s=5 ]";
134 std::string constantsAsString =
"";
139 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
141 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
146 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
148 formulas[0] = simplifier.getSimplifiedFormula();
152 if (storm::settings::getModule<storm::settings::modules::BisimulationSettings>().isWeakBisimulationSet()) {
155 model = storm::api::performBisimulationMinimization<storm::RationalFunction>(model, formulas, bisimType)
161 modelParameters.insert(rewParameters.begin(), rewParameters.end());
166 auto order = monRes.begin()->first;
167 ASSERT_EQ(order->getNumberOfAddedStates(), model->getTransitionMatrix().getColumnCount());
168 ASSERT_TRUE(order->getDoneBuilding());
170 std::make_shared<storm::analysis::LocalMonotonicityResult<storm::RationalFunctionVariable>>(monRes.begin()->second.first, order->getNumberOfStates());
177 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=pL<=0.73,0.2<=pK<=0.715", modelParameters);
181 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.4<=pL<=0.65,0.75<=pK<=0.95", modelParameters);
185 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.7<=pL<=0.9,0.75<=pK<=0.95", modelParameters);
190TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Brp_Prob_Mon_LEQ_Incr) {
191 typedef typename TestFixture::ValueType
ValueType;
193 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/brp16_2_mon_incr.pm";
194 std::string formulaAsString =
"P<=0.84 [F s=5 ]";
195 std::string constantsAsString =
"";
200 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
202 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
207 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
209 formulas[0] = simplifier.getSimplifiedFormula();
213 if (storm::settings::getModule<storm::settings::modules::BisimulationSettings>().isWeakBisimulationSet()) {
216 model = storm::api::performBisimulationMinimization<storm::RationalFunction>(model, formulas, bisimType)
222 modelParameters.insert(rewParameters.begin(), rewParameters.end());
227 auto order = monRes.begin()->first;
228 ASSERT_EQ(order->getNumberOfAddedStates(), model->getTransitionMatrix().getColumnCount());
229 ASSERT_TRUE(order->getDoneBuilding());
231 std::make_shared<storm::analysis::LocalMonotonicityResult<storm::RationalFunctionVariable>>(monRes.begin()->second.first, order->getNumberOfStates());
238 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.7<=pL<=0.9,0.75<=pK<=0.95", modelParameters);
242 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.4<=pL<=0.65,0.75<=pK<=0.95", modelParameters);
246 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=pL<=0.73,0.2<=pK<=0.715", modelParameters);
251TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Brp_Prob_Mon_GEQ_Incr) {
252 typedef typename TestFixture::ValueType
ValueType;
254 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/brp16_2_mon_incr.pm";
255 std::string formulaAsString =
"P>=0.84 [F s=5 ]";
256 std::string constantsAsString =
"";
261 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
263 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
268 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
270 formulas[0] = simplifier.getSimplifiedFormula();
274 if (storm::settings::getModule<storm::settings::modules::BisimulationSettings>().isWeakBisimulationSet()) {
277 model = storm::api::performBisimulationMinimization<storm::RationalFunction>(model, formulas, bisimType)
283 modelParameters.insert(rewParameters.begin(), rewParameters.end());
288 auto order = monRes.begin()->first;
289 ASSERT_EQ(order->getNumberOfAddedStates(), model->getTransitionMatrix().getColumnCount());
290 ASSERT_TRUE(order->getDoneBuilding());
292 std::make_shared<storm::analysis::LocalMonotonicityResult<storm::RationalFunctionVariable>>(monRes.begin()->second.first, order->getNumberOfStates());
299 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=pL<=0.73,0.2<=pK<=0.715", modelParameters);
303 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.4<=pL<=0.65,0.75<=pK<=0.95", modelParameters);
307 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.7<=pL<=0.9,0.75<=pK<=0.95", modelParameters);
312TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Parametric_Die_Mon) {
313 typedef typename TestFixture::ValueType
ValueType;
315 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/parametric_die_2.pm";
316 std::string formulaAsString =
"P <=0.5 [F s=7 & d=2 ]";
317 std::string constantsAsString =
"";
322 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
324 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
330 modelParameters.insert(rewParameters.begin(), rewParameters.end());
334 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
336 formulas[0] = simplifier.getSimplifiedFormula();
340 if (storm::settings::getModule<storm::settings::modules::BisimulationSettings>().isWeakBisimulationSet()) {
343 model = storm::api::performBisimulationMinimization<storm::RationalFunction>(model, formulas, bisimType)
351 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.2,0.8<=q<=0.9", modelParameters);
358 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.9,0.1<=q<=0.9", modelParameters);
362 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.8<=p<=0.9,0.1<=q<=0.2", modelParameters);
367TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Simple1_Mon) {
368 typedef typename TestFixture::ValueType
ValueType;
370 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/simple1.pm";
371 std::string formulaAsString =
"P<0.75 [F s=3 ]";
372 std::string constantsAsString =
"";
377 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
379 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
385 modelParameters.insert(rewParameters.begin(), rewParameters.end());
392 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.4<=p<=0.6", modelParameters);
399 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.9", modelParameters);
403 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.05<=p<=0.1", modelParameters);
408TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Casestudy1_Mon) {
409 typedef typename TestFixture::ValueType
ValueType;
411 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/casestudy1.pm";
412 std::string formulaAsString =
"P<0.5 [F s=3 ]";
413 std::string constantsAsString =
"";
418 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
420 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
426 modelParameters.insert(rewParameters.begin(), rewParameters.end());
433 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.5", modelParameters);
440 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.4<=p<=0.8", modelParameters);
444 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.7<=p<=0.9", modelParameters);
449TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Casestudy2_Mon) {
450 typedef typename TestFixture::ValueType
ValueType;
452 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/casestudy2.pm";
453 std::string formulaAsString =
"P<0.5 [F s=4 ]";
454 std::string constantsAsString =
"";
459 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
461 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
467 modelParameters.insert(rewParameters.begin(), rewParameters.end());
474 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.4", modelParameters);
481 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.4<=p<=0.9", modelParameters);
485 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.8<=p<=0.9", modelParameters);
490TYPED_TEST(SparseDtmcParameterLiftingMonotonicityTest, Casestudy3_Mon) {
491 typedef typename TestFixture::ValueType
ValueType;
493 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/casestudy3.pm";
494 std::string formulaAsString =
"P<0.5 [F s=3 ]";
495 std::string constantsAsString =
"";
500 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
502 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
508 modelParameters.insert(rewParameters.begin(), rewParameters.end());
514 model->getTransitionMatrix().printAsMatlabMatrix(std::cout);
518 ASSERT_TRUE(order->getDoneBuilding());
521 auto allSatRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.6<=p<=0.9", modelParameters);
526 auto exBothRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.3<=p<=0.7", modelParameters);
531 auto allVioRegion = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.4", modelParameters);
SolverEnvironment & solver()
void setPrecision(storm::RationalNumber value)
void setMethod(storm::solver::MinMaxMethod value, bool isSetFromDefault=false)
MinMaxSolverEnvironment & minMax()
std::map< std::shared_ptr< Order >, std::pair< std::shared_ptr< MonotonicityResult< VariableType > >, std::vector< std::shared_ptr< expressions::BinaryRelationExpression > > > > checkMonotonicityInBuild(std::ostream &outfile, bool usePLA=false, std::string dotOutfileName="dotOutput")
Builds Reachability Orders for the given model and simultaneously uses them to check for Monotonicity...
std::shared_ptr< LocalMonotonicityResult< VariableType > > createLocalMonotonicityResult(std::shared_ptr< Order > order, storage::ParameterRegion< ValueType > region)
Builds Reachability Orders for the given model and simultaneously uses them to check for Monotonicity...
std::shared_ptr< ModelType > as()
Casts the model into the model type given by the template parameter.
This class represents a discrete-time Markov chain.
Base class for all sparse models.
std::vector< storm::jani::Property > parsePropertiesForPrismProgram(std::string const &inputString, storm::prism::Program const &program, boost::optional< std::set< std::string > > const &propertyFilter)
storm::prism::Program parseProgram(std::string const &filename, bool prismCompatibility, bool simplify)
std::unique_ptr< storm::modelchecker::RegionModelChecker< ValueType > > initializeRegionModelChecker(Environment const &env, std::shared_ptr< storm::models::sparse::Model< ValueType > > const &model, storm::modelchecker::CheckTask< storm::logic::Formula, ValueType > const &task, storm::modelchecker::RegionCheckEngine engine, bool allowModelSimplification=true, bool graphPreserving=true, bool preconditionsValidated=false, MonotonicitySetting monotonicitySetting=MonotonicitySetting(), std::optional< std::pair< std::set< typename storm::storage::ParameterRegion< ValueType >::VariableType >, std::set< typename storm::storage::ParameterRegion< ValueType >::VariableType > > > monotoneParameters=std::nullopt)
std::vector< std::shared_ptr< storm::logic::Formula const > > extractFormulasFromProperties(std::vector< storm::jani::Property > const &properties)
SFTBDDChecker::ValueType ValueType
RegionCheckEngine
The considered engine for region checking.
@ ParameterLifting
Parameter lifting approach.
@ ExactParameterLifting
Parameter lifting approach with exact arithmethics.
std::set< storm::RationalFunctionVariable > getRewardParameters(Model< storm::RationalFunction > const &model)
Get all parameters occurring in rewards.
std::set< storm::RationalFunctionVariable > getProbabilityParameters(Model< storm::RationalFunction > const &model)
Get all probability parameters occurring on transitions.
storm::prism::Program preprocess(storm::prism::Program const &program, std::map< storm::expressions::Variable, storm::expressions::Expression > const &constantDefinitions)
TYPED_TEST(GraphTestAR, SymbolicProb01StochasticGameDieSmall)
TYPED_TEST_SUITE(GraphTestAR, TestingTypes,)
::testing::Types< Cudd, Sylvan > TestingTypes