知道一组数据,如何用matlab进行三次样条函数拟合?

2022-04-13 社会 100阅读

如下:

functionfit_tulun 
%多项式拟合方式
x=linspace(0,4*pi,6); 
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:') 
holdon 
fnplt(sp,'r') 
fnplt(s_diff,'c') 
x1=linspace(0,4*pi,200); 
plot(x1,sin(x1),'m','linewidth',1.8) 
legend('多项式拟合样本点','多项式拟合曲线','三次样条拟合曲线','三次样条导数曲线','正弦曲线精确图形').

声明:你问我答网所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流。若您的权利被侵害,请联系fangmu6661024@163.com