我想对以下数据进行曲线拟合:munich_temperatures_average.txt
我试过:
import numpy as np
import matplotlib.pyplot as plt
from scipy import optimize
def func(temp, a, b, c):
return a * np.cos(2 * np.pi * temp + b) + c
date, temperature = np.loadtxt('munich_temperatures_average.txt', unpack=True)
result = optimize.curve_fit(func, date, temperature)
plt.plot(date, temperature, '.')
plt.plot(date, func(date, result[0][0], result[0][1], result[0][2]), c='red', zorder=10)
plt.ylim([-20, 30])
plt.xlabel("Year", fontsize=18)
plt.ylabel("Temperature", fontsize=18)
plt.show()
但是在输出图中可以看到,拟合后的模型的振荡幅度似乎比实际小,请问如何才能使拟合更准确?先谢谢你。
1条答案
按热度按时间mo49yndu1#
感谢@Reinderien的解释,我使用1D median filter来过滤离群值,因此模型拟合似乎是准确的: