codegen.h
1 #ifndef SYMENGINE_CODEGEN_H
2 #define SYMENGINE_CODEGEN_H
3 
4 #include <symengine/printers.h>
5 #include <symengine/visitor.h>
6 #include <symengine/printers/strprinter.h>
7 #include <symengine/symengine_exception.h>
8 
9 namespace SymEngine
10 {
11 
12 class CodePrinter : public RewriteTrigVisitor<CodePrinter, StrPrinter>
13 {
14 public:
15  explicit CodePrinter(CodePrinterPrecision precision
16  = CodePrinterPrecision::Double);
17  using StrPrinter::apply;
18  using StrPrinter::bvisit;
19  using StrPrinter::str_;
20  void bvisit(const Basic &x);
21  void bvisit(const Complex &x);
22  void bvisit(const Dummy &x);
23  void bvisit(const Interval &x);
24  void bvisit(const Contains &x);
25  void bvisit(const Piecewise &x);
26  void bvisit(const BooleanAtom &x);
27  void bvisit(const And &x);
28  void bvisit(const Or &x);
29  void bvisit(const Xor &x);
30  void bvisit(const Not &x);
31  void bvisit(const Integer &x);
32  void bvisit(const Rational &x);
33  void bvisit(const EmptySet &x);
34  void bvisit(const FiniteSet &x);
35  void bvisit(const Reals &x);
36  void bvisit(const Rationals &x);
37  void bvisit(const Integers &x);
38  void bvisit(const UniversalSet &x);
39  void bvisit(const Abs &x);
40  void bvisit(const Ceiling &x);
41  void bvisit(const Truncate &x);
42  void bvisit(const Max &x);
43  void bvisit(const Min &x);
44  void bvisit(const Constant &x);
45  void bvisit(const NaN &x);
46  void bvisit(const Equality &x);
47  void bvisit(const Unequality &x);
48  void bvisit(const LessThan &x);
49  void bvisit(const StrictLessThan &x);
50  void bvisit(const Sign &x);
51  void bvisit(const UnevaluatedExpr &x);
52  void bvisit(const UnivariateSeries &x);
53  void bvisit(const Derivative &x);
54  void bvisit(const Subs &x);
55  void bvisit(const GaloisField &x);
56  void bvisit(const Function &x);
57  void bvisit(const RealDouble &x);
58 #ifdef HAVE_SYMENGINE_MPFR
59  void bvisit(const RealMPFR &x);
60 #endif
61 
62 protected:
63  CodePrinterPrecision precision_;
64  std::string print_scalar_literal(double d) const;
65  std::string print_math_function(const std::string &name) const;
66  virtual std::string
67  format_codegen_function_name(const std::string &name) const;
68  std::string print_binary_reduction(const vec_basic &args,
69  const std::string &func_name);
70  std::string print_binary_reduction_impl(vec_basic::const_iterator begin,
71  vec_basic::const_iterator end,
72  const std::string &func_name);
73 };
74 
75 class C89CodePrinter : public RewriteTrigVisitor<C89CodePrinter, CodePrinter>
76 {
77 public:
78  explicit C89CodePrinter(CodePrinterPrecision precision
79  = CodePrinterPrecision::Double);
80  using CodePrinter::apply;
81  using CodePrinter::bvisit;
82  using CodePrinter::str_;
83  void bvisit(const Infty &x);
84  void _print_pow(std::ostringstream &o, const RCP<const Basic> &a,
85  const RCP<const Basic> &b) override;
86 };
87 
88 class C99CodePrinter : public RewriteTrigVisitor<C99CodePrinter, C89CodePrinter>
89 {
90 public:
91  explicit C99CodePrinter(CodePrinterPrecision precision
92  = CodePrinterPrecision::Double);
93  using C89CodePrinter::apply;
94  using C89CodePrinter::bvisit;
95  using C89CodePrinter::str_;
96  void bvisit(const Infty &x);
97  void _print_pow(std::ostringstream &o, const RCP<const Basic> &a,
98  const RCP<const Basic> &b) override;
99  void bvisit(const Gamma &x);
100  void bvisit(const LogGamma &x);
101 };
102 
104  : public RewriteTrigVisitor<CudaCodePrinter, C99CodePrinter>
105 {
106 public:
107  explicit CudaCodePrinter(CodePrinterPrecision precision
108  = CodePrinterPrecision::Double);
109  using C99CodePrinter::apply;
110  using C99CodePrinter::bvisit;
111  using C99CodePrinter::str_;
112  void bvisit(const Integer &x);
113  void bvisit(const Constant &x);
114  void bvisit(const NaN &x);
115  void bvisit(const Infty &x);
116 };
117 
119  : public RewriteTrigVisitor<MetalCodePrinter, CodePrinter>
120 {
121 public:
122  explicit MetalCodePrinter(CodePrinterPrecision precision
123  = CodePrinterPrecision::Float);
124  using CodePrinter::apply;
125  using CodePrinter::bvisit;
126  using CodePrinter::str_;
127  void bvisit(const Constant &x);
128  void bvisit(const NaN &x);
129  void bvisit(const Infty &x);
130  void bvisit(const Abs &x);
131  void bvisit(const Ceiling &x);
132  void bvisit(const Truncate &x);
133  void bvisit(const Max &x);
134  void bvisit(const Min &x);
135  void _print_pow(std::ostringstream &o, const RCP<const Basic> &a,
136  const RCP<const Basic> &b) override;
137 
138 protected:
139  std::string
140  format_codegen_function_name(const std::string &name) const override;
141 };
142 
143 class JSCodePrinter : public RewriteTrigVisitor<JSCodePrinter, CodePrinter>
144 {
145 public:
146  using CodePrinter::apply;
147  using CodePrinter::bvisit;
148  using CodePrinter::str_;
149  void bvisit(const Constant &x);
150  void _print_pow(std::ostringstream &o, const RCP<const Basic> &a,
151  const RCP<const Basic> &b) override;
152  void bvisit(const Abs &x);
153  void bvisit(const Sin &x);
154  void bvisit(const Cos &x);
155  void bvisit(const Max &x);
156  void bvisit(const Min &x);
157 
158 protected:
159  std::string
160  format_codegen_function_name(const std::string &name) const override;
161 };
162 } // namespace SymEngine
163 
164 #endif // SYMENGINE_CODEGEN_H
The lowest unit of symbolic representation.
Definition: basic.h:97
Complex Class.
Definition: complex.h:33
Integer Class.
Definition: integer.h:19
Rational Class.
Definition: rational.h:16
RealDouble Class to hold double values.
Definition: real_double.h:20
UnivariateSeries Class.
Main namespace for SymEngine package.
Definition: add.cpp:19