diff --git a/src/storm/modelchecker/CheckTask.h b/src/storm/modelchecker/CheckTask.h index 898795fda..6598d5a85 100644 --- a/src/storm/modelchecker/CheckTask.h +++ b/src/storm/modelchecker/CheckTask.h @@ -9,6 +9,7 @@ #include "storm/solver/OptimizationDirection.h" #include "storm/logic/ComparisonType.h" +#include "storm/logic/PlayerCoalition.h" #include "storm/modelchecker/hints/ModelCheckerHint.h" #include "storm/exceptions/InvalidOperationException.h" @@ -51,7 +52,7 @@ namespace storm { */ template CheckTask substituteFormula(NewFormulaType const& newFormula) const { - CheckTask result(newFormula, this->optimizationDirection, this->rewardModel, this->onlyInitialStatesRelevant, this->bound, this->qualitative, this->produceSchedulers, this->hint); + CheckTask result(newFormula, this->optimizationDirection, this->playerCoalition, this->rewardModel, this->onlyInitialStatesRelevant, this->bound, this->qualitative, this->produceSchedulers, this->hint); result.updateOperatorInformation(); return result; } @@ -104,7 +105,7 @@ namespace storm { */ template CheckTask convertValueType() const { - return CheckTask(this->formula, this->optimizationDirection, this->rewardModel, this->onlyInitialStatesRelevant, this->bound, this->qualitative, this->produceSchedulers, this->hint); + return CheckTask(this->formula, this->optimizationDirection, this->playerCoalition, this->rewardModel, this->onlyInitialStatesRelevant, this->bound, this->qualitative, this->produceSchedulers, this->hint); } /*! @@ -135,6 +136,28 @@ namespace storm { optimizationDirection = dir; } + /*! + * Retrieves whether a player coalition was set. + */ + bool isPlayerCoalitionSet() const { + return static_cast(playerCoalition); + } + + /*! + * Retrieves the player coalition (if set). + */ + storm::logic::PlayerCoalition const& getPlayerCoalition() const { + return playerCoalition.get(); + } + + /*! + * Sets the player coalition. + */ + CheckTask& setPlayerCoalition(storm::logic::PlayerCoalition const& coalition) { + playerCoalition = coalition; + return *this; + } + /*! * Retrieves whether a reward model was set. */ @@ -261,6 +284,7 @@ namespace storm { * * @param formula The formula to attach to the task. * @param optimizationDirection If set, the probabilities will be minimized/maximized. + * @param playerCoalition If set, the given coalitions of players will be assumed. * @param rewardModelName If given, the checking has to be done wrt. to this reward model. * @param onlyInitialStatesRelevant If set to true, the model checker may decide to only compute the values * for the initial states. @@ -270,7 +294,7 @@ namespace storm { * @param produceSchedulers If supported by the model checker and the model formalism, schedulers to achieve * a value will be produced if this flag is set. */ - CheckTask(std::reference_wrapper const& formula, boost::optional const& optimizationDirection, boost::optional const& rewardModel, bool onlyInitialStatesRelevant, boost::optional const& bound, bool qualitative, bool produceSchedulers, std::shared_ptr const& hint) : formula(formula), optimizationDirection(optimizationDirection), rewardModel(rewardModel), onlyInitialStatesRelevant(onlyInitialStatesRelevant), bound(bound), qualitative(qualitative), produceSchedulers(produceSchedulers), hint(hint) { + CheckTask(std::reference_wrapper const& formula, boost::optional const& optimizationDirection, boost::optional playerCoalition, boost::optional const& rewardModel, bool onlyInitialStatesRelevant, boost::optional const& bound, bool qualitative, bool produceSchedulers, std::shared_ptr const& hint) : formula(formula), optimizationDirection(optimizationDirection), playerCoalition(playerCoalition), rewardModel(rewardModel), onlyInitialStatesRelevant(onlyInitialStatesRelevant), bound(bound), qualitative(qualitative), produceSchedulers(produceSchedulers), hint(hint) { // Intentionally left empty. } @@ -279,6 +303,9 @@ namespace storm { // If set, the probabilities will be minimized/maximized. boost::optional optimizationDirection; + + // If set, the given coalitions of players will be assumed. + boost::optional playerCoalition; // If set, the reward property has to be interpreted over this model. boost::optional rewardModel;