python - 计算python中非线性曲线拟合的确定系数(R2)和均方根误差(RMSE)

标签 python numpy matplotlib scipy statsmodels

如何在 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()

最佳答案

你可以这样做:

print "Mean Squared Error: ", np.mean((y-func(x, *popt))**2)

ss_res = np.dot((yn - func(x, *popt)),(yn - func(x, *popt)))
ymean = np.mean(yn)
ss_tot = np.dot((yn-ymean),(yn-ymean))
print "Mean R :",  1-ss_res/ss_tot

这是直接采用定义,例如在维基百科中: http://en.wikipedia.org/wiki/Coefficient_of_determination#Definitions

关于python - 计算python中非线性曲线拟合的确定系数(R2)和均方根误差(RMSE),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20115272/

相关文章:

python - 在 python 中将两个项目列表相互求和的最快方法

python - 为什么 Python 多处理守护进程不打印到标准输出?

python - 在 Tensorflow 中重新训练模型

python - numpy 的平均值大于 memmap 的最大值

matplotlib - 子图隐藏 xlabel

python - matplotlib 轴标签的奇怪错误

django - 避免网络上多个 Matplotlib 图形之间的干扰

python - Selenium Python 2 按名称和值查找元素?

python - 我的应用程序的管理模板与内置模板的优先级

python - Python中的 `board[x, y]`和 `board[x][y]`有区别吗?