Numworks Epsilon  1.4.1
Graphing Calculator Operating System
matrix_inverse.h
Go to the documentation of this file.
1 #ifndef POINCARE_MATRIX_INVERSE_H
2 #define POINCARE_MATRIX_INVERSE_H
3 
6 #include <poincare/complex.h>
7 
8 namespace Poincare {
9 
10 class MatrixInverse : public StaticHierarchy<1> {
12 public:
13  Type type() const override;
14  Expression * clone() const override;
15 private:
16  /* Evaluation */
17  ExpressionLayout * privateCreateLayout(PrintFloat::Mode floatDisplayMode, ComplexFormat complexFormat) const override {
18  return LayoutEngine::createPrefixLayout(this, floatDisplayMode, complexFormat, name());
19  }
20  int writeTextInBuffer(char * buffer, int bufferSize, int numberOfSignificantDigits = PrintFloat::k_numberOfStoredSignificantDigits) const override {
21  return LayoutEngine::writePrefixExpressionTextInBuffer(this, buffer, bufferSize, numberOfSignificantDigits, name());
22  }
23  const char * name() const { return "inverse"; }
24  /* Simplification */
25  Expression * shallowReduce(Context & context, AngleUnit angleUnit) override;
26  /* Evaluation */
27  Expression * privateApproximate(SinglePrecision p, Context& context, AngleUnit angleUnit) const override { return templatedApproximate<float>(context, angleUnit); }
28  Expression * privateApproximate(DoublePrecision p, Context& context, AngleUnit angleUnit) const override { return templatedApproximate<double>(context, angleUnit); }
29  template<typename T> Expression * templatedApproximate(Context& context, AngleUnit angleUnit) const;
30 };
31 
32 }
33 
34 #endif
35 
Expression * clone() const override
static ExpressionLayout * createPrefixLayout(const Expression *expression, PrintFloat::Mode floatDisplayMode, Expression::ComplexFormat complexFormat, const char *operatorName)
Type type() const override
static int writePrefixExpressionTextInBuffer(const Expression *expression, char *buffer, int bufferSize, int numberOfDigits, const char *operatorName)