不使用 GEKKO 的多元非线性回归

Multivariate Nonlinear Regression without using GEKKO

import numpy as np
import pandas as pd

#import the excel file
dataset = pd.read_excel('data.xlsx')


#set all the independent variable as 'x', 'y', and 'z' and the dependent variable as 'sy'
x = dataset.iloc[:,0]
y = dataset.iloc[:,1]
z = dataset.iloc[:,2]
sy = dataset.iloc[:,3]

A = np.column_stack([np.ones(len(x)), x, x**2, y, y**2, z, z**2])

#"B" will be "sy" array
B = sy

#Solving Ax = B
a, b, c, d, e, f, g = np.linalg.lstsq(A,B)
#result, _, _, _, _, _ = np.linalg.lstsq(A,B)
#a, b, c, d, e, f, g = result

所以,我有三列独立变量 xyz。一个因变量 sy。我正在尝试为此安装一个模型。我从 post 复制代码,但出现以下错误:

ValueError: not enough values to unpack (expected 7, got 4)

你能帮我解决这个问题吗?

我要拟合的模型是 sy = a + b*x + c*x^2 + d*y + e*y^2 + f*z + g*z^2。有什么方法可以得到模型的 Adjusted R-Squared 值吗?

要修复错误并获得结果,您的代码的第 10 行需要修改如下:

a, b, c, d, e, f, g = np.linalg.lstsq(A,B)[0]