Blame view

build4/epsilon-master/poincare/src/simplification_engine.cpp 721 Bytes
6663b6c9   adorian   projet complet av...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
  #include <poincare/simplification_engine.h>
  
  #if MATRIX_EXACT_REDUCING
  
  namespace Poincare {
  
  Expression * SimplificationEngine::map(Expression * e, Context & context, Expression::AngleUnit angleUnit) {
    assert(e->numberOfOperands() == 1 && e->operand(0)->type() == Expression::Type::Matrix);
    Expression * op = e->editableOperand(0);
    for (int i = 0; i < op->numberOfOperands(); i++) {
      Expression * entry = op->editableOperand(i);
      Expression * eCopy = e->clone();
      eCopy->replaceOperand(eCopy->editableOperand(0), entry, true);
      op->replaceOperand(entry, eCopy, false);
      eCopy->shallowReduce(context, angleUnit);
    }
    return e->replaceWith(op, true)->shallowReduce(context, angleUnit);
  }
  
  }
  
  #endif