gpt4 book ai didi

python - 如何在Python中计算平方和?

转载 作者:行者123 更新时间:2023-12-01 08:06:09 27 4
gpt4 key购买 nike

首先,公式TSS = ESS + RSS 总是正确的吗?即使对于指数模型?如果是的话,我只是不明白我错在哪里。

我有 2 个 x 和 y 值数组,其中 y 取决于 x。

x = np.array([1.5, 2.1, 2.4, 2.7, 3.2, 3.4, 3.6, 3.7, 4.0, 4.5, 5.1, 5.6])
y = np.array([0.6, 1.2, 1.3, 1.4, 1.45, 1.5, 1.6, 1.8, 1.9, 1.95, 2.1, 2.2])

我有一个函数可以确定系数 a 和 b 并返回线性回归方程(或者如果需要,仅返回 a 和 b)

def Linear(x, y, getAB = False):
AVG_X = np.average(x)
AVG_Y = np.average(y)
DISP_X = np.var(x)
DISP_Y = np.var(y)
STD_X = np.std(x)
STD_Y = np.std(y)

AVG_prod = np.average(x*y)
cov = AVG_prod - (AVG_X*AVG_Y)

b = cov/DISP_X
a = AVG_Y - b*AVG_X

if getAB:
return a, b

return lambda X: a + b*X

我有一个函数可以确定系数 a 和 b 并返回指数回归方程

def Exponential(x, y, getAB = False):
LOG_Y_array = [math.log(value) for value in y]

A, B = Linear(x, LOG_Y_array, getAB = True)

a = math.exp(A)
b = math.exp(B)

if getAB:
return a, b

return lambda X: a * (b**X)

我创建了基于指数模型计算的 y 值的数组

Exponential_Prediction = Exponential(x, y)
Exponential_Prediction_y = [Exponential_Prediction(value) for value in x]

最后,这就是我计算 TSS、ESS 和 RSS 的方法

TSS = np.sum((y - np.average(y))**2)
ESS_Exp = np.sum((Exponential_Prediction_y - np.average(y))**2)
RSS_Exp = np.sum((y-Exponential_Prediction_y)**2)

这一切都很清楚,除了这个的输出

print(str(TSS) + " = " + str(ESS_Exp) + " + " + str(RSS_Exp))

是 2.18166666667 = 2.75523753042 + 0.432362713806

我不明白 ESS 怎么会比 TSS 更好

最佳答案

当您使用线性回归时,您缺少一个为零的项,因为您没有,所以必须添加它。在 Vince 评论的链接中,您可以看到 TSS = ESS + RSS + 2*sum((y - yhat)*(yhat - ybar))。

您需要包含该额外术语才能使其相加:

extra_term = 2 * np.sum((y - Exponential_Prediction_y) * (Exponential_Prediction_y - y.mean())) 
print(str(TSS) + " = " + str(ESS_Exp) + " + " + str(RSS_Exp) + " + " + str(extra_term))

关于python - 如何在Python中计算平方和?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55523222/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com