曲线拟合(多项式函数+MATLAB实例)
创作时间:
作者:
@小白创作中心
曲线拟合(多项式函数+MATLAB实例)
引用
CSDN
1.
https://m.blog.csdn.net/weixin_46308081/article/details/116566819
本文将介绍如何使用MATLAB进行曲线拟合,重点讲解polyfit和polyval两个函数的使用方法,并通过一个预测人口的具体案例来展示如何应用这些函数。
一.拟合所需函数
这里我们主要考虑用多项式函数去进行曲线拟合
(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年发生了天灾人祸使得前十年的数据严重不符,那么这一阶段的数据就可以舍弃。
曲线拟合作用
- 预测趋势
- 总结规律
- 估算数据
热门推荐
上海音乐学院新春音乐会:一场中西合璧的音乐盛宴
华山论剑打卡!长空栈道挑战极限
华山秋游攻略:避开人潮,享受静谧之美
穿越千年:华山与华清宫的文化盛宴
华山摄影打卡圣地:北峰顶、东峰顶、西峰
买入时机判断:如何运用技术分析判断股票买入时机
底部判断方法:如何判断股票有底了
床墊異味如何除臭?小孩寵物尿床、嘔吐去除臭味及預防?
有尿骚味的被子晒太阳有没有用
德昌桑葚干:养生新宠!
有机认证的桑葚干,你真的会选吗?
全职妈妈如何摆脱经济依赖?这些方法值得一试
经济独立,让婚姻更甜蜜?
中式咸鱼真的会致癌吗?世界卫生组织早已给出答案
《柳叶刀》最新研究:中国饮食致癌率全球第一!
餐桌上的隐形杀手:硼砂致癌物,这些食物要当心!
远离黄曲霉毒素:青少年饮食安全全攻略
完颜阿骨打:金朝的奠基者与改革者
猛安谋克:金军战术大揭秘!
金朝勃极烈制度:权力运作揭秘
中国精准反制美国关税升级,专家:贸易战没有赢家
洋流大变局:海水密度如何影响全球气候?
全球变暖下的海洋生态危机:水的密度之谜
交管12123让你秒变驾照达人!
驾照被扣12分?满分学习和学法减分详解
达日县交警曝光无证驾驶案例:多人被拘并罚款
家人共享位置,安全又便捷!
双十一购物狂欢,银行如何用定位防诈骗?
普洱茶里面有黑色的物质要如何处理,如何处理普洱茶中的黑色物质?
为何澳大利亚的小众护肤品牌会成为市场主力?