polyfit命令是多项式拟合,其拟合精度相对来说不是很好,尤其是在样本点稀疏和图像有尖点的地方,可以从以下语句与图形中看出这一点,举例波动性较强的正弦函数绘图。顺便说一句,三次样条还不是最好的拟合函数,但一般情况下也够了,本例题里只是选择了6个样本点,已经达到了这样的拟合效果。
function fit_tulun
%多项式拟合方式
x=linspace(0,4*pi,6);
matlab拟合数据
y_jingque=sin(x); %决定稀疏样本点数据
p_poly=polyfit(x,y_jingque,5);
x_poly_fit=linspace(0,4*pi,100);
y_poly_fit=polyval(p_poly,x_poly_fit);
%三次样条拟合方式
sp=csapi(x,y_jingque);
%求三次样条函数的导数.
s_diff=fnder(sp,1);
plot(x_poly_fit,y_poly_fit,'ko',x_poly_fit,y_poly_fit,'b:')
%plot(x_poly_fit,y_poly_fit,'b:')
hold on
fnplt(sp,'r')
fnplt(s_diff,'c')
x1=linspace(0,4*pi,200);
plot(x1,sin(x1),'m','linewidth',1.8)
legend('多项式拟合样本点','多项式拟合曲线','三次样条拟合曲线','三次样条导数曲线','正弦曲线精确图形')

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。