• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Matlab拟合

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

实验目的

  (1)掌握曲线拟合的相应算法;

  (2)将拟合与插值法进行比较。

实验要求

  实验步骤要有模型建立,模型求解、结果分析。

实验内容

  (1)用给定的多项式,如y=x3-6x2+5x-3,产生一组数据(xi,yi,i=1,2,…,n),再在yi上添加随机干扰(可用rand产生(0,1)均匀分布随机数,或用rands产生N(0,1)分布随机数),然后用xi和添加了随机干扰的yi作的3次多项式拟合,与原系数比较。如果作2或4次多项式拟合,结果如何? 

  (2)用电压V=10伏的电池给电容器充电,电容器上t时刻的电压为   ,其中V0是电容器的初始电压,  是充电常数。试由下面一组t,V数据确定V0,τ 

t()

0.5

1

2

3

4

5

7

9

V()

6.36

6.48

7.26

8.22

8.66

8.99

9.43

9.63

实验步骤

  (1)解:编程解题,取[1,23]为例展示,代码

 1 %% 给定x,得到y
 2 x=1:0.1:23;
 3 y=x.^3-6*x.^2+5*x-3;
 4 y0=y+rand;%随机干扰
 5 %% 输出多项式系数
 6 f1=[1 -6 5 -3];%原系数
 7 f2=polyfit(x,y0,2);%2次多项式
 8 f3=polyfit(x,y0,3);%3次多项式
 9 f4=polyfit(x,y0,4);%4次多项式
10 %% 输出图像
11 % 计算各x点拟合值
12 y2=polyval(f2,x);
13 y3=polyval(f3,x);
14 y4=polyval(f4,x);
15 % 画图
16 figure,subplot(2,2,1)
17 plot(x,y,\'r\',\'LineWidth\',3);%原图像
18 legend(\'原函数\',\'Location\',\'northwest\');
19 title(\'[1,23]原函数图像\');
20 xlabel(\'x轴\');
21 ylabel(\'y轴\');
22  
23 subplot(2,2,2)
24 plot(x,y,\'r\',x,y2,\'b\',\'LineWidth\',1,\'LineWidth\',2)%2次多项式拟合
25 legend(\'原函数\',\'2次多项式拟合\',\'Location\',\'northwest\');
26 title(\'[1,23]的2次拟合函数及原函数图像\');
27 xlabel(\'x轴\');
28 ylabel(\'y轴\');
29  
30 subplot(2,2,3)
31 plot(x,y,\'rs\',x,y3,\'y\',\'LineWidth\',1,\'LineWidth\',2)%3次多项式拟合
32 legend(\'原函数\',\'3次多项式拟合\',\'Location\',\'northwest\');
33 title(\'[1,23]的3次拟合函数及原函数图像\');
34 xlabel(\'x轴\');
35 ylabel(\'y轴\');
36  
37 subplot(2,2,4)
38 plot(x,y,\'rs\',x,y4,\'g\',\'LineWidth\',1,\'LineWidth\',2);%4次多项式拟合
39 legend(\'原函数\',\'4次多项式拟合\',\'Location\',\'northwest\');
40 title(\'[1,23]的4次拟合函数及原函数图像\');
41 xlabel(\'x轴\');
42 ylabel(\'y轴\');
43  
44  
45  
题1_MATLAB

  程序运行

  原系数:1,-6,5,-3;

  二次拟合系数:30,-353.7420,846.8601;

  三次拟合系数:1,-6,5,-2.0439;

  四次拟合系数:-4.6603e-17,1,-6,5,-2.0439。

  右上述运行的结论,得出三次拟合系数与原系数相差不大,只有常数项不一样;四次系数的四次项的系数几乎为0,而接下来的系数与原系数相差就在常数项中;只有二次拟合的系数相差巨大。

  由图可见,三次多项式和四次多项式的拟合效果较好。二次多项式拟合效果较差。

  (2)解:根据题意得,v(t)与T呈指数变化关系,本报告使用指数曲线拟合(非线性拟合),对题干中的变量做新的阐述,v1代替v(t),t0代替τ,v2是拟合后的曲线方程,对v(t)=v-(v-v0)e(-t/τ)取对数,有令 ,,则,。编程解题,代码

 1 %题2
 2 t=[0.5 1 2 3 4 5 7 9];
 3 v1=[6.36 6.48 7.26 8.22 8.66 8.99 9.43 9.63];
 4 y=log(10-v1);
 5 f=polyfit(t,y,1);
 6 t0=-1/f(1);
 7 v0=10-exp(f(2));
 8 v2=10-(10-v0)*exp(-t/t0);
 9 plot(t,v1,\'rx\',t,v2,\'k:\',\'LineWidth\',2,...
10     \'LineWidth\',2);
11 grid on
12 legend(\'原始数据\',\'曲线拟合\',\'Location\',\'northwest\');
13 xlabel(\'时间t(s)\'),ylabel(\'充电电压(V)\');
14 title(\'电容器充电电压与时间t的曲线\');
15  
题2_MATLAB

  运行示例,

   由图示,拟合效果良好,解得t0=3.5269,v0=5.6221。也就是τ=3.5269。

小结

   使用曲线拟合之前最好对该曲线的的可能拟合的方程做大致的估计,并且在拟合完成之后,应当使用其他数据进行检验。

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Delphi显示和隐藏窗体发布时间:2022-07-18
下一篇:
matlab学习笔记第十章——曲线拟合发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap