Storm
A Modern Probabilistic Model Checker
Loading...
Searching...
No Matches
Formula.cpp
Go to the documentation of this file.
1#include <boost/any.hpp>
2#include <sstream>
4
13
14namespace storm {
15namespace logic {
16boost::any Formula::accept(FormulaVisitor const& visitor) const {
17 return accept(visitor, boost::any());
18}
19
21 return false;
22}
23
25 return false;
26}
27
29 return false;
30}
31
33 return false;
34}
35
37 return false;
38}
39
41 return false;
42}
43
45 return false;
46}
47
49 return false;
50}
51
53 return false;
54}
55
57 return false;
58}
59
61 return false;
62}
63
65 return false;
66}
67
69 return false;
70}
71
73 return false;
74}
75
77 return false;
78}
79
81 return false;
82}
83
85 return false;
86}
87
89 return false;
90}
91
93 return false;
94}
95
97 return false;
98}
99
101 return false;
102}
103
105 return false;
106}
107
109 return false;
110}
111
113 return false;
114}
115
117 return false;
118}
119
121 return false;
122}
123
125 return false;
126}
127
129 return false;
130}
131
133 return false;
134}
135
137 return false;
138}
139
141 return false;
142}
143
145 return false;
146}
147
149 return false;
150}
151
153 return false;
154}
155
157 return false;
158}
159
161 return false;
162}
163
165 return false;
166}
167
169 return false;
170}
171
173 return false;
174}
175
177 return false;
178}
179
181 return false;
182}
183
187
189 return true;
190}
191
193 return false;
194}
195
196bool Formula::isInFragment(FragmentSpecification const& fragment) const {
197 FragmentChecker checker;
198 return checker.conformsToSpecification(*this, fragment);
199}
200
201FormulaInformation Formula::info(bool recurseIntoOperators) const {
202 return FormulaInformationVisitor::getInformation(*this, recurseIntoOperators);
203}
204
205std::shared_ptr<Formula const> Formula::getTrueFormula() {
206 return std::shared_ptr<Formula const>(new BooleanLiteralFormula(true));
207}
208
210 return this->isAtomicLabelFormula() && this->asAtomicLabelFormula().getLabel() == "init";
211}
212
214 return dynamic_cast<PathFormula&>(*this);
215}
216
218 return dynamic_cast<PathFormula const&>(*this);
219}
220
222 return dynamic_cast<StateFormula&>(*this);
223}
224
226 return dynamic_cast<StateFormula const&>(*this);
227}
228
232
234 return dynamic_cast<MultiObjectiveFormula const&>(*this);
235}
236
238 return dynamic_cast<QuantileFormula&>(*this);
239}
240
242 return dynamic_cast<QuantileFormula const&>(*this);
243}
244
246 return dynamic_cast<BinaryStateFormula&>(*this);
247}
248
250 return dynamic_cast<BinaryStateFormula const&>(*this);
251}
252
254 return dynamic_cast<UnaryStateFormula&>(*this);
255}
256
258 return dynamic_cast<UnaryStateFormula const&>(*this);
259}
260
262 return dynamic_cast<ConditionalFormula&>(*this);
263}
264
266 return dynamic_cast<ConditionalFormula const&>(*this);
267}
268
272
274 return dynamic_cast<BinaryBooleanStateFormula const&>(*this);
275}
276
280
282 return dynamic_cast<UnaryBooleanStateFormula const&>(*this);
283}
284
288
290 return dynamic_cast<BooleanLiteralFormula const&>(*this);
291}
292
296
298 return dynamic_cast<AtomicExpressionFormula const&>(*this);
299}
300
302 return dynamic_cast<AtomicLabelFormula&>(*this);
303}
304
306 return dynamic_cast<AtomicLabelFormula const&>(*this);
307}
308
310 return dynamic_cast<HOAPathFormula&>(*this);
311}
312
314 return dynamic_cast<HOAPathFormula const&>(*this);
315}
316
318 return dynamic_cast<UntilFormula&>(*this);
319}
320
322 return dynamic_cast<UntilFormula const&>(*this);
323}
324
328
330 return dynamic_cast<BoundedUntilFormula const&>(*this);
331}
332
334 return dynamic_cast<EventuallyFormula&>(*this);
335}
336
338 return dynamic_cast<EventuallyFormula const&>(*this);
339}
340
344
346 return dynamic_cast<EventuallyFormula const&>(*this);
347}
348
352
354 return dynamic_cast<EventuallyFormula const&>(*this);
355}
356
360
362 return dynamic_cast<EventuallyFormula const&>(*this);
363}
364
366 return dynamic_cast<GameFormula&>(*this);
367}
368
370 return dynamic_cast<GameFormula const&>(*this);
371}
372
374 return dynamic_cast<GloballyFormula&>(*this);
375}
376
378 return dynamic_cast<GloballyFormula const&>(*this);
379}
380
382 return dynamic_cast<BinaryPathFormula&>(*this);
383}
384
386 return dynamic_cast<BinaryPathFormula const&>(*this);
387}
388
390 return dynamic_cast<UnaryPathFormula&>(*this);
391}
392
394 return dynamic_cast<UnaryPathFormula const&>(*this);
395}
396
398 return dynamic_cast<NextFormula&>(*this);
399}
400
402 return dynamic_cast<NextFormula const&>(*this);
403}
404
408
412
416
418 return dynamic_cast<TimeOperatorFormula const&>(*this);
419}
420
424
426 return dynamic_cast<CumulativeRewardFormula const&>(*this);
427}
428
430 return dynamic_cast<TotalRewardFormula&>(*this);
431}
432
434 return dynamic_cast<TotalRewardFormula const&>(*this);
435}
436
440
442 return dynamic_cast<InstantaneousRewardFormula const&>(*this);
443}
444
448
450 return dynamic_cast<LongRunAverageRewardFormula const&>(*this);
451}
452
456
458 return dynamic_cast<ProbabilityOperatorFormula const&>(*this);
459}
460
464
466 return dynamic_cast<RewardOperatorFormula const&>(*this);
467}
468
470 return dynamic_cast<OperatorFormula&>(*this);
471}
472
474 return dynamic_cast<OperatorFormula const&>(*this);
475}
476
477std::vector<std::shared_ptr<AtomicExpressionFormula const>> Formula::getAtomicExpressionFormulas() const {
478 std::vector<std::shared_ptr<AtomicExpressionFormula const>> result;
479 this->gatherAtomicExpressionFormulas(result);
480 return result;
481}
482
483std::vector<std::shared_ptr<AtomicLabelFormula const>> Formula::getAtomicLabelFormulas() const {
484 std::vector<std::shared_ptr<AtomicLabelFormula const>> result;
485 this->gatherAtomicLabelFormulas(result);
486 return result;
487}
488
489std::set<storm::expressions::Variable> Formula::getUsedVariables() const {
490 std::set<storm::expressions::Variable> usedVariables;
491 this->gatherUsedVariables(usedVariables);
492 return usedVariables;
493}
494
495std::set<std::string> Formula::getReferencedRewardModels() const {
496 std::set<std::string> referencedRewardModels;
497 this->gatherReferencedRewardModels(referencedRewardModels);
498 return referencedRewardModels;
499}
500
501std::shared_ptr<Formula> Formula::clone() const {
502 CloneVisitor cv;
503 return cv.clone(*this);
504}
505
506std::shared_ptr<Formula> Formula::substitute(std::map<storm::expressions::Variable, storm::expressions::Expression> const& substitution) const {
508 return substitute([&v](storm::expressions::Expression const& exp) { return v.substitute(exp); });
509}
510
511std::shared_ptr<Formula> Formula::substitute(
512 std::function<storm::expressions::Expression(storm::expressions::Expression const&)> const& expressionSubstitution) const {
514 return visitor.substitute(*this, expressionSubstitution);
515}
516
517std::shared_ptr<Formula> Formula::substitute(std::map<std::string, storm::expressions::Expression> const& labelSubstitution) const {
518 LabelSubstitutionVisitor visitor(labelSubstitution);
519 return visitor.substitute(*this);
520}
521
522std::shared_ptr<Formula> Formula::substitute(std::map<std::string, std::string> const& labelSubstitution) const {
523 LabelSubstitutionVisitor visitor(labelSubstitution);
524 return visitor.substitute(*this);
525}
526
527std::shared_ptr<Formula> Formula::substituteRewardModelNames(std::map<std::string, std::string> const& rewardModelNameSubstitution) const {
528 RewardModelNameSubstitutionVisitor visitor(rewardModelNameSubstitution);
529 return visitor.substitute(*this);
530}
531
532std::shared_ptr<Formula> Formula::substituteTranscendentalNumbers() const {
533 using SubMap = std::map<storm::expressions::Variable, storm::expressions::Expression>;
534 storm::expressions::JaniExpressionSubstitutionVisitor<SubMap> transcendentalsVisitor(SubMap(), true);
535 return substitute([&transcendentalsVisitor](storm::expressions::Expression const& exp) { return transcendentalsVisitor.substitute(exp); });
536}
537
539 std::map<std::string, storm::expressions::Expression> const& labelToExpressionMapping) const {
540 ToExpressionVisitor visitor;
541 if (labelToExpressionMapping.empty()) {
542 return visitor.toExpression(*this, manager);
543 } else {
544 return visitor.toExpression(*this->substitute(labelToExpressionMapping), manager);
545 }
546}
547
548std::shared_ptr<Formula const> Formula::asSharedPointer() {
549 return this->shared_from_this();
550}
551
552std::shared_ptr<Formula const> Formula::asSharedPointer() const {
553 return this->shared_from_this();
554}
555
556void Formula::gatherAtomicExpressionFormulas(std::vector<std::shared_ptr<AtomicExpressionFormula const>>&) const {
557 return;
558}
559
560void Formula::gatherAtomicLabelFormulas(std::vector<std::shared_ptr<AtomicLabelFormula const>>&) const {
561 return;
562}
563
564void Formula::gatherReferencedRewardModels(std::set<std::string>&) const {
565 return;
566}
567
568void Formula::gatherUsedVariables(std::set<storm::expressions::Variable>&) const {
569 return;
570}
571
572std::string Formula::toString() const {
573 std::stringstream str2;
574 writeToStream(str2);
575 return str2.str();
576}
577
578std::ostream& operator<<(std::ostream& out, Formula const& formula) {
579 return formula.writeToStream(out);
580}
581
582std::string Formula::toPrefixString() const {
583 ToPrefixStringVisitor visitor;
584 return visitor.toPrefixString(*this);
585}
586
587} // namespace logic
588} // namespace storm
This class is responsible for managing a set of typed variables and all expressions using these varia...
Expression substitute(Expression const &expression)
Substitutes the identifiers in the given expression according to the previously given map and returns...
std::string const & getLabel() const
std::shared_ptr< Formula > clone(Formula const &f) const
std::shared_ptr< Formula > substitute(Formula const &f, std::function< storm::expressions::Expression(storm::expressions::Expression const &)> const &substitutionFunction) const
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
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
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
FormulaInformation info(bool recurseIntoOperators=true) const
Definition Formula.cpp:201
boost::any accept(FormulaVisitor const &visitor) const
Definition Formula.cpp:16
static FormulaInformation getInformation(Formula const &f, bool recurseIntoOperators=true)
bool conformsToSpecification(Formula const &f, FragmentSpecification const &specification) const
std::shared_ptr< Formula > substitute(Formula const &f) const
std::shared_ptr< Formula > substitute(Formula const &f) const
storm::expressions::Expression toExpression(Formula const &f, storm::expressions::ExpressionManager const &manager) const
std::string toPrefixString(Formula const &f) const
std::ostream & operator<<(std::ostream &out, Bound const &bound)
Definition Bound.h:40
LabParser.cpp.
Definition cli.cpp:18