26 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/simple1.pm";
27 std::string formulaAsString =
"P=? [F s=3 ]";
28 std::string constantsAsString =
"";
33 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
35 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
39 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
40 model = simplifier.getSimplifiedModel();
44 auto region = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.9", modelParameters);
45 std::vector<storm::storage::ParameterRegion<storm::RationalFunction>> regions = {region};
54 propositionalChecker.
check(formula.
getSubformula())->template asExplicitQualitativeCheckResult<storm::RationalFunction>().getTruthValuesVector();
56 std::pair<storm::storage::BitVector, storm::storage::BitVector> statesWithProbability01 =
64 auto order = std::get<0>(orderExtender.toOrder(region,
nullptr));
69 auto var = modelParameters.begin();
75 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/simple1.pm";
76 std::string formulaAsString =
"P=? [F s=3 ]";
77 std::string constantsAsString =
"";
82 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
84 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
88 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
89 model = simplifier.getSimplifiedModel();
93 auto region = storm::api::parseRegion<storm::RationalFunction>(
"0.51<=p<=0.9", modelParameters);
94 std::vector<storm::storage::ParameterRegion<storm::RationalFunction>> regions = {region};
103 propositionalChecker.
check(formula.
getSubformula())->template asExplicitQualitativeCheckResult<storm::RationalFunction>().getTruthValuesVector();
105 std::pair<storm::storage::BitVector, storm::storage::BitVector> statesWithProbability01 =
113 auto order = std::get<0>(orderExtender.toOrder(region,
nullptr));
118 auto var = modelParameters.begin();
125 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/casestudy1.pm";
126 std::string formulaAsString =
"P=? [F s=3 ]";
127 std::string constantsAsString =
"";
132 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
134 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
138 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
139 model = simplifier.getSimplifiedModel();
143 auto region = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.9", modelParameters);
144 std::vector<storm::storage::ParameterRegion<storm::RationalFunction>> regions = {region};
153 propositionalChecker.
check(formula.
getSubformula())->template asExplicitQualitativeCheckResult<storm::RationalFunction>().getTruthValuesVector();
155 std::pair<storm::storage::BitVector, storm::storage::BitVector> statesWithProbability01 =
163 auto res = orderExtender.extendOrder(
nullptr, region);
164 auto order = std::get<0>(res);
165 ASSERT_TRUE(order->getDoneBuilding());
171 auto var = modelParameters.begin();
172 for (uint_fast64_t i = 0; i < 3; i++) {
179 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/casestudy2.pm";
180 std::string formulaAsString =
"P=? [F s=4 ]";
181 std::string constantsAsString =
"";
186 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
188 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
192 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
193 model = simplifier.getSimplifiedModel();
197 auto region = storm::api::parseRegion<storm::RationalFunction>(
"0.51<=p<=0.9", modelParameters);
198 std::vector<storm::storage::ParameterRegion<storm::RationalFunction>> regions = {region};
207 propositionalChecker.
check(formula.
getSubformula())->template asExplicitQualitativeCheckResult<storm::RationalFunction>().getTruthValuesVector();
209 std::pair<storm::storage::BitVector, storm::storage::BitVector> statesWithProbability01 =
217 auto res = orderExtender.extendOrder(
nullptr, region);
218 auto order = std::get<0>(res);
219 order->addRelation(1, 3);
220 order->addRelation(3, 2);
226 auto var = modelParameters.begin();
227 for (uint_fast64_t i = 0; i < 3; i++) {
234 std::string programFile = STORM_TEST_RESOURCES_DIR
"/pdtmc/casestudy3.pm";
235 std::string formulaAsString =
"P=? [F s=3 ]";
236 std::string constantsAsString =
"";
241 std::vector<std::shared_ptr<const storm::logic::Formula>> formulas =
243 std::shared_ptr<storm::models::sparse::Dtmc<storm::RationalFunction>> model =
247 ASSERT_TRUE(simplifier.simplify(*(formulas[0])));
248 model = simplifier.getSimplifiedModel();
252 auto region = storm::api::parseRegion<storm::RationalFunction>(
"0.1<=p<=0.9", modelParameters);
253 std::vector<storm::storage::ParameterRegion<storm::RationalFunction>> regions = {region};
262 propositionalChecker.
check(formula.
getSubformula())->template asExplicitQualitativeCheckResult<storm::RationalFunction>().getTruthValuesVector();
264 std::pair<storm::storage::BitVector, storm::storage::BitVector> statesWithProbability01 =
272 auto res = orderExtender.extendOrder(
nullptr, region);
273 auto order = std::get<0>(res);
274 ASSERT_TRUE(order->getDoneBuilding());
280 auto var = modelParameters.begin();
285 region = storm::api::parseRegion<storm::RationalFunction>(
"0.51<=p<=0.9", modelParameters);
Monotonicity checkLocalMonotonicity(std::shared_ptr< Order > const &order, uint_fast64_t state, VariableType const &var, storage::ParameterRegion< ValueType > const ®ion)
Checks for local monotonicity at the given state.
std::pair< storm::storage::BitVector, storm::storage::BitVector > performProb01(storm::models::sparse::DeterministicModel< T > const &model, storm::storage::BitVector const &phiStates, storm::storage::BitVector const &psiStates)
Computes the sets of states that have probability 0 or 1, respectively, of satisfying phi until psi i...