18TEST(ExplicitDtmcPrctlModelCheckerTest, Die) {
20 STORM_TEST_RESOURCES_DIR
"/tra/die.tra", STORM_TEST_RESOURCES_DIR
"/lab/die.lab",
"", STORM_TEST_RESOURCES_DIR
"/rew/die.coin_flips.trans.rew");
23 double const precision = 1e-6;
29 auto expManager = std::make_shared<storm::expressions::ExpressionManager>();
36 ASSERT_EQ(dtmc->getNumberOfStates(), 13ull);
37 ASSERT_EQ(dtmc->getNumberOfTransitions(), 20ull);
43 std::unique_ptr<storm::modelchecker::CheckResult> result = checker.
check(env, *formula);
46 EXPECT_NEAR(1.0 / 6.0, quantitativeResult1[0], precision);
50 result = checker.
check(env, *formula);
53 EXPECT_NEAR(1.0 / 6.0, quantitativeResult2[0], precision);
57 result = checker.
check(env, *formula);
60 EXPECT_NEAR(1.0 / 6.0, quantitativeResult3[0], precision);
64 result = checker.
check(env, *formula);
67 EXPECT_NEAR(11.0 / 3.0, quantitativeResult4[0], precision);
70TEST(ExplicitDtmcPrctlModelCheckerTest, Crowds) {
72 double const precision = 1e-6;
76 std::shared_ptr<storm::models::sparse::Model<double>> abstractModel =
83 auto expManager = std::make_shared<storm::expressions::ExpressionManager>();
88 ASSERT_EQ(8607ull, dtmc->getNumberOfStates());
89 ASSERT_EQ(15113ull, dtmc->getNumberOfTransitions());
95 std::unique_ptr<storm::modelchecker::CheckResult> result = checker.
check(env, *formula);
98 EXPECT_NEAR(0.3328800375801578281, quantitativeResult1[0], precision);
102 result = checker.
check(env, *formula);
105 EXPECT_NEAR(0.1522194965, quantitativeResult2[0], precision);
109 result = checker.
check(env, *formula);
112 EXPECT_NEAR(0.32153724292835045, quantitativeResult3[0], precision);
115TEST(ExplicitDtmcPrctlModelCheckerTest, SynchronousLeader) {
117 double const precision = 1e-6;
121 std::shared_ptr<storm::models::sparse::Model<double>> abstractModel =
123 STORM_TEST_RESOURCES_DIR
"/rew/leader4_8.pick.trans.rew");
129 auto expManager = std::make_shared<storm::expressions::ExpressionManager>();
134 ASSERT_EQ(12400ull, dtmc->getNumberOfStates());
135 ASSERT_EQ(16495ull, dtmc->getNumberOfTransitions());
141 std::unique_ptr<storm::modelchecker::CheckResult> result = checker.
check(env, *formula);
144 EXPECT_NEAR(1.0, quantitativeResult1[0], precision);
148 result = checker.
check(env, *formula);
151 EXPECT_NEAR(0.9999965911265462636, quantitativeResult2[0], precision);
155 result = checker.
check(env, *formula);
158 EXPECT_NEAR(1.0448979591836789, quantitativeResult3[0], precision);
static std::shared_ptr< storm::models::sparse::Model< ValueType, storm::models::sparse::StandardRewardModel< RewardValueType > > > parseModel(std::string const &transitionsFilename, std::string const &labelingFilename, std::string const &stateRewardFilename="", std::string const &transitionRewardFilename="", std::string const &choiceLabelingFilename="")
Checks the given files and parses the model within these files.