如何在Python中计算非线性曲线拟合的决定系数(R2)和均方根误差(RMSE)。以下代码完成了曲线拟合。接下来如何计算R2和RMSE?
import numpy as np
import matplotlib.pyplot as plt
from scipy.optimize import curve_fit
def func(x, a, b, c):
return a * np.exp(-b * x) + c
x = np.linspace(0,4,50)
y = func(x, 2.5, 1.3, 0.5)
yn = y + 0.2*np.random.normal(size=len(x))
popt, pcov = curve_fit(func, x, yn)
plt.figure()
plt.plot(x, yn, 'ko', label="Original Noised Data")
plt.plot(x, func(x, *popt), 'r-', label="Fitted Curve")
plt.legend()
plt.show()
scipy.stats.linregress
中的std_err
实际上是斜率系数误差。这个值与RMSE不同,RMSE是(平方残差的平均值)^0.5,是一个随着自由度而变化的不同值。 - pylang