MatLab和R中的正弦拟合

时间:2019-12-23 22:19:36

标签: r matlab translate

我正在将代码从MatLab转换为R,但是我对MatLab完全陌生。我无法理解MatLab代码中发生了什么以及如何将其转换为R。这是问题所在:

在代码中,一个函数调用另一个名为@fit_sine的函数

x0=[max(y),2*3.14159/360,0.01,mean(y)]; 
options = optimset('Display','off');
coeff=lsqcurvefit(@fit_sine,x0,x,y,[],[],options);
fit=coeff(1).*sind(coeff(2).*x+coeff(3))+coeff(4);

这是@fit_sine函数:

function F=fit_sine(x,xdata)
F=x(1).*sind(x(2).*xdata+x(3))+x(4);

但是 xdata没有定义。这是令我感到困惑的步骤。在R中,有一个类似于lsqcurvefit的函数,即nls,但是我无法重现与此MatLab代码类似的结果。

以下是用于x和y的数据:
y = -0.4764 -1.0880 -1.0115 -0.8586 -0.7822 -0.7058 -0.4000 0.3644 0.8231 0.7466 0.5173 0.4408
x = 0 30 60 90 120 150 180 210 240 270 300 330

以及coeff的输出:
coeff = 0.9098 0.8974 -157.6722 -0.1853

编辑:

解决方案:

    fp <- function(x0, x) (x0[1]*sin((x0[2]*x+x0[3])*(pi/180))+x0[4])

    library(pracma)
    coeff <- lsqcurvefit(fp, x0, x, y)

    fit=coeff$x[1]*sin((coeff$x[2]*x+coeff$x[3])*(pi/180))+coeff$x[4]

1 个答案:

答案 0 :(得分:1)

fit_sine是一个用户定义的函数,它接受两个输入:xxdata。就像在R中一样,不需要在函数外部使用相同的名称。 fit_sine函数是用于进行最小二乘曲线拟合的非线性函数。 lsqcurvefit接受输入(a function, x0, x, y)以及其他输入。在文档中,

  

lsqcurvefit(fun,x0,xdata,ydata)从x0开始,并找到系数x以使非线性函数fun(x,xdata)最适合数据ydata(在最小二乘意义上)。 ydata的大小必须与fun返回的向量(或矩阵)F相同。

在这种情况下,编写fit_sine函数的人将x0定义为x,将x定义为xdata,大概是为了匹配MATLAB文档。