【MATLAB第41期】源码分享 | 基于MATLAB的二次及三次指数平滑及其时间序列预测代码

简介: 【MATLAB第41期】源码分享 | 基于MATLAB的二次及三次指数平滑及其时间序列预测代码

MATLAB第41期】源码分享 | 基于MATLAB的二次及三次指数平滑及其时间序列预测代码


一、资源获取


后台私信回复“41期”,可免费获取代码下载链接。


二、效果展示


1.二次指数平滑法

2.三次指数平滑法

三、代码展示

%%  清空环境变量
warning off             % 关闭报警信息
close all               % 关闭开启的图窗
clear                   % 清空变量
clc                     % 清空命令行
%%  导入数据(时间序列的单列数据)
Yt = xlsread('数据集.xlsx');
alpha=0.5;
t=10;
%%  数据分析
num_samples = length(Yt);  % 样本个数 
[Y,S1,S2,a,b] = expsmooth2(Yt,alpha,t)
function [Y,S1,S2,a,b] = expsmooth2(Yt,alpha,t)
%Yt:原时间序列;alpha:平滑系数;t:预测时长
%Y:预测值;S1/S2:一次/二次指数平滑值;a/b:预测公式参数
n=length(Yt);
%计算一次指数平滑值
%计算二次指数平滑值
%计算参数a和b
for i=1:n
    a(i)=2*S1(i)-S2(i);
    b(i)=alpha/(1-alpha)*(S1(i)-S2(i));
end
%计算预测值Y
for i=1:t
    Y(i)=a(n)+b(n)*i;
end
%绘图
plot(1:n,Yt,(n+1):(n+t),Y,'*');
end
%%  清空环境变量
warning off             % 关闭报警信息
close all               % 关闭开启的图窗
clear                   % 清空变量
clc                     % 清空命令行
%%  导入数据(时间序列的单列数据)
Yt = xlsread('数据集.xlsx');
alpha=0.5;
t=10;
%%  数据分析
num_samples = length(Yt);  % 样本个数 
[Y,S1,S2,S3,a,b,c] = expsmooth3(Yt,alpha,t)
function [Y,S1,S2,S3,a,b,c] = expsmooth3(Yt,alpha,t)
%Yt:原时间序列;alpha:平滑系数;t:预测时长
%Y:预测值;S1/S2/S3:一次/二次/三次指数平滑值;a/b/c:预测公式参数
n=length(Yt);
%计算一次指数平滑值
%计算二次指数平滑值
%计算三次指数平滑值
%计算参数a、b、c
for i=1:n
    a(i)=3*S1(i)-3*S2(i)+S3(i);
    b(i)=alpha/(1-alpha)^2/2 * ((6-5*alpha)*S1(i) - 2*(5-4*alpha)*S2(i) + (4-3*alpha)*S3(i));
    c(i)=alpha/(1-alpha)^2/2 * (S1(i)-2*S2(i)+S3(i));
end
%计算预测值Y
for i=1:t
    Y(i)=a(n)+b(n)*i+c(n)*i^2;
end
%绘图
plot(1:n,Yt,(n+1):(n+t),Y,'*');
end


相关文章
|
3月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
395 0
|
3月前
|
算法 定位技术 计算机视觉
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
178 0
|
3月前
|
算法 机器人 计算机视觉
【图像处理】水下图像增强的颜色平衡与融合技术研究(Matlab代码实现)
【图像处理】水下图像增强的颜色平衡与融合技术研究(Matlab代码实现)
148 0
|
3月前
|
新能源 Java Go
【EI复现】参与调峰的储能系统配置方案及经济性分析(Matlab代码实现)
【EI复现】参与调峰的储能系统配置方案及经济性分析(Matlab代码实现)
147 0
|
3月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
210 8
|
3月前
|
机器学习/深度学习 编解码 算法
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
225 8
|
3月前
|
机器学习/深度学习 数据采集 测试技术
基于CEEMDAN-VMD-BiLSTM的多变量输入单步时序预测研究(Matlab代码实现)
基于CEEMDAN-VMD-BiLSTM的多变量输入单步时序预测研究(Matlab代码实现)
133 8
|
3月前
|
机器学习/深度学习 算法 自动驾驶
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
228 8
|
3月前
|
机器学习/深度学习 供应链 算法
【电动车】基于削峰填谷的电动汽车多目标优化调度策略研究(Matlab代码实现)
【电动车】基于削峰填谷的电动汽车多目标优化调度策略研究(Matlab代码实现)
160 0
|
3月前
|
传感器 机器学习/深度学习 算法
【无人机协同】动态环境下多无人机系统的协同路径规划与防撞研究(Matlab代码实现)
【无人机协同】动态环境下多无人机系统的协同路径规划与防撞研究(Matlab代码实现)
272 0

热门文章

最新文章