R在数据上拟合多项式

bro*_*oli 1 r polynomial-math linear-regression lm

我有一些从下面显示的函数合成生成的数据.

fn <- function(w1,w2){
  f= -(0.1 + 1.3*w1 + 0.4*w2 - 1.8*w1*w1 - 1.8*w2*w2)
  return(f)
}
Run Code Online (Sandbox Code Playgroud)

接下来,我创建一个数据框,其值如下所示

x = data.frame(
  yval = fn(seq(0.1,0.9,by=0.01),seq(1.1,0.3,by=-0.01)),
  x1 = seq(0.1,0.9,by=0.01),
  x2 = seq(1.1,0.3,by=-0.01)
)
Run Code Online (Sandbox Code Playgroud)

我想看看我是否可以通过使用多项式拟合重新创建fn中多项式的系数,我尝试如下所示

fit = lm(yval ~ x1 + x2 + I(x1^2) + I(x2^2),data=x)
coef(fit)
Run Code Online (Sandbox Code Playgroud)

但是,当我运行上面的代码时,我得到以下内容

(Intercept)          x1          x2     I(x1^2)     I(x2^2) 
      2.012      -5.220          NA       3.600          NA 
Run Code Online (Sandbox Code Playgroud)

似乎从未"检测到"x2这个词.有人会知道我做错了什么吗?我知道如果我创建合成线性数据并尝试使用lm重新创建系数,我会相当准确地得到系数.提前致谢.

Hon*_*Ooi 5

如果您适合2个预测变量的网格,则需要expand.grid.

x <- expand.grid(x1=seq(0.1, 0.9, by=0.01), x2=seq(1.1, 0.3, by=-0.01))
x$yval <- with(x, fn(x1, x2))

fit = lm(yval ~ x1 + x2 + I(x1^2) + I(x2^2),data=x)
coef(fit)
(Intercept)          x1          x2     I(x1^2)     I(x2^2) 
       -0.1        -1.3        -0.4         1.8         1.8 
Run Code Online (Sandbox Code Playgroud)