Storm 1.11.1.1
A Modern Probabilistic Model Checker
Loading...
Searching...
No Matches
NondeterministicModel.cpp
Go to the documentation of this file.
2
6#include "storm/io/export.h"
13
14namespace storm {
15namespace models {
16namespace sparse {
17
18template<typename ValueType, typename RewardModelType>
24
25template<typename ValueType, typename RewardModelType>
28 : Model<ValueType, RewardModelType>(modelType, std::move(components)) {
29 // Intentionally left empty
31
32template<typename ValueType, typename RewardModelType>
34 return this->getTransitionMatrix().getRowGroupIndices();
35}
36
37template<typename ValueType, typename RewardModelType>
39 auto indices = this->getNondeterministicChoiceIndices();
40 return indices[state + 1] - indices[state];
41}
42
43template<typename ValueType, typename RewardModelType>
45 for (auto& rewardModel : this->getRewardModels()) {
46 rewardModel.second.reduceToStateBasedRewards(this->getTransitionMatrix(), false);
47 }
49
50template<typename ValueType, typename RewardModelType>
51std::shared_ptr<storm::models::sparse::Model<ValueType, RewardModelType>> NondeterministicModel<ValueType, RewardModelType>::applyScheduler(
52 storm::storage::Scheduler<ValueType> const& scheduler, bool dropUnreachableStates, bool preserveModelType) const {
53 if (scheduler.isMemorylessScheduler() && scheduler.isDeterministicScheduler() && !scheduler.isPartialScheduler()) {
54 // Special case with improved handling.
55 storm::storage::BitVector actionSelection = scheduler.computeActionSupport(getNondeterministicChoiceIndices());
56 storm::storage::BitVector allStates(this->getNumberOfStates(), true);
58 options.makeRowGroupingTrivial = !preserveModelType;
59 auto res = storm::transformer::buildSubsystem(*this, allStates, actionSelection, !dropUnreachableStates, options);
60 return res.model;
61 } else {
63 if (!dropUnreachableStates) {
64 memoryProduct.setBuildFullProduct();
65 }
66 return memoryProduct.build(preserveModelType);
67 }
68}
70template<typename ValueType, typename RewardModelType>
72 this->printModelInformationHeaderToStream(out);
73 out << "Choices: \t" << this->getNumberOfChoices() << '\n';
74 this->printModelInformationFooterToStream(out);
75}
76
77template<typename ValueType, typename RewardModelType>
78void NondeterministicModel<ValueType, RewardModelType>::writeDotToStream(std::ostream& outStream, size_t maxWidthLabel, bool includeLabeling,
79 storm::storage::BitVector const* subsystem, std::vector<ValueType> const* firstValue,
80 std::vector<ValueType> const* secondValue,
81 std::vector<uint_fast64_t> const* stateColoring,
82 std::vector<std::string> const* colors, std::vector<uint_fast64_t>* scheduler,
83 bool finalizeOutput) const {
84 Model<ValueType, RewardModelType>::writeDotToStream(outStream, maxWidthLabel, includeLabeling, subsystem, firstValue, secondValue, stateColoring, colors,
85 scheduler, false);
86
87 // Write the probability distributions for all the states.
88 for (uint_fast64_t state = 0; state < this->getNumberOfStates(); ++state) {
89 uint_fast64_t rowCount = this->getNondeterministicChoiceIndices()[state + 1] - this->getNondeterministicChoiceIndices()[state];
90 bool highlightChoice = true;
91
92 // For this, we need to iterate over all available nondeterministic choices in the current state.
93 for (uint_fast64_t choice = 0; choice < rowCount; ++choice) {
94 uint_fast64_t rowIndex = this->getNondeterministicChoiceIndices()[state] + choice;
95 typename storm::storage::SparseMatrix<ValueType>::const_rows row = this->getTransitionMatrix().getRow(rowIndex);
96
97 if (scheduler != nullptr) {
98 // If the scheduler picked the current choice, we will not make it dotted, but highlight it.
99 if ((*scheduler)[state] == choice) {
100 highlightChoice = true;
101 } else {
102 highlightChoice = false;
103 }
104 }
105
106 // For each nondeterministic choice, we draw an arrow to an intermediate node to better display
107 // the grouping of transitions.
108
109 // The intermediate node:
110 outStream << "\t\"" << state << "c" << choice << "\" [shape = \"point\"";
111 // If we were given a scheduler to highlight, we do so now.
112 if (scheduler != nullptr) {
113 if (highlightChoice) {
114 outStream << ", fillcolor=\"red\"";
115 }
116 }
117 outStream << "];\n";
118
119 // The arrow to the intermediate node:
120 outStream << "\t" << state << " -> \"" << state << "c" << choice << "\"";
121 bool arrowHasLabel = false;
122 if (this->isOfType(ModelType::MarkovAutomaton)) {
123 // If this is a Markov automaton, we have to check whether the current choice is a Markovian choice and correspondingly print the exit rate
125 if (ma->isMarkovianState(state) && choice == 0) {
126 arrowHasLabel = true;
127 outStream << " [ label = \"" << ma->getExitRate(state);
128 }
129 }
130 if (this->hasChoiceLabeling()) {
131 if (arrowHasLabel) {
132 outStream << " | {";
133 } else {
134 outStream << " [ label = \"{";
135 }
136 arrowHasLabel = true;
137 storm::io::outputFixedWidth(outStream, this->getChoiceLabeling().getLabelsOfChoice(rowIndex), maxWidthLabel);
138 outStream << "}";
139 }
140 if (arrowHasLabel) {
141 outStream << "\"";
142 }
143 // If we were given a scheduler to highlight, we do so now.
144 if (scheduler != nullptr) {
145 if (arrowHasLabel) {
146 outStream << ", ";
147 } else {
148 outStream << "[ ";
149 }
150 if (highlightChoice) {
151 outStream << "color=\"red\", penwidth = 2";
152 } else {
153 outStream << "style = \"dotted\"";
154 }
155 }
156
157 if (arrowHasLabel || scheduler != nullptr) {
158 outStream << "]\n";
159 }
160 outStream << ";\n";
161
162 // Now draw all probabilistic arcs that belong to this non-deterministic choice.
163 for (auto const& transition : row) {
164 if (subsystem == nullptr || subsystem->get(transition.getColumn())) {
165 outStream << "\t\"" << state << "c" << choice << "\" -> " << transition.getColumn() << " [ label= \"" << transition.getValue() << "\" ]";
166
167 // If we were given a scheduler to highlight, we do so now.
168 if (scheduler != nullptr) {
169 if (highlightChoice) {
170 outStream << " [color=\"red\", penwidth = 2]";
171 } else {
172 outStream << " [style = \"dotted\"]";
173 }
174 }
175 outStream << ";\n";
176 }
177 }
178 }
179 }
180
181 if (finalizeOutput) {
182 outStream << "}\n";
183 }
184}
185
186template<typename ValueType, typename RewardModelType>
188 return this->getNondeterministicChoiceIndices()[stateactPair.getState()] + stateactPair.getAction();
189}
190
191template class NondeterministicModel<double>;
196} // namespace sparse
197} // namespace models
198} // namespace storm
virtual uint_fast64_t getNumberOfChoices() const =0
Returns the number of choices ine the model.
This class represents a Markov automaton.
bool isMarkovianState(storm::storage::sparse::state_type state) const
Retrieves whether the given state is a Markovian state.
ValueType const & getExitRate(storm::storage::sparse::state_type state) const
Retrieves the exit rate of the given state.
Base class for all sparse models.
Definition Model.h:32
virtual void writeDotToStream(std::ostream &outStream, size_t maxWidthLabel=30, bool includeLabeling=true, storm::storage::BitVector const *subsystem=nullptr, std::vector< ValueType > const *firstValue=nullptr, std::vector< ValueType > const *secondValue=nullptr, std::vector< uint64_t > const *stateColoring=nullptr, std::vector< std::string > const *colors=nullptr, std::vector< uint_fast64_t > *scheduler=nullptr, bool finalizeOutput=true) const
Exports the model to the dot-format and prints the result to the given stream.
The base class of sparse nondeterministic models.
std::vector< uint_fast64_t > const & getNondeterministicChoiceIndices() const
Retrieves the vector indicating which matrix rows represent non-deterministic choices of a certain st...
virtual void printModelInformationToStream(std::ostream &out) const override
Prints information about the model to the specified stream.
NondeterministicModel(ModelType modelType, storm::storage::sparse::ModelComponents< ValueType, RewardModelType > const &components)
Constructs a model from the given data.
std::shared_ptr< storm::models::sparse::Model< ValueType, RewardModelType > > applyScheduler(storm::storage::Scheduler< ValueType > const &scheduler, bool dropUnreachableStates=true, bool preserveModelType=false) const
Applies the given scheduler to this model.
virtual void reduceToStateBasedRewards() override
Converts the transition rewards of all reward models to state-based rewards.
virtual void writeDotToStream(std::ostream &outStream, size_t maxWidthLabel=30, bool includeLabeling=true, storm::storage::BitVector const *subsystem=nullptr, std::vector< ValueType > const *firstValue=nullptr, std::vector< ValueType > const *secondValue=nullptr, std::vector< uint_fast64_t > const *stateColoring=nullptr, std::vector< std::string > const *colors=nullptr, std::vector< uint_fast64_t > *scheduler=nullptr, bool finalizeOutput=true) const override
uint_fast64_t getChoiceIndex(storm::storage::StateActionPair const &stateactPair) const
For a state/action pair, get the choice index referring to the state-action pair.
A bit vector that is internally represented as a vector of 64-bit values.
Definition BitVector.h:16
bool get(uint64_t index) const
Retrieves the truth value of the bit at the given index and performs a bound check.
This class defines which action is chosen in a particular state of a non-deterministic model.
Definition Scheduler.h:18
bool isDeterministicScheduler() const
Retrieves whether all defined choices are deterministic.
storm::storage::BitVector computeActionSupport(std::vector< uint64_t > const &nondeterministicChoiceIndicies) const
Compute the Action Support: A bit vector that indicates all actions that are selected with positive p...
bool isPartialScheduler() const
Retrieves whether there is a reachable pair of model and memory state for which the choice is undefin...
bool isMemorylessScheduler() const
Retrieves whether the scheduler considers a trivial memory structure (i.e., a memory structure with j...
This class represents a number of consecutive rows of the matrix.
This class builds the product of the given sparse model and the given memory structure.
uint_fast64_t getState() const
uint_fast64_t getAction() const
void outputFixedWidth(std::ostream &stream, Container const &output, size_t maxWidth=30)
Output list of strings with linebreaks according to fixed width.
Definition export.h:60
SubsystemBuilderReturnType< ValueType, RewardModelType > buildSubsystem(storm::models::sparse::Model< ValueType, RewardModelType > const &originalModel, storm::storage::BitVector const &subsystemStates, storm::storage::BitVector const &subsystemActions, bool keepUnreachableStates, SubsystemBuilderOptions options)