Approximation et extrapolation par moindres carrés

Approximation et extrapolation par moindres carrés#

Approximation par moindres carrés#

\[ \theta = (H^TH)^{-1} H^Ty \]
# Normalisation des abscisses entre 0 et 1
x = (year-1880) / (2020-1880)

# Données sous forme de vecteur colonne
y = np.transpose(temp)

# Matrice H
H = np.transpose(np.array([ x**0, x**1, x**2 ]))

# Estimation des paramètres θ
HT     = np.transpose(H)
HTH    = np.dot(HT, H)
HTHinv = linalg.pinv(HTH)
HTy    = np.dot(HT, y)
theta  = np.dot(HTHinv, HTy)

# Calcul du polynôme z
z = np.dot(H,theta)
../_images/fe25628871a4098a7f82f83d8b25b12c3cc15af18538e7c82eab93e36569d470.png

Extrapolation#

Pour extrapoler la courbe (c’est-à-dire calculer ses valeurs au délà des données), il suffit de calculer le polynôme sur une autre plage des abscisses, donc en redéfinissant \(H\).

year2 = np.arange(1880,2070)
x = (year2-1880)/(2020-1880)
H = np.transpose(np.array([ x**0, x**1, x**2 ]))
z = np.dot(H,theta)
../_images/6121114fd25463a624ab5afb9ff5d53243cf92bed0c8d22f5d0d7c2dd36f082b.png

Si vous avez le moral accroché, vous pouvez connaître les conséquences issues de cette extrapolation sur l’article Wikipedia Changement climatique… 😱

Données :