Storm
A Modern Probabilistic Model Checker
Loading...
Searching...
No Matches
Formula.h
Go to the documentation of this file.
1#ifndef STORM_LOGIC_FORMULA_H_
2#define STORM_LOGIC_FORMULA_H_
3
4#include <iosfwd>
5#include <memory>
6#include <set>
7#include <vector>
8
9#include <boost/any.hpp>
11
12namespace storm {
13namespace expressions {
14class Variable;
15class Expression;
16class ExpressionManager;
17} // namespace expressions
18
19namespace logic {
20
21// Forward-declare visitor for accept() method.
22class FormulaVisitor;
23
24// Forward-declare fragment specification for isInFragment() method.
25class FragmentSpecification;
26
27// Forward-declare formula information class for info() method.
28class FormulaInformation;
29
30class Formula : public std::enable_shared_from_this<Formula> {
31 public:
32 // Make the destructor virtual to allow deletion of objects of subclasses via a pointer to this class.
33 virtual ~Formula() {
34 // Intentionally left empty.
35 };
36
37 friend std::ostream& operator<<(std::ostream& out, Formula const& formula);
38
39 // Basic formula types.
40 virtual bool isPathFormula() const;
41 virtual bool isStateFormula() const;
42 virtual bool isConditionalProbabilityFormula() const;
43 virtual bool isConditionalRewardFormula() const;
44
45 virtual bool isProbabilityPathFormula() const;
46 virtual bool isRewardPathFormula() const;
47 virtual bool isTimePathFormula() const;
48
49 virtual bool isBinaryBooleanStateFormula() const;
50 virtual bool isUnaryBooleanStateFormula() const;
51
52 virtual bool isBinaryBooleanPathFormula() const;
53 virtual bool isUnaryBooleanPathFormula() const;
54
55 virtual bool isMultiObjectiveFormula() const;
56 virtual bool isQuantileFormula() const;
57
58 // Operator formulas.
59 virtual bool isOperatorFormula() const;
60 virtual bool isLongRunAverageOperatorFormula() const;
61 virtual bool isTimeOperatorFormula() const;
62 virtual bool isProbabilityOperatorFormula() const;
63 virtual bool isRewardOperatorFormula() const;
64
65 // Atomic state formulas.
66 virtual bool isBooleanLiteralFormula() const;
67 virtual bool isTrueFormula() const;
68 virtual bool isFalseFormula() const;
69 virtual bool isAtomicExpressionFormula() const;
70 virtual bool isAtomicLabelFormula() const;
71
72 // Probability path formulas.
73 virtual bool isNextFormula() const;
74 virtual bool isUntilFormula() const;
75 virtual bool isBoundedUntilFormula() const;
76 virtual bool isGloballyFormula() const;
77 virtual bool isEventuallyFormula() const;
78 virtual bool isReachabilityProbabilityFormula() const;
79 virtual bool isHOAPathFormula() const;
80
81 // Reward formulas.
82 virtual bool isCumulativeRewardFormula() const;
83 virtual bool isInstantaneousRewardFormula() const;
84 virtual bool isReachabilityRewardFormula() const;
85 virtual bool isLongRunAverageRewardFormula() const;
86 virtual bool isTotalRewardFormula() const;
87
88 // Expected time formulas.
89 virtual bool isReachabilityTimeFormula() const;
90
91 // Game formulas.
92 virtual bool isGameFormula() const;
93
94 // Type checks for abstract intermediate classes.
95 virtual bool isBinaryPathFormula() const;
96 virtual bool isBinaryStateFormula() const;
97 virtual bool isUnaryPathFormula() const;
98 virtual bool isUnaryStateFormula() const;
99 bool isUnaryFormula() const;
100
101 // Accessors for the return type of a formula.
102 virtual bool hasQualitativeResult() const;
103 virtual bool hasQuantitativeResult() const;
104
105 bool isInFragment(FragmentSpecification const& fragment) const;
106 FormulaInformation info(bool recurseIntoOperators = true) const;
107
108 boost::any accept(FormulaVisitor const& visitor) const;
109 virtual boost::any accept(FormulaVisitor const& visitor, boost::any const& data) const = 0;
110
111 static std::shared_ptr<Formula const> getTrueFormula();
112
113 bool isInitialFormula() const;
114
116 PathFormula const& asPathFormula() const;
117
119 StateFormula const& asStateFormula() const;
120
123
125 QuantileFormula const& asQuantileFormula() const;
126
129
132
135
138
141
144
147
149 UntilFormula const& asUntilFormula() const;
150
152 HOAPathFormula const& asHOAPathFormula() const;
153
156
159
162
165
168
170 GameFormula const& asGameFormula() const;
171
173 GloballyFormula const& asGloballyFormula() const;
174
177
180
183
185 NextFormula const& asNextFormula() const;
186
189
192
195
198
201
204
207
210
212 OperatorFormula const& asOperatorFormula() const;
213
214 std::vector<std::shared_ptr<AtomicExpressionFormula const>> getAtomicExpressionFormulas() const;
215 std::vector<std::shared_ptr<AtomicLabelFormula const>> getAtomicLabelFormulas() const;
216 std::set<storm::expressions::Variable> getUsedVariables() const;
217 std::set<std::string> getReferencedRewardModels() const;
218
219 std::shared_ptr<Formula const> asSharedPointer();
220 std::shared_ptr<Formula const> asSharedPointer() const;
221
222 std::shared_ptr<Formula> clone() const;
223
224 std::shared_ptr<Formula> substitute(std::map<storm::expressions::Variable, storm::expressions::Expression> const& substitution) const;
225 std::shared_ptr<Formula> substitute(
226 std::function<storm::expressions::Expression(storm::expressions::Expression const&)> const& expressionSubstitution) const;
227 std::shared_ptr<Formula> substitute(std::map<std::string, storm::expressions::Expression> const& labelSubstitution) const;
228 std::shared_ptr<Formula> substitute(std::map<std::string, std::string> const& labelSubstitution) const;
229 std::shared_ptr<Formula> substituteRewardModelNames(std::map<std::string, std::string> const& rewardModelNameSubstitution) const;
230 std::shared_ptr<Formula> substituteTranscendentalNumbers() const;
231
242 std::map<std::string, storm::expressions::Expression> const& labelToExpressionMapping = {}) const;
243
244 std::string toString() const;
245
252 virtual std::ostream& writeToStream(std::ostream& out, bool allowParentheses = false) const = 0;
253
254 std::string toPrefixString() const;
255
256 virtual void gatherAtomicExpressionFormulas(std::vector<std::shared_ptr<AtomicExpressionFormula const>>& atomicExpressionFormulas) const;
257 virtual void gatherAtomicLabelFormulas(std::vector<std::shared_ptr<AtomicLabelFormula const>>& atomicLabelFormulas) const;
258 virtual void gatherReferencedRewardModels(std::set<std::string>& referencedRewardModels) const;
259 virtual void gatherUsedVariables(std::set<storm::expressions::Variable>& usedVariables) const;
260
261 private:
262 // Currently empty.
263};
264
265std::ostream& operator<<(std::ostream& out, Formula const& formula);
266} // namespace logic
267} // namespace storm
268
269#endif /* STORM_LOGIC_FORMULA_H_ */
This class is responsible for managing a set of typed variables and all expressions using these varia...
TotalRewardFormula & asTotalRewardFormula()
Definition Formula.cpp:429
HOAPathFormula & asHOAPathFormula()
Definition Formula.cpp:309
virtual bool isUnaryBooleanStateFormula() const
Definition Formula.cpp:48
RewardOperatorFormula & asRewardOperatorFormula()
Definition Formula.cpp:461
std::vector< std::shared_ptr< AtomicExpressionFormula const > > getAtomicExpressionFormulas() const
Definition Formula.cpp:477
virtual bool isReachabilityRewardFormula() const
Definition Formula.cpp:152
virtual bool isGloballyFormula() const
Definition Formula.cpp:96
virtual bool isUnaryPathFormula() const
Definition Formula.cpp:108
bool isInitialFormula() const
Definition Formula.cpp:209
virtual bool isFalseFormula() const
Definition Formula.cpp:68
virtual bool isProbabilityPathFormula() const
Definition Formula.cpp:120
GameFormula & asGameFormula()
Definition Formula.cpp:365
virtual bool isBooleanLiteralFormula() const
Definition Formula.cpp:60
virtual std::ostream & writeToStream(std::ostream &out, bool allowParentheses=false) const =0
Writes the forumla to the given output stream.
virtual bool isMultiObjectiveFormula() const
Definition Formula.cpp:28
virtual bool isBinaryPathFormula() const
Definition Formula.cpp:104
std::string toString() const
Definition Formula.cpp:572
storm::expressions::Expression toExpression(storm::expressions::ExpressionManager const &manager, std::map< std::string, storm::expressions::Expression > const &labelToExpressionMapping={}) const
Takes the formula and converts it to an equivalent expression.
Definition Formula.cpp:538
virtual bool isBinaryBooleanPathFormula() const
Definition Formula.cpp:52
UntilFormula & asUntilFormula()
Definition Formula.cpp:317
virtual bool isTrueFormula() const
Definition Formula.cpp:64
virtual bool isBinaryBooleanStateFormula() const
Definition Formula.cpp:44
virtual bool isRewardPathFormula() const
Definition Formula.cpp:124
virtual bool isNextFormula() const
Definition Formula.cpp:132
BoundedUntilFormula & asBoundedUntilFormula()
Definition Formula.cpp:325
virtual bool isInstantaneousRewardFormula() const
Definition Formula.cpp:148
virtual bool isUnaryStateFormula() const
Definition Formula.cpp:40
static std::shared_ptr< Formula const > getTrueFormula()
Definition Formula.cpp:205
virtual bool isReachabilityTimeFormula() const
Definition Formula.cpp:164
LongRunAverageOperatorFormula & asLongRunAverageOperatorFormula()
Definition Formula.cpp:405
virtual void gatherReferencedRewardModels(std::set< std::string > &referencedRewardModels) const
Definition Formula.cpp:564
virtual bool isOperatorFormula() const
Definition Formula.cpp:180
virtual bool isQuantileFormula() const
Definition Formula.cpp:32
virtual bool isReachabilityProbabilityFormula() const
Definition Formula.cpp:92
LongRunAverageRewardFormula & asLongRunAverageRewardFormula()
Definition Formula.cpp:445
BinaryBooleanStateFormula & asBinaryBooleanStateFormula()
Definition Formula.cpp:269
virtual bool isProbabilityOperatorFormula() const
Definition Formula.cpp:172
virtual bool isCumulativeRewardFormula() const
Definition Formula.cpp:144
ProbabilityOperatorFormula & asProbabilityOperatorFormula()
Definition Formula.cpp:453
std::vector< std::shared_ptr< AtomicLabelFormula const > > getAtomicLabelFormulas() const
Definition Formula.cpp:483
std::string toPrefixString() const
Definition Formula.cpp:582
BooleanLiteralFormula & asBooleanLiteralFormula()
Definition Formula.cpp:285
ConditionalFormula & asConditionalFormula()
Definition Formula.cpp:261
EventuallyFormula & asReachabilityTimeFormula()
Definition Formula.cpp:357
GloballyFormula & asGloballyFormula()
Definition Formula.cpp:373
OperatorFormula & asOperatorFormula()
Definition Formula.cpp:469
AtomicExpressionFormula & asAtomicExpressionFormula()
Definition Formula.cpp:293
virtual void gatherAtomicLabelFormulas(std::vector< std::shared_ptr< AtomicLabelFormula const > > &atomicLabelFormulas) const
Definition Formula.cpp:560
UnaryBooleanStateFormula & asUnaryBooleanStateFormula()
Definition Formula.cpp:277
StateFormula & asStateFormula()
Definition Formula.cpp:221
bool isUnaryFormula() const
Definition Formula.cpp:184
std::shared_ptr< Formula > substituteRewardModelNames(std::map< std::string, std::string > const &rewardModelNameSubstitution) const
Definition Formula.cpp:527
std::set< std::string > getReferencedRewardModels() const
Definition Formula.cpp:495
virtual bool isGameFormula() const
Definition Formula.cpp:168
virtual bool isUntilFormula() const
Definition Formula.cpp:80
virtual ~Formula()
Definition Formula.h:33
QuantileFormula & asQuantileFormula()
Definition Formula.cpp:237
virtual bool isRewardOperatorFormula() const
Definition Formula.cpp:176
virtual bool isPathFormula() const
Definition Formula.cpp:20
virtual bool isLongRunAverageRewardFormula() const
Definition Formula.cpp:156
EventuallyFormula & asEventuallyFormula()
Definition Formula.cpp:333
BinaryStateFormula & asBinaryStateFormula()
Definition Formula.cpp:245
virtual void gatherUsedVariables(std::set< storm::expressions::Variable > &usedVariables) const
Definition Formula.cpp:568
bool isInFragment(FragmentSpecification const &fragment) const
Definition Formula.cpp:196
virtual boost::any accept(FormulaVisitor const &visitor, boost::any const &data) const =0
PathFormula & asPathFormula()
Definition Formula.cpp:213
TimeOperatorFormula & asTimeOperatorFormula()
Definition Formula.cpp:413
UnaryPathFormula & asUnaryPathFormula()
Definition Formula.cpp:389
InstantaneousRewardFormula & asInstantaneousRewardFormula()
Definition Formula.cpp:437
virtual bool isLongRunAverageOperatorFormula() const
Definition Formula.cpp:136
virtual bool isBoundedUntilFormula() const
Definition Formula.cpp:84
NextFormula & asNextFormula()
Definition Formula.cpp:397
virtual bool isTimePathFormula() const
Definition Formula.cpp:128
std::shared_ptr< Formula > clone() const
Definition Formula.cpp:501
virtual bool isEventuallyFormula() const
Definition Formula.cpp:88
EventuallyFormula & asReachabilityRewardFormula()
Definition Formula.cpp:341
virtual bool hasQuantitativeResult() const
Definition Formula.cpp:192
virtual bool isHOAPathFormula() const
Definition Formula.cpp:100
virtual void gatherAtomicExpressionFormulas(std::vector< std::shared_ptr< AtomicExpressionFormula const > > &atomicExpressionFormulas) const
Definition Formula.cpp:556
virtual bool isConditionalRewardFormula() const
Definition Formula.cpp:116
virtual bool isTimeOperatorFormula() const
Definition Formula.cpp:140
std::set< storm::expressions::Variable > getUsedVariables() const
Definition Formula.cpp:489
virtual bool isStateFormula() const
Definition Formula.cpp:24
MultiObjectiveFormula & asMultiObjectiveFormula()
Definition Formula.cpp:229
virtual bool isTotalRewardFormula() const
Definition Formula.cpp:160
AtomicLabelFormula & asAtomicLabelFormula()
Definition Formula.cpp:301
CumulativeRewardFormula & asCumulativeRewardFormula()
Definition Formula.cpp:421
EventuallyFormula & asReachabilityProbabilityFormula()
Definition Formula.cpp:349
std::shared_ptr< Formula > substitute(std::map< storm::expressions::Variable, storm::expressions::Expression > const &substitution) const
Definition Formula.cpp:506
std::shared_ptr< Formula > substituteTranscendentalNumbers() const
Definition Formula.cpp:532
virtual bool isUnaryBooleanPathFormula() const
Definition Formula.cpp:56
UnaryStateFormula & asUnaryStateFormula()
Definition Formula.cpp:253
virtual bool isConditionalProbabilityFormula() const
Definition Formula.cpp:112
virtual bool isAtomicLabelFormula() const
Definition Formula.cpp:76
BinaryPathFormula & asBinaryPathFormula()
Definition Formula.cpp:381
virtual bool isBinaryStateFormula() const
Definition Formula.cpp:36
std::shared_ptr< Formula const > asSharedPointer()
Definition Formula.cpp:548
virtual bool isAtomicExpressionFormula() const
Definition Formula.cpp:72
virtual bool hasQualitativeResult() const
Definition Formula.cpp:188
friend std::ostream & operator<<(std::ostream &out, Formula const &formula)
Definition Formula.cpp:578
FormulaInformation info(bool recurseIntoOperators=true) const
Definition Formula.cpp:201
boost::any accept(FormulaVisitor const &visitor) const
Definition Formula.cpp:16
std::ostream & operator<<(std::ostream &out, Bound const &bound)
Definition Bound.h:40
LabParser.cpp.
Definition cli.cpp:18