数学实验第三版(主编:李继成 赵小艳)课后练习答案(十三)(1)

实验十三:数据拟合与数据差值

练习一

1.采用不同的拟合函数拟合示例4中的数据点,然后利用弧长公式预测光缆长度,同正文中的结果进行比较.

Matlab 复制代码
clc;clear;
p=[9.01,8.96,7.96,7.97,8.02,9.05,10.13,11.18,12.26,13.28,13.32,12.61,11.29,10.22,9.15,7.90,7.95,8.86,9.81,10.80,10.93];
x=0:20;
plot(x,p,'.');
f=inline('a(1)*x+a(2)*sin(0.5*x)+a(3)*cos(0.5*x)+10','a','x');
a0=[0 0 0];
[a,resnorm]=lsqcurvefit(f,a0,x,p)
x1=0:0.1:20;
g=a(1)*x1+a(2)*sin(0.5*x1)+a(3)*cos(0.5*x1)+10;
hold on
plot(x1,g,'r-');
l=0;
for i=1:length(x1)-1
    l=l+sqrt((x1(i)-x1(i+1))^2+(g(i)-g(i+1))^2);
end
l

找到局部最小值。

优化已完成,因为梯度大小小于

最优性容差的值。

<停止条件详细信息>

a =

0.0389 -2.5033 0.0164

resnorm =3.8448

l =26.6787

2.已知观测数据如下:

|-------|----------|---------|----------|-----------|-----------|----------|---------|-----------|--------|----------|
| x | 1.6 | 2.7 | 1.3 | 4.1 | 3.6 | 2.3 | 0.6 | 4.9 | 3 | 2.4 |
| y | 17.7 | 49 | 13.1 | 189.4 | 110.8 | 34.5 | 4 | 409.1 | 65 | 36.9 |

求a,b,c的值,使得曲线 与已知数据点在最小二乘意义上充分接近,并求残差平方和.

Matlab 复制代码
clc;clear;
x=[1.6,2.7,1.3,4.1,3.6,2.3,0.6,4.9,3,2.4];
y=[17.7,49,13.1,189.4,110.8,34.5,4,409.1,65,36.9];
f=inline('a(1)*exp(x)+a(2)*sin(x)+a(3)*log(x)','a','x');
a0=[0,0,0];
[a,ransnorm]=lsqcurvefit(f,a0,x,y)
x1=0.6:0.1:4.9;
g=a(1)*exp(x1)+a(2)*sin(x1)+a(3)*log(x1);
plot(x,y,'r.');
hold on
plot(x1,g);

a = 3.0154 1.0327 3.5933

ransnorm = 25.0753

3.商品的需求量与其价格有一定的关系.现对一定时期内的商品价格x与需求量y进行观察,取得如下数据:

|-------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 价格x/元 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| 需求量y/kg | 58 | 50 | 44 | 38 | 34 | 30 | 29 | 26 | 25 | 24 |

(1)分别作出上述数据点的直线、抛物线、3次多项式拟合,分别求出残差平方和,并比较优劣;

Matlab 复制代码
clc;clear;
x=2:11;
y=[58,50,44,38,34,30,29,26,25,24];
plot(x,y,'r.');
p1=polyfit(x,y,1);
p2=polyfit(x,y,2);
p3=polyfit(x,y,3);
x1=2:0.1:11;
n1=polyval(p1,x1);
n11=polyval(p1,x);
n2=polyval(p2,x1);
n22=polyval(p2,x);
n3=polyval(p3,x1);
n33=polyval(p3,x);
hold on
plot(x1,n1);%直线拟合
hold on
plot(x1,n2,'k',x1,n3);
legend('点','直线','抛物线','三次多项式');
r1=0;r2=0;r3=0;
for i=1:length(y)
    r1=r1+(y(i)-n11(i))^2;
    r2=r2+(y(i)-n22(i))^2;
    r3=r3+(y(i)-n33(i))^2;
end
r1,r2,r3

r1 =

103.4061

r2 =

3.2167

r3 =

1.5103

(2)假设拟合函数为 ,试求a,b.

Matlab 复制代码
clc;clear;
x=2:11;
y=[58,50,44,38,34,30,29,26,25,24];
f=inline('a(1)+a(2)./x','a','x');
a0=[0,0];
[a,r]=lsqcurvefit(f,a0,x,y)
plot(x,y,'.');
x1=2:0.1:11;
hold on
g=a(1)+a(2)./x1;
plot(x1,g);

找到局部最小值。

优化已完成,因为梯度大小小于

最优性容差的值。

<停止条件详细信息>

a =

18.1604 87.3300

r =

57.3023

本文由作者自创,由于时间原因,难免出现些许错误,还请大家多多指正。创作不易,请大家多多支持。

相关推荐
laowangpython6 小时前
Gurobi求解器Matlab安装配置教程
开发语言·其他·matlab
知识浅谈6 小时前
DeepSeek V4 和 GPT-5.5 在同一天发布了??我也很懵,但对比完我悟了
算法
DeepModel6 小时前
通俗易懂讲透 Q-Learning:从零学会强化学习核心算法
人工智能·学习·算法·机器学习
田梓燊6 小时前
力扣:19.删除链表的倒数第 N 个结点
算法·leetcode·链表
简简单单做算法8 小时前
基于GA遗传优化双BP神经网络的时间序列预测算法matlab仿真
神经网络·算法·matlab·时间序列预测·双bp神经网络
yu85939588 小时前
基于MATLAB的随机振动仿真与分析完整实现
开发语言·matlab
guygg888 小时前
利用遗传算法解决列车优化运行问题的MATLAB实现
开发语言·算法·matlab
gihigo19988 小时前
基于MATLAB实现NSGA-III的土地利用空间优化模型
开发语言·matlab
武藤一雄9 小时前
19个核心算法(C#版)
数据结构·windows·算法·c#·排序算法·.net·.netcore
sali-tec9 小时前
C# 基于OpenCv的视觉工作流-章52-交点查找
图像处理·人工智能·opencv·算法·计算机视觉