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

 我来答
day忘不掉的痛
推荐于2017-10-02 · 知道合伙人数码行家
day忘不掉的痛
知道合伙人数码行家
采纳数:62646 获赞数:223933
本人担任公司网络部总经理多年,有充足的网络经验、互联网相关知识和资讯。

向TA提问 私信TA
展开全部

如下:

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

宇逸ycl
2013-03-23 · TA获得超过4088个赞
知道大有可为答主
回答量:1589
采纳率:50%
帮助的人:1830万
展开全部

x = 0:10; 

y = sin(x);% 已知数据


xx = 0:.25:10; %插值点

yy = spline(x,y,xx); %三次样条插值

plot(x,y,'o',xx,yy) %绘图

圆圈代表原来的数据,曲线代表插值之后的图形曲线。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式