数学建模算法之拟合算法

 选择线性拟合

原因是简单,且在做草图后发现线性相关高

clear;clc

load data.mat

n = size(year,2);
k = (n*sum(year.*po)-sum(po)*sum(year))/(n*sum(year.*year)-sum(year)*sum(year));
b = (sum(year.*year)*sum(po)-sum(year)*sum(year.*po))/(n*sum(year.*year)-sum(year)*sum(year));

f = @(year) k*year + b;
fplot(f,[2009,2018]);

hold on % 继续在之前的图形上来画图形

plot(year,po,'o');

po_hat = k*year+b; % y的拟合值
SSR = sum((po_hat-mean(po)).^2);  % 回归平方和
SSE = sum((po_hat-po).^2); % 误差平方和
SST = sum((po-mean(po)).^2); % 总体平方和
SST-SSE-SSR;  % 5.6843e-14  =   5.6843*10^-14   matlab浮点数计算的一个误差
R_2 = SSR / SST;

 代码实现结果如下图

利用matlab拟合工具箱得到

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值