作业帮 > 综合 > 作业

Matlab指数拟合问题:谁能帮我看看为什么画出来的图像函数部分是一条直线呢?

来源:学生作业帮 编辑:作业帮 分类:综合作业 时间:2024/07/19 06:31:07
Matlab指数拟合问题:谁能帮我看看为什么画出来的图像函数部分是一条直线呢?
程序如下:
第一步:生成目标函数的函数文件goal002.m
function f=goal002(a,x)
f=a(1)+(-a(1)+a(2))*exp(-a(3)*x);
第二步:生成计算的主程序cfit002.m
clear;
x=[1790 1800 1810 1820 1830 1840 1850 1860 1870 1880 1890 1900 1910 1920 1930 1940 1950 1960 1970 1980 1990 2000];
y=[3.9 5.3 7.2 9.6 12.9 17.1 23.2 31.4 38.6 50.2 62.9 76.0 92.0 106.5 123.2 131.7 150.7 179.3 204.0 226.5 251.4 281.4];
a0=[1 1 1];
[a,jm]=lsqcurvefit(@goal002,a0,x,y)
x1=sort(x);
y1=goal002(a,x1);
plot(x,y,'r*');hold on
plot(x1,y1)
我的曲线画出来为什么是直线呢?
谁能帮我看看^
你的代码没错,你要拟合的曲线是 f=a(1)+(-a(1)+a(2))*exp(-a(3)*x);
     问题就出在exp(-a(3)*x)上  ,由于x的值都很大,因此exp(-a(3)*x)在超过了matlab的最小数,因此matlab显示的是0.所以当你用拟合的曲线计算在x出的值时,都等于a(1)了,因为后面的等于零.因此你画出的图像就是直线了.
我试了一下确实如此.
>> exp(-1790)
ans =
     0
   还有个原因,即使把你的x除以100也会得到一条直线,因为这样的x使得
(-a(1)+a(2))*exp(-a(3)*x)的值很小
>> x
x =
  Columns 1 through 10
   17.9000   18.0000   18.1000   18.2000   18.3000   18.4000   18.5000   18.6000   18.7000   18.8000
  Columns 11 through 20
   18.9000   19.0000   19.1000   19.2000   19.3000   19.4000   19.5000   19.6000   19.7000   19.8000
  Columns 21 through 22
   19.9000   20.0000
>> (-a(1)+a(2))*exp(-a(3)*x)
ans =
  1.0e-005 *
  Columns 1 through 10
   -0.1578   -0.1428   -0.1292   -0.1169   -0.1058   -0.0957   -0.0866   -0.0784   -0.0709   -0.0642
  Columns 11 through 20
   -0.0581   -0.0525   -0.0475   -0.0430   -0.0389   -0.0352   -0.0319   -0.0288   -0.0261   -0.0236
  Columns 21 through 22
   -0.0214   -0.0193
由于a(1)=94.7727,与上述值比起来要大很多 ,因此加起来还是等于94.7727.
>> ans+94.7727
ans =
  Columns 1 through 10
   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727
  Columns 11 through 20
   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727   94.7727
  Columns 21 through 22
   94.7727   94.7727
 这是不是意味着matlab出错呢?不是的,如果我们换成长格式,让matlab更加精确,就可以看出差别了.
format long
>> ans
ans =
  Columns 1 through 5
  94.772698421642701  94.772698571843264  94.772698707750351  94.772698830724153  94.772698941995472
  Columns 6 through 10
  94.772699042677914  94.772699133779156  94.772699216210967  94.772699290798357  94.772699358287809
  Columns 11 through 15
  94.772699419354808  94.772699474610505  94.772699524607916  94.772699569847461  94.772699610781885
  Columns 16 through 20
  94.772699647820886  94.772699681335155  94.772699711660124  94.772699739099295  94.772699763927278
  Columns 21 through 22
  94.772699786392565  94.772699806719999
这样就很明白了,造成这种问题的原因是值和值之间的相差太小,因此画出的也是直线.
    结论是:  必须把x缩小,再使用对数y轴,如图: