MicroModelicaCCompiler  4.5.3
equation_printer.hpp
Go to the documentation of this file.
1 /*****************************************************************************
2 
3  This file is part of QSS Solver.
4 
5  QSS Solver is free software: you can redistribute it and/or modify
6  it under the terms of the GNU General Public License as published by
7  the Free Software Foundation, either version 3 of the License, or
8  (at your option) any later version.
9 
10  QSS Solver is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU General Public License for more details.
14 
15  You should have received a copy of the GNU General Public License
16  along with QSS Solver. If not, see <http://www.gnu.org/licenses/>.
17 
18  ******************************************************************************/
19 
20 #pragma once
21 
22 #include <ast/ast_types.hpp>
23 #include <ir/helpers.hpp>
24 #include <ir/index.hpp>
25 #include <util/table.hpp>
26 
27 namespace MicroModelica {
28 namespace Util {
30 }
31 
32 namespace IR {
33 
34 class Equation;
35 
36 class EquationPrinter {
37  public:
38  EquationPrinter(Equation eq);
39  virtual ~EquationPrinter() = default;
40  virtual std::string print() const { return ""; };
41  virtual std::string macro() const { return ""; };
42  std::string identifier() const { return _identifier; };
43  std::string algCode() const { return _alg_code; }
44  std::string prefix() const;
45  std::string lhs(int order = 0) const;
46  virtual std::string equationId() const;
48  std::multimap<std::string, int> usedVariables() const;
49 
50  protected:
51  void setup(Equation eq);
52 
53  private:
54  std::string _identifier;
55  int _id;
56  int _type;
58  std::string _alg_code;
60  std::multimap<std::string, int> _used_variables;
61 };
62 
64 
65 class DerivativePrinter : public EquationPrinter {
66  public:
68  ~DerivativePrinter() = default;
69  std::string print() const override;
70  std::string macro() const override;
71  inline void factorialInit(int fact_init) { _fact_init = fact_init; };
72 
73  protected:
75  std::string generateDerivatives(std::string tabs, int init = 1) const;
76 
77  private:
79  int _fact_init;
80  int _id;
84 };
85 
86 class ClassicPrinter : public DerivativePrinter {
87  public:
89  ~ClassicPrinter() = default;
90  std::string print() const override;
91 
92  private:
95 };
96 
98  public:
100  ~OutputPrinter() = default;
101 
102  std::string print() const override;
103  std::string equationId() const override;
104 
105  private:
106  int _id;
109 };
110 
112  public:
114  ~AlgebraicPrinter() = default;
115  std::string print() const override;
116  std::string equationId() const override;
117 
118  private:
122  int _id;
123 };
124 
126  public:
128  ~DependencyPrinter() = default;
129  std::string print() const override;
130 
131  protected:
132  std::string beginParallelMap(std::string& tabs) const;
133  std::string endParallelMap() const;
134 
135  private:
140  bool _parallel;
141 };
142 
143 class ZeroCrossingPrinter : public DerivativePrinter {
144  public:
146  ~ZeroCrossingPrinter() = default;
147  std::string equationId() const override;
148 
149  private:
150  int _id;
151 };
152 
153 } // namespace IR
154 } // namespace MicroModelica
MicroModelica::IR::AlgebraicPrinter::_rhs
Expression _rhs
Definition: equation_printer.hpp:137
MicroModelica::IR::DerivativePrinter::_fact_init
int _fact_init
Definition: equation_printer.hpp:96
MicroModelica::IR::DependencyPrinter
Definition: equation_printer.hpp:142
ModelTable< std::string, std::string >
MicroModelica::IR::DerivativePrinter::_lhs
Expression _lhs
Definition: equation_printer.hpp:99
MicroModelica::IR::OutputPrinter::_rhs
Expression _rhs
Definition: equation_printer.hpp:125
MicroModelica::IR::DerivativePrinter::~DerivativePrinter
~DerivativePrinter()=default
MicroModelica::IR::EquationPrinter::_used_variables
std::multimap< std::string, int > _used_variables
Definition: equation_printer.hpp:77
MicroModelica::IR::DerivativePrinter::generateDerivatives
std::string generateDerivatives(std::string tabs, int init=1) const
Definition: equation_printer.cpp:208
MicroModelica::IR::DerivativePrinter::factorialInit
void factorialInit(int fact_init)
Definition: equation_printer.hpp:88
index.hpp
MicroModelica::IR::AlgebraicPrinter::AlgebraicPrinter
AlgebraicPrinter(Equation eq)
Definition: equation_printer.cpp:305
MicroModelica::IR::EquationPrinter::_alg_code
std::string _alg_code
Definition: equation_printer.hpp:75
MicroModelica::IR::AlgebraicPrinter::equationId
std::string equationId() const override
Definition: equation_printer.cpp:333
MicroModelica::IR::EquationPrinter::_return_stm
FUNCTION_PRINTER::ReturnStatementType _return_stm
Definition: equation_printer.hpp:76
MicroModelica::IR::DerivativePrinter
Definition: equation_printer.hpp:82
MicroModelica::IR::ClassicPrinter::ClassicPrinter
ClassicPrinter(Equation eq)
Definition: equation_printer.cpp:258
MicroModelica::IR::DependencyPrinter::endParallelMap
std::string endParallelMap() const
Definition: equation_printer.cpp:359
MicroModelica::IR::ZeroCrossingPrinter::equationId
std::string equationId() const override
Definition: equation_printer.cpp:404
MicroModelica::IR::AlgebraicPrinter::_lhs
Expression _lhs
Definition: equation_printer.hpp:138
MicroModelica::IR::DerivativePrinter::_range
Option< Range > _range
Definition: equation_printer.hpp:98
MicroModelica::IR::ClassicPrinter::~ClassicPrinter
~ClassicPrinter()=default
MicroModelica::IR::AlgebraicPrinter::_id
int _id
Definition: equation_printer.hpp:139
MicroModelica::IR::EquationPrinter::lhs
std::string lhs(int order=0) const
Definition: equation_printer.cpp:116
MicroModelica::IR::getPrinter
EquationPrinter * getPrinter(Equation eq)
Definition: equation_printer.cpp:64
MicroModelica::IR::OutputPrinter::~OutputPrinter
~OutputPrinter()=default
MicroModelica::IR::AlgebraicPrinter::_range
Option< Range > _range
Definition: equation_printer.hpp:136
MicroModelica::IR::DependencyPrinter::_range
Option< Range > _range
Definition: equation_printer.hpp:154
MicroModelica::IR::OutputPrinter::equationId
std::string equationId() const override
Definition: equation_printer.cpp:277
helpers.hpp
Option
Definition: util_types.hpp:32
MicroModelica::IR::EquationPrinter::_identifier
std::string _identifier
Definition: equation_printer.hpp:71
MicroModelica::IR::AlgebraicPrinter
Definition: equation_printer.hpp:128
MicroModelica::IR::EquationPrinter::returnStm
FUNCTION_PRINTER::ReturnStatementType returnStm() const
Definition: equation_printer.cpp:105
MicroModelica::IR::DependencyPrinter::print
std::string print() const override
Definition: equation_printer.cpp:369
MicroModelica::IR::DependencyPrinter::_usage
Index _usage
Definition: equation_printer.hpp:153
MicroModelica::IR::OutputPrinter::_range
Option< Range > _range
Definition: equation_printer.hpp:124
MicroModelica::IR::DerivativePrinter::_id
int _id
Definition: equation_printer.hpp:97
MicroModelica::IR::DerivativePrinter::print
std::string print() const override
Definition: equation_printer.cpp:236
MicroModelica::Util::SymbolTable
ModelTable< std::string, std::string > SymbolTable
Definition: equation.hpp:62
MicroModelica::IR::Expression
Definition: expression.hpp:64
MicroModelica::IR::EquationPrinter::print
virtual std::string print() const
Definition: equation_printer.hpp:57
MicroModelica::IR::DerivativePrinter::_derivatives
Expression _derivatives[3]
Definition: equation_printer.hpp:95
MicroModelica::IR::ZeroCrossingPrinter::_id
int _id
Definition: equation_printer.hpp:167
MicroModelica::IR::EquationPrinter::EquationPrinter
EquationPrinter(Equation eq)
Definition: equation_printer.cpp:82
MicroModelica::IR::OutputPrinter::_id
int _id
Definition: equation_printer.hpp:123
MicroModelica::IR::OutputPrinter::print
std::string print() const override
Definition: equation_printer.cpp:284
MicroModelica::IR::ZeroCrossingPrinter::ZeroCrossingPrinter
ZeroCrossingPrinter(Equation eq)
Definition: equation_printer.cpp:402
MicroModelica::IR::EquationPrinter::_lhs
Expression _lhs
Definition: equation_printer.hpp:74
MicroModelica::IR::Equation
Definition: equation.hpp:67
MicroModelica::IR::EquationPrinter::setup
void setup(Equation eq)
Definition: equation_printer.cpp:87
MicroModelica::IR::ClassicPrinter::print
std::string print() const override
Definition: equation_printer.cpp:260
MicroModelica::IR::DerivativePrinter::_rhs
Expression _rhs
Definition: equation_printer.hpp:100
MicroModelica::IR::DependencyPrinter::_rhs
Expression _rhs
Definition: equation_printer.hpp:155
MicroModelica::IR::EquationPrinter::equationId
virtual std::string equationId() const
Definition: equation_printer.cpp:109
MicroModelica::IR::DerivativePrinter::initializeDerivatives
void initializeDerivatives()
Definition: equation_printer.cpp:194
MicroModelica::IR::ClassicPrinter::_range
Option< Range > _range
Definition: equation_printer.hpp:110
MicroModelica::IR::OutputPrinter
Definition: equation_printer.hpp:114
MicroModelica::IR::ClassicPrinter::_rhs
Expression _rhs
Definition: equation_printer.hpp:111
MicroModelica::IR::EquationPrinter::identifier
std::string identifier() const
Definition: equation_printer.hpp:59
MicroModelica::IR::Index
Definition: index.hpp:92
MicroModelica::IR::ClassicPrinter
Definition: equation_printer.hpp:103
MicroModelica
Definition: files.cpp:45
MicroModelica::IR::EquationPrinter::_type
int _type
Definition: equation_printer.hpp:73
MicroModelica::IR::DependencyPrinter::DependencyPrinter
DependencyPrinter(Equation eq)
Definition: equation_printer.cpp:340
MicroModelica::IR::DependencyPrinter::_parallel
bool _parallel
Definition: equation_printer.hpp:157
MicroModelica::IR::ZeroCrossingPrinter::~ZeroCrossingPrinter
~ZeroCrossingPrinter()=default
MicroModelica::IR::EquationPrinter::_id
int _id
Definition: equation_printer.hpp:72
MicroModelica::IR::DependencyPrinter::~DependencyPrinter
~DependencyPrinter()=default
table.hpp
ast_types.hpp
MicroModelica::IR::EquationPrinter
Definition: equation_printer.hpp:53
MicroModelica::IR::DependencyPrinter::beginParallelMap
std::string beginParallelMap(std::string &tabs) const
Definition: equation_printer.cpp:348
MicroModelica::IR::EquationPrinter::macro
virtual std::string macro() const
Definition: equation_printer.hpp:58
MicroModelica::IR::AlgebraicPrinter::print
std::string print() const override
Definition: equation_printer.cpp:310
MicroModelica::IR::DerivativePrinter::macro
std::string macro() const override
Definition: equation_printer.cpp:170
MicroModelica::IR::DependencyPrinter::_var_idx
Index _var_idx
Definition: equation_printer.hpp:156
MicroModelica::IR::DerivativePrinter::DerivativePrinter
DerivativePrinter(Equation eq)
Definition: equation_printer.cpp:164
MicroModelica::IR::OutputPrinter::OutputPrinter
OutputPrinter(Equation eq)
Definition: equation_printer.cpp:275
MicroModelica::IR::EquationPrinter::~EquationPrinter
virtual ~EquationPrinter()=default
MicroModelica::IR::EquationPrinter::prefix
std::string prefix() const
Definition: equation_printer.cpp:145
MicroModelica::IR::EquationPrinter::usedVariables
std::multimap< std::string, int > usedVariables() const
Definition: equation_printer.cpp:107
MicroModelica::IR::ZeroCrossingPrinter
Definition: equation_printer.hpp:160
MicroModelica::IR::AlgebraicPrinter::~AlgebraicPrinter
~AlgebraicPrinter()=default
MicroModelica::IR::EquationPrinter::algCode
std::string algCode() const
Definition: equation_printer.hpp:60
MicroModelica::IR::FUNCTION_PRINTER::ReturnStatementType
ReturnStatementType
Definition: helpers.hpp:144