我花了一些时间,但我使用下面的代码为我的 x,y 数据集创建了一个高斯拟合。
import matplotlib.pyplot as plt
import numpy as np
from scipy.optimize import curve_fit
def Gauss(x, a, x0, sigma, offset):
return a * np.exp(-(x - x0)**2 / (2 * sigma**2)) + offset
x, y = np.random.random(100), np.random.random(100)
popt, pcov = curve_fit(Gauss, x, y, p0=[np.max(y), np.median(x), np.std(x), np.min(y)])
plt.plot(x, y, 'b+:', label='data')
x_fit = np.linspace(np.min(x), np.max(x), 1000)
plt.plot(x_fit, Gauss(x_fit, *popt), 'r-', label='fit')
plt.legend()
plt.title('Something')
plt.xlabel('Anotherthing')
plt.ylabel('Athing')
plt.show()
我可以看到我的配合做得很好,并查看图表和所有内容。
我现在想知道的是如何在我的屏幕上打印出这种拟合的结果,例如拟合最大点 x 处的最大值、估计的误差等?
这些信息是否可以访问?如果是这样,有没有办法打印出这些信息?如果没有,有人可以指出我找到合适的错误的正确方向吗?