我花了一些时间,但我使用下面的代码为自己创建了一个适合我的 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 处的最大值、估计误差等?
这些信息可以访问吗?如果是这样,有没有办法打印出这些信息?如果不是,请问有人能指出正确的方向来找出合适的错误吗?
桃花长相依
墨色风雨
慕妹3242003
相关分类