diff --git a/src/models/sparse/MarkovAutomaton.cpp b/src/models/sparse/MarkovAutomaton.cpp index 8276f519d..aa5ffc5e2 100644 --- a/src/models/sparse/MarkovAutomaton.cpp +++ b/src/models/sparse/MarkovAutomaton.cpp @@ -19,8 +19,9 @@ namespace storm { std::vector const& exitRates, std::unordered_map const& rewardModels, boost::optional> const& optionalChoiceLabeling) - : NondeterministicModel(storm::models::ModelType::MarkovAutomaton, transitionMatrix, stateLabeling, rewardModels, optionalChoiceLabeling), markovianStates(markovianStates), exitRates(exitRates), closed(false) { + : NondeterministicModel(storm::models::ModelType::MarkovAutomaton, transitionMatrix, stateLabeling, rewardModels, optionalChoiceLabeling), markovianStates(markovianStates), exitRates(exitRates) { this->turnRatesToProbabilities(); + closed = !hasHybridState(); } template @@ -30,8 +31,9 @@ namespace storm { std::vector const& exitRates, std::unordered_map&& rewardModels, boost::optional>&& optionalChoiceLabeling) - : NondeterministicModel(storm::models::ModelType::MarkovAutomaton, std::move(transitionMatrix), std::move(stateLabeling), std::move(rewardModels), std::move(optionalChoiceLabeling)), markovianStates(markovianStates), exitRates(std::move(exitRates)), closed(false) { + : NondeterministicModel(storm::models::ModelType::MarkovAutomaton, std::move(transitionMatrix), std::move(stateLabeling), std::move(rewardModels), std::move(optionalChoiceLabeling)), markovianStates(markovianStates), exitRates(std::move(exitRates)) { this->turnRatesToProbabilities(); + closed = !hasHybridState(); } template @@ -42,9 +44,10 @@ namespace storm { bool probabilities, std::unordered_map&& rewardModels, boost::optional>&& optionalChoiceLabeling) - : NondeterministicModel(storm::models::ModelType::MarkovAutomaton, std::move(transitionMatrix), std::move(stateLabeling), std::move(rewardModels), std::move(optionalChoiceLabeling)), markovianStates(markovianStates), exitRates(std::move(exitRates)), closed(false) { + : NondeterministicModel(storm::models::ModelType::MarkovAutomaton, std::move(transitionMatrix), std::move(stateLabeling), std::move(rewardModels), std::move(optionalChoiceLabeling)), markovianStates(markovianStates), exitRates(std::move(exitRates)) { assert(probabilities); assert(this->getTransitionMatrix().isProbabilistic()); + closed = !hasHybridState(); } template @@ -67,6 +70,16 @@ namespace storm { return !this->markovianStates.get(state); } + template + bool MarkovAutomaton::hasHybridState() const { + for (uint_fast64_t state = 0; state < this->getNumberOfStates(); ++state) { + if (this->isHybridState(state)) { + return true; + } + } + return false; + } + template std::vector const& MarkovAutomaton::getExitRates() const { return this->exitRates; diff --git a/src/models/sparse/MarkovAutomaton.h b/src/models/sparse/MarkovAutomaton.h index e335f5050..d97ff1517 100644 --- a/src/models/sparse/MarkovAutomaton.h +++ b/src/models/sparse/MarkovAutomaton.h @@ -157,6 +157,13 @@ namespace storm { */ void turnRatesToProbabilities(); + /*! + * Check if at least one hybrid state exists. + * + * @return True, if at least one hybrid state exists, false if none exists. + */ + bool hasHybridState() const; + // A bit vector representing the set of Markovian states. storm::storage::BitVector markovianStates;