如何找到多项式拟合通过零的点

Vin*_*woo 1 r curve-fitting polynomial-math polynomials polynomial-approximations

我已经将四阶多项式曲线拟合到我的数据中,如下所示:

y<-c(-13,16,35,40,28,36,43,33,40,33,22,-5,-27,-31,-29,-25,-26,-31,-26,-24,-25,-29,-23,4)
x<-1:24

#4th order polynomial fit
fit<-lm(y~poly(x,4,raw=TRUE))

plot(x,y,ylim=c(min(y)-10,max(y)+10))
lines(x,predict(fit,data.frame(x=x)),col="red")
abline(h=0,lty=2)
Run Code Online (Sandbox Code Playgroud)

我的最终目标是计算这条曲线与零线相交的 3 个点。

所以首先,我需要延长曲线拟合的末端,使其第三次超过零线。完成此操作后,我想计算该方程通过零线的 3 个点。

MrF*_*ick 5

您可以使用该predict函数从拟合模型中获取值。例如

pred <- function(x) predict(fit, newdata=data.frame(x=x))
Run Code Online (Sandbox Code Playgroud)

然后,如果你想多根,你可以使用这样的函数uniroot.allrootSolve

rootSolve::uniroot.all(pred, c(0,30))
# 1.428859 11.990087 24.420745
Run Code Online (Sandbox Code Playgroud)

它将从您的模型中找到 0 到 30 之间的根。您还可以uniroot多次调用基本函数。

  • 使用这样的多项式,您可以取导数并找到拐点并将它们用作我猜的间隔?但据我所知,找到所有的根在最一般的意义上并不是一个容易的问题。 (2认同)