#include "gtest/gtest.h" #include "storm-config.h" #ifdef STORM_HAVE_MSAT #include "storm/parser/PrismParser.h" #include "storm/abstraction/MenuGameRefiner.h" #include "storm/abstraction/prism/PrismMenuGameAbstractor.h" #include "storm/storage/expressions/Expression.h" #include "storm/storage/dd/Add.h" #include "storm/storage/dd/Bdd.h" #include "storm/models/symbolic/StandardRewardModel.h" #include "storm/utility/solver.h" #include "storm/adapters/CarlAdapter.h" TEST(PrismMenuGame, DieAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/die.pm"); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(26ull, game.getNumberOfTransitions()); EXPECT_EQ(4ull, game.getNumberOfStates()); EXPECT_EQ(2ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, DieAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/die.pm"); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(26ull, game.getNumberOfTransitions()); EXPECT_EQ(4ull, game.getNumberOfStates()); EXPECT_EQ(2ull, game.getBottomStates().getNonZeroCount()); } #ifdef STORM_HAVE_CARL // Commented out due to incompatibility with new refiner functionality. // This functionality depends on some operators being available on the value type which are not there for rational functions. //TEST(PrismMenuGame, DieAbstractionTest_SylvanWithRationalFunction) { // storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/die.pm"); // std::vector initialPredicates; // storm::expressions::ExpressionManager& manager = program.getManager(); // initialPredicates.push_back(manager.getVariableExpression("s") < manager.integer(3)); // std::shared_ptr smtSolverFactory = std::make_shared(); // storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); // storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); // refiner.refine(initialPredicates); // storm::abstraction::MenuGame game = abstractor.abstract(); // EXPECT_EQ(26, game.getNumberOfTransitions()); // EXPECT_EQ(4, game.getNumberOfStates()); // EXPECT_EQ(2, game.getBottomStates().getNonZeroCount()); //} #endif TEST(PrismMenuGame, DieAbstractionAndRefinementTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/die.pm"); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("s") == manager.integer(7)})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(24ull, game.getNumberOfTransitions()); EXPECT_EQ(5ull, game.getNumberOfStates()); EXPECT_EQ(2ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, DieAbstractionAndRefinementTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/die.pm"); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("s") == manager.integer(7)})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(24ull, game.getNumberOfTransitions()); EXPECT_EQ(5ull, game.getNumberOfStates()); EXPECT_EQ(2ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, DieFullAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/die.pm"); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(6)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(20ull, game.getNumberOfTransitions()); EXPECT_EQ(13ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, DieFullAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/die.pm"); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("d") == manager.integer(6)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(20ull, game.getNumberOfTransitions()); EXPECT_EQ(13ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, CrowdsAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/crowds-5-5.pm"); program = program.substituteConstants(); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("phase") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(31ull, game.getNumberOfTransitions()); EXPECT_EQ(4ull, game.getNumberOfStates()); EXPECT_EQ(2ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, CrowdsAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/crowds-5-5.pm"); program = program.substituteConstants(); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("phase") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(31ull, game.getNumberOfTransitions()); EXPECT_EQ(4ull, game.getNumberOfStates()); EXPECT_EQ(2ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, CrowdsAbstractionAndRefinementTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/crowds-5-5.pm"); program = program.substituteConstants(); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("phase") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("observe0") + manager.getVariableExpression("observe1") + manager.getVariableExpression("observe2") + manager.getVariableExpression("observe3") + manager.getVariableExpression("observe4") <= manager.getVariableExpression("runCount")})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(68ull, game.getNumberOfTransitions()); EXPECT_EQ(8ull, game.getNumberOfStates()); EXPECT_EQ(4ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, CrowdsAbstractionAndRefinementTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/crowds-5-5.pm"); program = program.substituteConstants(); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("phase") < manager.integer(3)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("observe0") + manager.getVariableExpression("observe1") + manager.getVariableExpression("observe2") + manager.getVariableExpression("observe3") + manager.getVariableExpression("observe4") <= manager.getVariableExpression("runCount")})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(68ull, game.getNumberOfTransitions()); EXPECT_EQ(8ull, game.getNumberOfStates()); EXPECT_EQ(4ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, CrowdsFullAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/crowds-5-5.pm"); program = program.substituteConstants(); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("good")); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(4)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(15113ull, game.getNumberOfTransitions()); EXPECT_EQ(8607ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, CrowdsFullAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/dtmc/crowds-5-5.pm"); program = program.substituteConstants(); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("phase") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("good")); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("runCount") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe0") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe3") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("observe4") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("lastSeen") == manager.integer(4)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(15113ull, game.getNumberOfTransitions()); EXPECT_EQ(8607ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, TwoDiceAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/two_dice.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(0)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(90ull, game.getNumberOfTransitions()); EXPECT_EQ(8ull, game.getNumberOfStates()); EXPECT_EQ(4ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, TwoDiceAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/two_dice.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(0)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(90ull, game.getNumberOfTransitions()); EXPECT_EQ(8ull, game.getNumberOfStates()); EXPECT_EQ(4ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, TwoDiceAbstractionAndRefinementTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/two_dice.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(0)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("d1") + manager.getVariableExpression("d2") == manager.integer(7)})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(276ull, game.getNumberOfTransitions()); EXPECT_EQ(16ull, game.getNumberOfStates()); EXPECT_EQ(8ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, TwoDiceAbstractionAndRefinementTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/two_dice.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(0)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("d1") + manager.getVariableExpression("d2") == manager.integer(7)})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(276ull, game.getNumberOfTransitions()); EXPECT_EQ(16ull, game.getNumberOfStates()); EXPECT_EQ(8ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, TwoDiceFullAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/two_dice.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(6)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(436ull, game.getNumberOfTransitions()); EXPECT_EQ(169ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, TwoDiceFullAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/two_dice.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("d1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("d2") == manager.integer(6)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(436ull, game.getNumberOfTransitions()); EXPECT_EQ(169ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, WlanAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/wlan0-2-4.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.getVariableExpression("c2")); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(915ull, game.getNumberOfTransitions()); EXPECT_EQ(8ull, game.getNumberOfStates()); EXPECT_EQ(4ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, WlanAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/wlan0-2-4.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.getVariableExpression("c2")); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(915ull, game.getNumberOfTransitions()); EXPECT_EQ(8ull, game.getNumberOfStates()); EXPECT_EQ(4ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, WlanAbstractionAndRefinementTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/wlan0-2-4.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.getVariableExpression("c2")); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("backoff1") < manager.integer(7)})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(1824ull, game.getNumberOfTransitions()); EXPECT_EQ(16ull, game.getNumberOfStates()); EXPECT_EQ(8ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, WlanAbstractionAndRefinementTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/wlan0-2-4.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("s1") < manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.getVariableExpression("c2")); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); ASSERT_NO_THROW(refiner.refine({manager.getVariableExpression("backoff1") < manager.integer(7)})); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(1824ull, game.getNumberOfTransitions()); EXPECT_EQ(16ull, game.getNumberOfStates()); EXPECT_EQ(8ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, WlanFullAbstractionTest_Cudd) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/wlan0-2-4.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("col") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("col") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("col") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("c2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("c2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("slot1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("slot1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(13)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(14)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(15)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("slot2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("slot2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(13)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(14)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(15)); initialPredicates.push_back(manager.getVariableExpression("bc2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("bc2") == manager.integer(1)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(9503ull, game.getNumberOfTransitions()); EXPECT_EQ(5523ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } TEST(PrismMenuGame, WlanFullAbstractionTest_Sylvan) { storm::prism::Program program = storm::parser::PrismParser::parse(STORM_TEST_RESOURCES_DIR "/mdp/wlan0-2-4.nm"); program = program.substituteConstants(); program = program.flattenModules(std::make_shared()); std::vector initialPredicates; storm::expressions::ExpressionManager& manager = program.getManager(); initialPredicates.push_back(manager.getVariableExpression("col") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("col") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("col") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("c1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("c2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("c2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("c2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("x1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("s1") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("slot1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("slot1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(13)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(14)); initialPredicates.push_back(manager.getVariableExpression("backoff1") == manager.integer(15)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("bc1") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("x2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("s2") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("slot2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("slot2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(1)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(2)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(3)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(4)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(5)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(6)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(7)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(8)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(9)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(10)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(11)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(12)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(13)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(14)); initialPredicates.push_back(manager.getVariableExpression("backoff2") == manager.integer(15)); initialPredicates.push_back(manager.getVariableExpression("bc2") == manager.integer(0)); initialPredicates.push_back(manager.getVariableExpression("bc2") == manager.integer(1)); std::shared_ptr smtSolverFactory = std::make_shared(); storm::abstraction::prism::PrismMenuGameAbstractor abstractor(program, smtSolverFactory); storm::abstraction::MenuGameRefiner refiner(abstractor, smtSolverFactory->create(manager)); refiner.refine(initialPredicates); storm::abstraction::MenuGame game = abstractor.abstract(); EXPECT_EQ(9503ull, game.getNumberOfTransitions()); EXPECT_EQ(5523ull, game.getNumberOfStates()); EXPECT_EQ(0ull, game.getBottomStates().getNonZeroCount()); } #endif