gem5  v20.1.0.0
mathexpr.hh
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2016, 2020 ARM Limited
3  * All rights reserved
4  *
5  * The license below extends only to copyright in the software and shall
6  * not be construed as granting a license to any other intellectual
7  * property including but not limited to intellectual property relating
8  * to a hardware implementation of the functionality of the software
9  * licensed hereunder. You may use the software subject to the license
10  * terms below provided that you ensure that this notice is replicated
11  * unmodified and in its entirety in all distributions of the software,
12  * modified or unmodified, in source code or in binary form.
13  *
14  * Redistribution and use in source and binary forms, with or without
15  * modification, are permitted provided that the following conditions are
16  * met: redistributions of source code must retain the above copyright
17  * notice, this list of conditions and the following disclaimer;
18  * redistributions in binary form must reproduce the above copyright
19  * notice, this list of conditions and the following disclaimer in the
20  * documentation and/or other materials provided with the distribution;
21  * neither the name of the copyright holders nor the names of its
22  * contributors may be used to endorse or promote products derived from
23  * this software without specific prior written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  */
37 
38 #ifndef __SIM_MATHEXPR_HH__
39 #define __SIM_MATHEXPR_HH__
40 
41 #include <algorithm>
42 #include <array>
43 #include <functional>
44 #include <string>
45 #include <vector>
46 
47 class MathExpr {
48  public:
49 
50  MathExpr(std::string expr);
51 
52  typedef std::function<double(std::string)> EvalCallback;
53 
59  std::string toStr() const { return toStr(root, ""); }
60 
68  double eval(EvalCallback fn) const { return eval(root, fn); }
69 
80  {
82  getVariables(root, vars);
83  return vars;
84  }
85 
86  private:
87  enum Operator {
89  };
90 
91  // Match operators
92  const int MAX_PRIO = 4;
93  typedef double (*binOp)(double, double);
94  struct OpSearch {
95  bool binary;
97  int priority;
98  char c;
100  };
101 
103  std::array<OpSearch, uNeg + 1> ops;
104 
105  class Node {
106  public:
107  Node() : op(nInvalid), l(0), r(0), value(0) {}
108  std::string toStr() const {
109  const char opStr[] = {'+', '-', '*', '/', '^', '-'};
110  switch (op) {
111  case nInvalid:
112  return "INVALID";
113  case sVariable:
114  return variable;
115  case sValue:
116  return std::to_string(value);
117  default:
118  return std::string(1, opStr[op]);
119  };
120  }
121 
123  Node *l, *r;
124  double value;
125  std::string variable;
126  };
127 
130 
132  Node *parse(std::string expr);
133 
135  std::string toStr(Node *n, std::string prefix) const;
136 
138  double eval(const Node *n, EvalCallback fn) const;
139 
142  void getVariables(const Node *n, std::vector<std::string> &vars) const;
143 };
144 
145 #endif
MathExpr::bMul
@ bMul
Definition: mathexpr.hh:88
MathExpr::MAX_PRIO
const int MAX_PRIO
Definition: mathexpr.hh:92
MathExpr::nInvalid
@ nInvalid
Definition: mathexpr.hh:88
MathExpr::OpSearch::c
char c
Definition: mathexpr.hh:98
MathExpr::Node::variable
std::string variable
Definition: mathexpr.hh:125
MathExpr::OpSearch
Definition: mathexpr.hh:94
MathExpr::bDiv
@ bDiv
Definition: mathexpr.hh:88
sc_dt::to_string
const std::string to_string(sc_enc enc)
Definition: sc_fxdefs.cc:91
std::vector< std::string >
MathExpr::sVariable
@ sVariable
Definition: mathexpr.hh:88
MathExpr::MathExpr
MathExpr(std::string expr)
Definition: mathexpr.cc:47
MathExpr::getVariables
std::vector< std::string > getVariables() const
Return all variables in the this expression.
Definition: mathexpr.hh:79
MathExpr
Definition: mathexpr.hh:47
MathExpr::parse
Node * parse(std::string expr)
Parse and create nodes from string.
Definition: mathexpr.cc:75
ArmISA::n
Bitfield< 31 > n
Definition: miscregs_types.hh:450
MathExpr::Node::r
Node * r
Definition: mathexpr.hh:123
MathExpr::toStr
std::string toStr() const
Prints an ASCII representation of the expression tree.
Definition: mathexpr.hh:59
MathExpr::Node::op
Operator op
Definition: mathexpr.hh:122
MathExpr::OpSearch::op
Operator op
Definition: mathexpr.hh:96
MathExpr::uNeg
@ uNeg
Definition: mathexpr.hh:88
MathExpr::bAdd
@ bAdd
Definition: mathexpr.hh:88
MathExpr::Node::value
double value
Definition: mathexpr.hh:124
MathExpr::Node::Node
Node()
Definition: mathexpr.hh:107
MathExpr::bSub
@ bSub
Definition: mathexpr.hh:88
MathExpr::OpSearch::binary
bool binary
Definition: mathexpr.hh:95
MathExpr::Node::toStr
std::string toStr() const
Definition: mathexpr.hh:108
MathExpr::binOp
double(* binOp)(double, double)
Definition: mathexpr.hh:93
MathExpr::OpSearch::fn
binOp fn
Definition: mathexpr.hh:99
ArmISA::fn
Bitfield< 18, 16 > fn
Definition: types.hh:158
MathExpr::ops
std::array< OpSearch, uNeg+1 > ops
Operator list.
Definition: mathexpr.hh:103
MathExpr::Operator
Operator
Definition: mathexpr.hh:87
MathExpr::eval
double eval(EvalCallback fn) const
Evaluates the expression.
Definition: mathexpr.hh:68
MathExpr::bPow
@ bPow
Definition: mathexpr.hh:88
MathExpr::sValue
@ sValue
Definition: mathexpr.hh:88
MathExpr::OpSearch::priority
int priority
Definition: mathexpr.hh:97
MathExpr::Node
Definition: mathexpr.hh:105
MathExpr::Node::l
Node * l
Definition: mathexpr.hh:123
MathExpr::EvalCallback
std::function< double(std::string)> EvalCallback
Definition: mathexpr.hh:52
MathExpr::root
Node * root
Root node.
Definition: mathexpr.hh:129

Generated on Wed Sep 30 2020 14:02:14 for gem5 by doxygen 1.8.17