曲线拟合(多项式函数+MATLAB实例)
创作时间:
作者:
@小白创作中心
曲线拟合(多项式函数+MATLAB实例)
引用
CSDN
1.
https://m.blog.csdn.net/weixin_46308081/article/details/116566819
曲线拟合是数据分析中常用的技术手段,通过多项式函数可以很好地拟合数据并进行预测。本文将详细介绍如何使用MATLAB进行曲线拟合,包括关键函数的使用方法和具体案例分析。
一.拟合所需函数
这里我们主要考虑用多项式函数去进行曲线拟合
(1)polyfit 函数
功能:求得结果为最小二乘法拟合的多项式系数。
格式:
p = polyfit(X,Y,n);
X,Y为进行拟合的样本数据,类型为矩阵。n为拟合的多项式次数,看散点图判断拟合次数。p为拟合后返回的多项式系数矩阵。
[p,s] = polyfit(X,Y,n);
返回两个结果,s为采样点的误差数据
[p,s,mu] = polyfit(X,Y,n);
返回三个结果,mu是一个二元向量,其中mu(1)是X的平均值即mean(X), mu(2)是X的标准差即std(X)。
(2)polyval 函数
功能:求得在上面函数所得的p系数下,某一点预测的函数值。
格式:
polyval(p,15);
返回值为X=15时的函数值。
二.举例(预测人口)
(1)问题数据
某地区2010-2020人口数据:
x | 2010 | 2011 | 2012 | 2013 | 2014 | 2015 | 2016 | 2017 | 2018 | 2019 | 2020 |
|---|---|---|---|---|---|---|---|---|---|---|---|
y | 3.9 | 5.3 | 7.2 | 9.6 | 12.9 | 17.1 | 23.2 | 31.4 | 38.6 | 50.2 | 63.0 |
(2)求解
我们先分步求解,后面有完整代码
【1】先查看散点图趋势
x=2010:1:2020;
y=[3.9,5.3,7.2,9.6,12.9,17.1,23.2,31.4,38.6, 50.2,63.0];
plot(x,y,'*');
【2】进行多项式函数拟合(这里可以尝试不同的次数择优选取)
p = polyfit(x,y,2);
plot(x,y,'*',x,polyval(p,x))
可以看到结果基本吻合
【3】可以继续进行预测未来的人口
polyval(p,2021)
ans =
74.4776
(3)完整代码
x=2010:1:2020;
y=[3.9,5.3,7.2,9.6,12.9,17.1,23.2,31.4,38.6, 50.2,63.0];
p = polyfit(x,y,2);
plot(x,y,'*',x,polyval(p,x))
polyval(p,2021);
(4)注意点
我们在选取数据时,并不是数据越多越好。在选取数据时,同时要考虑到实际情况,就比如说对人口预测,可能前10年发生了天灾人祸使得前十年的数据严重不符,那么这一阶段的数据就可以舍弃。
曲线拟合作用
- 预测趋势
- 总结规律
- 估算数据
热门推荐
学前教育科学研究的具体步骤
小区盗窃案引发的法律思考与防范对策
薄膜键盘与机械键盘的全面对比
母亲想再婚被儿子起诉:法律分析与家庭关系的复杂性
7 款最佳游戏 DNS 服务器推荐:提升游戏体验的利器
比熊犬洗澡全攻略:注意事项与洗澡频率指南
LED灯具散热结构设计
导热材料选择指南:CPU用导热硅脂还是导热硅胶?
醒来手麻是不是大病的预兆
商铺提前退租违约的法律风险及应对策略
ERP厂房退租全流程指南:5个关键步骤确保顺利退租
房屋质量纠纷中开发商的责任认定与购房者权益保护
水泵型号的字母分别代表什么
七个症状警惕肝衰竭,越早发现越有利于康复
一年能吃掉3千只蚊子,8年才长大,却被当成美食大量捕捉
央视推荐5部神级纪录片,孩子不想学习时,可以点燃孩子学习热情
医学影像技术在胰腺疾病筛查中的应用
布洛芬分散片和普通的区别
胃反酸烧心吃什么食物可以缓解
每天早上睡懒觉的老人,除了有利于大脑,还会带来这4个好处
家庭甲醛检测方法及注意事项详解
外地车辆在北京还有哪些注意事项?
哲学思维最高境界:从批判性思考到全球视野
雪松的功效与使用:从身体到心灵的全方位呵护
中国养老行业风险投资态势与投融资策略全景洞察(2025-2030)
技术管理者,一定要有体系
路亚竿枪柄和直柄有什么区别?
插电混动汽车:能否只充电不加油,看使用场景而定!
婴儿睡觉时捂住口鼻是否会造成脑损伤
2009年第7顺位选秀:库里前6位球员的成就探讨