Intégration fonctions polynomiales

This commit is contained in:
Jérôme Delacotte
2025-05-04 17:19:44 +02:00
parent d2378b0b63
commit d9f6d160f6
3 changed files with 191 additions and 0 deletions

42
tools/polynomiale2.py Normal file
View File

@@ -0,0 +1,42 @@
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
def rolling_polyfit_curves(series, degree=3, window=50, step=10):
curves = [] # Liste des courbes
positions = [] # Index de départ pour chaque courbe
for i in range(window, len(series), step):
y = series[i - window:i].values
x = np.arange(window)
coeffs = np.polyfit(x, y, degree)
poly = np.poly1d(coeffs)
curve = poly(x)
curves.append(curve)
positions.append(i)
return curves, positions
# Exemple d'utilisation
# Exemple avec une série synthétique
np.random.seed(0)
x = np.linspace(0, 20, 250)
y = 0.05 * x**3 - x**2 + 2 * x + 5 + np.random.normal(0, 15, size=len(x))
series = pd.Series(y)
# series = pd.Series(np.sin(np.linspace(0, 10*np.pi, 300)) + np.random.normal(0, 0.2, 300))
curves, positions = rolling_polyfit_curves(series, degree=3, window=50, step=10)
# Visualisation
plt.figure(figsize=(12, 6))
plt.plot(series.values, label="Original")
for curve, pos in zip(curves, positions):
x_global = np.arange(pos - 50, pos)
plt.plot(x_global, curve, alpha=0.6)
plt.title("Régressions polynomiales glissantes (chaque 10 bougies sur 50 précédentes)")
plt.legend()
plt.grid(True)
plt.show()