Storm
A Modern Probabilistic Model Checker
Loading...
Searching...
No Matches
ToRationalFunctionVisitor.h
Go to the documentation of this file.
1#ifndef STORM_STORAGE_EXPRESSIONS_TORATIONALFUNCTIONVISITOR_H_
2#define STORM_STORAGE_EXPRESSIONS_TORATIONALFUNCTIONVISITOR_H_
3
4#include <unordered_map>
5
7
13
14namespace storm {
15namespace expressions {
16
17#ifdef STORM_HAVE_CARL
18template<typename RationalFunctionType>
19class ToRationalFunctionVisitor : public ExpressionVisitor {
20 public:
21 ToRationalFunctionVisitor(ExpressionEvaluatorBase<RationalFunctionType> const& evaluator);
22
23 RationalFunctionType toRationalFunction(Expression const& expression);
24
25 virtual boost::any visit(IfThenElseExpression const& expression, boost::any const& data) override;
26 virtual boost::any visit(BinaryBooleanFunctionExpression const& expression, boost::any const& data) override;
27 virtual boost::any visit(BinaryNumericalFunctionExpression const& expression, boost::any const& data) override;
28 virtual boost::any visit(BinaryRelationExpression const& expression, boost::any const& data) override;
29 virtual boost::any visit(VariableExpression const& expression, boost::any const& data) override;
30 virtual boost::any visit(UnaryBooleanFunctionExpression const& expression, boost::any const& data) override;
31 virtual boost::any visit(UnaryNumericalFunctionExpression const& expression, boost::any const& data) override;
32 virtual boost::any visit(BooleanLiteralExpression const& expression, boost::any const& data) override;
33 virtual boost::any visit(IntegerLiteralExpression const& expression, boost::any const& data) override;
34 virtual boost::any visit(RationalLiteralExpression const& expression, boost::any const& data) override;
35
36 void setMapping(storm::expressions::Variable const& variable, RationalFunctionType const& value);
37
38 private:
39 template<typename TP = typename RationalFunctionType::PolyType, carl::EnableIf<carl::needs_cache<TP>> = carl::dummy>
40 RationalFunctionType convertVariableToPolynomial(storm::RationalFunctionVariable const& variable) {
41 return RationalFunctionType(typename RationalFunctionType::PolyType(typename RationalFunctionType::PolyType::PolyType(variable), cache));
42 }
43
44 template<typename TP = typename RationalFunctionType::PolyType, carl::DisableIf<carl::needs_cache<TP>> = carl::dummy>
45 RationalFunctionType convertVariableToPolynomial(storm::RationalFunctionVariable const& variable) {
46 return RationalFunctionType(variable);
47 }
48
49 // A mapping from our variables to carl's.
50 std::unordered_map<storm::expressions::Variable, storm::RationalFunctionVariable> variableToVariableMap;
51
52 // The cache that is used in case the underlying type needs a cache.
53 std::shared_ptr<storm::RawPolynomialCache> cache;
54
55 // A mapping from variables to their values.
56 std::unordered_map<storm::expressions::Variable, RationalFunctionType> valueMapping;
57
58 // A reference to an expression evaluator (mainly for resolving the boolean condition in IfThenElse expressions)
59 ExpressionEvaluatorBase<RationalFunctionType> const& evaluator;
60};
61#endif
62} // namespace expressions
63} // namespace storm
64
65#endif /* STORM_STORAGE_EXPRESSIONS_TORATIONALFUNCTIONVISITOR_H_ */
LabParser.cpp.
Definition cli.cpp:18
carl::Variable RationalFunctionVariable