10 changed files with 275 additions and 1 deletions
			
			
		- 
					4src/CMakeLists.txt
- 
					2src/adapters/Z3ExpressionAdapter.h
- 
					17src/storage/prism/menu_games/AbstractCommand.cpp
- 
					48src/storage/prism/menu_games/AbstractCommand.h
- 
					21src/storage/prism/menu_games/AbstractModule.cpp
- 
					51src/storage/prism/menu_games/AbstractModule.h
- 
					64src/storage/prism/menu_games/AbstractProgram.cpp
- 
					69src/storage/prism/menu_games/AbstractProgram.h
- 
					0src/storage/prism/menu_games/VariablePartition.cpp
- 
					0src/storage/prism/menu_games/VariablePartition.h
| @ -0,0 +1,17 @@ | |||||
|  | #include "src/storage/prism/menu_games/AbstractCommand.h"
 | ||||
|  | 
 | ||||
|  | #include "src/storage/prism/Command.h"
 | ||||
|  | #include "src/storage/prism/Update.h"
 | ||||
|  | 
 | ||||
|  | namespace storm { | ||||
|  |     namespace prism { | ||||
|  |         namespace menu_games { | ||||
|  |             template <storm::dd::DdType DdType, typename ValueType> | ||||
|  |             AbstractCommand<DdType, ValueType>::AbstractCommand(storm::expressions::ExpressionManager& expressionManager, storm::prism::Command const& command, std::vector<storm::expressions::Expression> const& initialPredicates, storm::utility::solver::SmtSolverFactory const& smtSolverFactory) : expressionManager(expressionManager), smtSolver(smtSolverFactory.create(expressionManager)), predicates(initialPredicates), command(command) { | ||||
|  |                 // Intentionally left empty.
 | ||||
|  |             } | ||||
|  |              | ||||
|  |             template class AbstractCommand<storm::dd::DdType::CUDD, double>; | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
| @ -0,0 +1,48 @@ | |||||
|  | #ifndef STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTCOMMAND_H_ | ||||
|  | #define STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTCOMMAND_H_ | ||||
|  | 
 | ||||
|  | #include <memory> | ||||
|  | 
 | ||||
|  | #include "src/storage/dd/DdType.h" | ||||
|  | #include "src/storage/expressions/Expression.h" | ||||
|  | 
 | ||||
|  | #include "src/solver/SmtSolver.h" | ||||
|  | #include "src/utility/solver.h" | ||||
|  | 
 | ||||
|  | namespace storm { | ||||
|  |     namespace prism { | ||||
|  |         // Forward-declare concrete command and update classes. | ||||
|  |         class Command; | ||||
|  |          | ||||
|  |         namespace menu_games { | ||||
|  |             template <storm::dd::DdType DdType, typename ValueType> | ||||
|  |             class AbstractCommand { | ||||
|  |             public: | ||||
|  |                 /*! | ||||
|  |                  * Constructs an abstract command from the given command and the initial predicates. | ||||
|  |                  * | ||||
|  |                  * @param expressionManager The manager responsible for the expressions of the command. | ||||
|  |                  * @param command The concrete command for which to build the abstraction. | ||||
|  |                  * @param initialPredicates The initial set of predicates. | ||||
|  |                  * @param smtSolverFactory A factory that is to be used for creating new SMT solvers. | ||||
|  |                  */ | ||||
|  |                 AbstractCommand(storm::expressions::ExpressionManager& expressionManager, storm::prism::Command const& command, std::vector<storm::expressions::Expression> const& initialPredicates, storm::utility::solver::SmtSolverFactory const& smtSolverFactory); | ||||
|  |                  | ||||
|  |             private: | ||||
|  |                 // The manager responsible for the expressions of the command and the SMT solvers. | ||||
|  |                 storm::expressions::ExpressionManager& expressionManager; | ||||
|  |                  | ||||
|  |                 // An SMT responsible for this abstract command. | ||||
|  |                 std::unique_ptr<storm::solver::SmtSolver> smtSolver; | ||||
|  |                  | ||||
|  |                 // The current set of predicates used in the abstraction. | ||||
|  |                 std::vector<storm::expressions::Expression> predicates; | ||||
|  |                  | ||||
|  |                 // The concrete command this abstract command refers to. | ||||
|  |                 std::reference_wrapper<Command const> command; | ||||
|  |             }; | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
|  | 
 | ||||
|  | #endif /* STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTCOMMAND_H_ */ | ||||
| @ -0,0 +1,21 @@ | |||||
|  | #include "src/storage/prism/menu_games/AbstractModule.h"
 | ||||
|  | 
 | ||||
|  | #include "src/storage/prism/Module.h"
 | ||||
|  | 
 | ||||
|  | namespace storm { | ||||
|  |     namespace prism { | ||||
|  |         namespace menu_games { | ||||
|  |              | ||||
|  |             template <storm::dd::DdType DdType, typename ValueType> | ||||
|  |             AbstractModule<DdType, ValueType>::AbstractModule(storm::expressions::ExpressionManager& expressionManager, storm::prism::Module const& module, std::vector<storm::expressions::Expression> const& initialPredicates, storm::utility::solver::SmtSolverFactory const& smtSolverFactory) : expressionManager(expressionManager), smtSolverFactory(smtSolverFactory), predicates(initialPredicates), commands(), module(module) { | ||||
|  |                  | ||||
|  |                 // For each concrete command, we create an abstract counterpart.
 | ||||
|  |                 for (auto const& command : module.getCommands()) { | ||||
|  |                     commands.emplace_back(expressionManager, command, initialPredicates, smtSolverFactory); | ||||
|  |                 } | ||||
|  |             } | ||||
|  |              | ||||
|  |             template class AbstractModule<storm::dd::DdType::CUDD, double>; | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
| @ -0,0 +1,51 @@ | |||||
|  | #ifndef STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTMODULE_H_ | ||||
|  | #define STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTMODULE_H_ | ||||
|  | 
 | ||||
|  | #include "src/storage/dd/DdType.h" | ||||
|  | 
 | ||||
|  | #include "src/storage/prism/menu_games/AbstractCommand.h" | ||||
|  | 
 | ||||
|  | #include "src/storage/expressions/Expression.h" | ||||
|  | 
 | ||||
|  | #include "src/utility/solver.h" | ||||
|  | 
 | ||||
|  | namespace storm { | ||||
|  |     namespace prism { | ||||
|  |         // Forward-declare concrete module class. | ||||
|  |         class Module; | ||||
|  |          | ||||
|  |         namespace menu_games { | ||||
|  |             template <storm::dd::DdType DdType, typename ValueType> | ||||
|  |             class AbstractModule { | ||||
|  |             public: | ||||
|  |                 /*! | ||||
|  |                  * Constructs an abstract module from the given module and the initial predicates. | ||||
|  |                  * | ||||
|  |                  * @param expressionManager The manager responsible for the expressions of the command. | ||||
|  |                  * @param module The concrete module for which to build the abstraction. | ||||
|  |                  * @param initialPredicates The initial set of predicates. | ||||
|  |                  * @param smtSolverFactory A factory that is to be used for creating new SMT solvers. | ||||
|  |                  */ | ||||
|  |                 AbstractModule(storm::expressions::ExpressionManager& expressionManager, storm::prism::Module const& module, std::vector<storm::expressions::Expression> const& initialPredicates, storm::utility::solver::SmtSolverFactory const& smtSolverFactory); | ||||
|  |                  | ||||
|  |             private: | ||||
|  |                 // The manager responsible for the expressions of the module and the SMT solvers. | ||||
|  |                 storm::expressions::ExpressionManager& expressionManager; | ||||
|  |                  | ||||
|  |                 // A factory that can be used to create new SMT solvers. | ||||
|  |                 storm::utility::solver::SmtSolverFactory const& smtSolverFactory; | ||||
|  |                  | ||||
|  |                 // The current set of predicates used in the abstraction. | ||||
|  |                 std::vector<storm::expressions::Expression> predicates; | ||||
|  |                  | ||||
|  |                 // The abstract commands of the abstract module. | ||||
|  |                 std::vector<AbstractCommand<DdType, ValueType>> commands; | ||||
|  |                  | ||||
|  |                 // The concrete module this abstract module refers to. | ||||
|  |                 std::reference_wrapper<Module const> module; | ||||
|  |             }; | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
|  | 
 | ||||
|  | #endif /* STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTMODULE_H_ */ | ||||
| @ -0,0 +1,64 @@ | |||||
|  | #include "src/storage/prism/menu_games/AbstractProgram.h"
 | ||||
|  | 
 | ||||
|  | #include <sstream>
 | ||||
|  | 
 | ||||
|  | #include "src/storage/prism/Program.h"
 | ||||
|  | 
 | ||||
|  | #include "src/storage/dd/CuddDdManager.h"
 | ||||
|  | 
 | ||||
|  | #include "src/utility/macros.h"
 | ||||
|  | #include "src/exceptions/WrongFormatException.h"
 | ||||
|  | 
 | ||||
|  | namespace storm { | ||||
|  |     namespace prism { | ||||
|  |         namespace menu_games { | ||||
|  |              | ||||
|  |             template <storm::dd::DdType DdType, typename ValueType> | ||||
|  |             AbstractProgram<DdType, ValueType>::AbstractProgram(storm::expressions::ExpressionManager& expressionManager, storm::prism::Program const& program, std::vector<storm::expressions::Expression> const& initialPredicates, std::unique_ptr<storm::utility::solver::SmtSolverFactory>&& smtSolverFactory, bool addAllGuards) : expressionManager(expressionManager), smtSolverFactory(std::move(smtSolverFactory)), predicates(initialPredicates), ddManager(new storm::dd::DdManager<DdType>()), predicateDdVariables(), commandDdVariable(), optionDdVariables(), modules(), program(program) { | ||||
|  |                  | ||||
|  |                 // For now, we assume that there is a single module. If the program has more than one module, it needs
 | ||||
|  |                 // to be flattened before the procedure.
 | ||||
|  |                 STORM_LOG_THROW(program.getNumberOfModules() == 1, storm::exceptions::WrongFormatException, "Cannot create abstract program from program containing too many modules."); | ||||
|  |                  | ||||
|  |                 uint_fast64_t totalNumberOfCommands = 0; | ||||
|  |                 for (auto const& module : program.getModules()) { | ||||
|  |                     // If we were requested to add all guards to the set of predicates, we do so now.
 | ||||
|  |                     if (addAllGuards) { | ||||
|  |                         for (auto const& command : module.getCommands()) { | ||||
|  |                             predicates.push_back(command.getGuardExpression()); | ||||
|  |                         } | ||||
|  |                     } | ||||
|  |                      | ||||
|  |                     totalNumberOfCommands += module.getNumberOfCommands(); | ||||
|  |                 } | ||||
|  |                  | ||||
|  |                 // Create DD variables for all predicates.
 | ||||
|  |                 for (auto const& predicate : predicates) { | ||||
|  |                     std::stringstream stream; | ||||
|  |                     stream << predicate; | ||||
|  |                     predicateDdVariables.push_back(ddManager->addMetaVariable(stream.str())); | ||||
|  |                 } | ||||
|  |                  | ||||
|  |                 // Create DD variable for the command encoding.
 | ||||
|  |                 commandDdVariable = ddManager->addMetaVariable("command", 0, totalNumberOfCommands - 1); | ||||
|  |                  | ||||
|  |                 // Create DD variables encoding the nondeterministic choices of player 2.
 | ||||
|  |                 // NOTE: currently we assume that 100 variables suffice, which corresponds to 2^100 possible choices.
 | ||||
|  |                 // If for some reason this should not be enough, we could grow this vector dynamically, but odds are
 | ||||
|  |                 // that it's impossible to treat such models in any event.
 | ||||
|  |                 for (uint_fast64_t index = 0; index < 100; ++index) { | ||||
|  |                     optionDdVariables.push_back(ddManager->addMetaVariable("opt" + std::to_string(index))); | ||||
|  |                 } | ||||
|  |                  | ||||
|  |                 // For each module of the concrete program, we create an abstract counterpart.
 | ||||
|  |                 for (auto const& module : program.getModules()) { | ||||
|  |                     modules.emplace_back(expressionManager, module, predicates, *smtSolverFactory); | ||||
|  |                 } | ||||
|  |             } | ||||
|  |              | ||||
|  |             // Explicitly instantiate the class.
 | ||||
|  |             template class AbstractProgram<storm::dd::DdType::CUDD, double>; | ||||
|  |              | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
| @ -0,0 +1,69 @@ | |||||
|  | #ifndef STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTPROGRAM_H_ | ||||
|  | #define STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTPROGRAM_H_ | ||||
|  | 
 | ||||
|  | #include "src/storage/dd/DdType.h" | ||||
|  | 
 | ||||
|  | #include "src/storage/prism/menu_games/AbstractModule.h" | ||||
|  | 
 | ||||
|  | #include "src/storage/expressions/Expression.h" | ||||
|  | 
 | ||||
|  | #include "src/utility/solver.h" | ||||
|  | 
 | ||||
|  | namespace storm { | ||||
|  |     namespace dd { | ||||
|  |         template <storm::dd::DdType DdType> | ||||
|  |         class DdManager; | ||||
|  |     } | ||||
|  |      | ||||
|  |     namespace prism { | ||||
|  |         // Forward-declare concrete Program class. | ||||
|  |         class Program; | ||||
|  |          | ||||
|  |         namespace menu_games { | ||||
|  |             template <storm::dd::DdType DdType, typename ValueType> | ||||
|  |             class AbstractProgram { | ||||
|  |             public: | ||||
|  |                 /*! | ||||
|  |                  * Constructs an abstract program from the given program and the initial predicates. | ||||
|  |                  * | ||||
|  |                  * @param expressionManager The manager responsible for the expressions of the program. | ||||
|  |                  * @param program The concrete program for which to build the abstraction. | ||||
|  |                  * @param initialPredicates The initial set of predicates. | ||||
|  |                  * @param smtSolverFactory A factory that is to be used for creating new SMT solvers. | ||||
|  |                  * @param addAllGuards A flag that indicates whether all guards of the program should be added to the initial set of predicates. | ||||
|  |                  */ | ||||
|  |                 AbstractProgram(storm::expressions::ExpressionManager& expressionManager, storm::prism::Program const& program, std::vector<storm::expressions::Expression> const& initialPredicates, std::unique_ptr<storm::utility::solver::SmtSolverFactory>&& smtSolverFactory = std::unique_ptr<storm::utility::solver::SmtSolverFactory>(new storm::utility::solver::SmtSolverFactory()), bool addAllGuards = false); | ||||
|  |                  | ||||
|  |             private: | ||||
|  |                 // The manager responsible for the expressions of the program and the SMT solvers. | ||||
|  |                 storm::expressions::ExpressionManager& expressionManager; | ||||
|  |                  | ||||
|  |                 // A factory that can be used to create new SMT solvers. | ||||
|  |                 std::unique_ptr<storm::utility::solver::SmtSolverFactory> smtSolverFactory; | ||||
|  |                  | ||||
|  |                 // The current set of predicates used in the abstraction. | ||||
|  |                 std::vector<storm::expressions::Expression> predicates; | ||||
|  |                  | ||||
|  |                 // The manager responsible for the DDs. | ||||
|  |                 std::shared_ptr<storm::dd::DdManager<DdType>> ddManager; | ||||
|  |                  | ||||
|  |                 // The DD variables corresponding to the predicates. | ||||
|  |                 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> predicateDdVariables; | ||||
|  |                  | ||||
|  |                 // The DD variable encoding the command (i.e., the nondeterministic choices of player 1). | ||||
|  |                 std::pair<storm::expressions::Variable, storm::expressions::Variable> commandDdVariable; | ||||
|  |                  | ||||
|  |                 // The DD variables encoding the nondeterministic choices of player 2. | ||||
|  |                 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>> optionDdVariables; | ||||
|  |                  | ||||
|  |                 // The abstract modules of the abstract program. | ||||
|  |                 std::vector<AbstractModule<DdType, ValueType>> modules; | ||||
|  |                  | ||||
|  |                 // The concrete program this abstract program refers to. | ||||
|  |                 std::reference_wrapper<Program const> program; | ||||
|  |             }; | ||||
|  |         } | ||||
|  |     } | ||||
|  | } | ||||
|  | 
 | ||||
|  | #endif /* STORM_STORAGE_PRISM_MENU_GAMES_ABSTRACTPROGRAM_H_ */ | ||||
						Write
						Preview
					
					
					Loading…
					
					Cancel
						Save
					
		Reference in new issue