Blame view

Modif/epsilon-master/apps/regression/model/model.h 2.55 KB
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
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
  #ifndef REGRESSION_MODEL_H
  #define REGRESSION_MODEL_H
  
  #include <stdint.h>
  #include "../../i18n.h"
  #include <poincare/context.h>
  #include <poincare/expression.h>
  
  namespace Regression {
  
  class Store;
  
  class Model {
  public:
    enum class Type : uint8_t {
      Linear      = 0,
      Quadratic   = 1,
      Cubic       = 2,
      Quartic     = 3,
      Logarithmic = 4,
      Exponential = 5,
      Power       = 6,
      Trigonometric = 7,
      Logistic    = 8
    };
    static constexpr int k_numberOfModels = 9;
    static constexpr int k_maxNumberOfCoefficients = 5;
    virtual ~Model() = default;
    virtual Poincare::ExpressionLayout * layout() = 0;
    // simplifiedExpression is overrided only by Models that override levelSet
    virtual Poincare::Expression * simplifiedExpression(double * modelCoefficients, Poincare::Context * context) { return nullptr; }
    virtual I18n::Message formulaMessage() const = 0;
    virtual double evaluate(double * modelCoefficients, double x) const = 0;
    virtual double levelSet(double * modelCoefficients, double xMin, double step, double xMax, double y, Poincare::Context * context);
    virtual void fit(Store * store, int series, double * modelCoefficients, Poincare::Context * context);
    virtual int numberOfCoefficients() const = 0;
    virtual int bannerLinesCount() const { return 2; }
  protected:
    // Fit
    virtual bool dataSuitableForFit(Store * store, int series) const;
  private:
    // Model attributes
    virtual double partialDerivate(double * modelCoefficients, int derivateCoefficientIndex, double x) const = 0;
  
    // Levenberg-Marquardt
    static constexpr double k_maxIterations = 100;
    static constexpr double k_maxMatrixInversionFixIterations = 10;
    static constexpr double k_initialLambda = 0.001;
    static constexpr double k_lambdaFactor = 10;
    static constexpr double k_chi2ChangeCondition = 0.001;
    static constexpr double k_initialCoefficientValue = 1.0;
    static constexpr int k_consecutiveSmallChi2ChangesLimit = 10;
    void fitLevenbergMarquardt(Store * store, int series, double * modelCoefficients, Poincare::Context * context);
    double chi2(Store * store, int series, double * modelCoefficients) const;
    double alphaPrimeCoefficient(Store * store, int series, double * modelCoefficients, int k, int l, double lambda) const;
    double alphaCoefficient(Store * store, int series, double * modelCoefficients, int k, int l) const;
    double betaCoefficient(Store * store, int series, double * modelCoefficients, int k) const;
    int solveLinearSystem(double * solutions, double * coefficients, double * constants, int solutionDimension, Poincare::Context * context);
  };
  
  }
  
  #endif