我正在尝试将非线性函数拟合到给定的数据集(代码片段中的 x 和 y),该函数定义为
f(x) = a/((sin((x-b)/2))^4)
x <- c(0, 5, -5, 10, -10, 15, -15, 20, -20, 25, -25, 30, -30)
y <- c(4.21, 3.73, 2.08, 1.1, 0.61, 0.42, 0.13, 0.1, 0.04, 0.036667, 0.016667, 0.007778, 0.007778)
plot(x,y, log="y")
这就是在提到函数之前我应该拟合的初始图的样子。
但是当我尝试使用 nls 拟合并绘制曲线时,该图看起来不太正确
f <- function(x,a,b) { a/((sin((x-b)/2))^4) }
fitmodel <- nls (y ~ f(x,a,b), start=list(a=1,b=1))
lines(x, predict(fitmodel))
这就是我所看到的:
我很确定我在这里做错了什么,并感谢您的帮助。