小波神经网络的时间序列预测-短时交通流量预测
更新时间:2023-10-26 02:18:01 阅读量: 综合文库 文档下载
- bp神经网络时间序列预测推荐度:
- 相关推荐
%% 清空环境变量 clc clear
%% 网络参数配置
load traffic_flux input output input_test output_test
M=size(input,2); %输入节点个数 N=size(output,2); %输出节点个数
n=6; %隐形节点个数 lr1=0.01; %学习概率 lr2=0.001; %学习概率 maxgen=100; %迭代次数
%权值初始化
Wjk=randn(n,M);Wjk_1=Wjk;Wjk_2=Wjk_1; Wij=randn(N,n);Wij_1=Wij;Wij_2=Wij_1; a=randn(1,n);a_1=a;a_2=a_1; b=randn(1,n);b_1=b;b_2=b_1;
%节点初始化 y=zeros(1,N); net=zeros(1,n); net_ab=zeros(1,n);
%权值学习增量初始化 d_Wjk=zeros(n,M); d_Wij=zeros(N,n); d_a=zeros(1,n);
d_b=zeros(1,n);
%% 输入输出数据归一化
[inputn,inputps]=mapminmax(input'); [outputn,outputps]=mapminmax(output'); inputn=inputn'; outputn=outputn';
%% 网络训练 for i=1:maxgen
%误差累计 error(i)=0;
% 循环训练 for kk=1:size(input,1) x=inputn(kk,:); yqw=outputn(kk,:);
for j=1:n for k=1:M
net(j)=net(j)+Wjk(j,k)*x(k); net_ab(j)=(net(j)-b(j))/a(j); end
temp=mymorlet(net_ab(j)); for k=1:N
y=y+Wij(k,j)*temp; %小波函数 end end
%计算误差和
error(i)=error(i)+sum(abs(yqw-y));
%权值调整 for j=1:n
%计算d_Wij
temp=mymorlet(net_ab(j)); for k=1:N
d_Wij(k,j)=d_Wij(k,j)-(yqw(k)-y(k))*temp; end
%计算d_Wjk
temp=d_mymorlet(net_ab(j)); for k=1:M for l=1:N
d_Wjk(j,k)=d_Wjk(j,k)+(yqw(l)-y(l))*Wij(l,j) ; end
d_Wjk(j,k)=-d_Wjk(j,k)*temp*x(k)/a(j); end %计算d_b for k=1:N
d_b(j)=d_b(j)+(yqw(k)-y(k))*Wij(k,j); end
d_b(j)=d_b(j)*temp/a(j); %计算d_a for k=1:N
d_a(j)=d_a(j)+(yqw(k)-y(k))*Wij(k,j); end
d_a(j)=d_a(j)*temp*((net(j)-b(j))/b(j))/a(j); end
%权值参数更新 Wij=Wij-lr1*d_Wij; Wjk=Wjk-lr1*d_Wjk; b=b-lr2*d_b; a=a-lr2*d_a;
d_Wjk=zeros(n,M); d_Wij=zeros(N,n); d_a=zeros(1,n); d_b=zeros(1,n);
y=zeros(1,N); net=zeros(1,n); net_ab=zeros(1,n);
Wjk_1=Wjk;Wjk_2=Wjk_1; Wij_1=Wij;Wij_2=Wij_1; a_1=a;a_2=a_1; b_1=b;b_2=b_1; end end
%% 网络预测 %预测输入归一化
x=mapminmax('apply',input_test',inputps); x=x';
%网络预测 for i=1:92 x_test=x(i,:);
for j=1:1:n for k=1:1:M
net(j)=net(j)+Wjk(j,k)*x_test(k); net_ab(j)=(net(j)-b(j))/a(j); end
temp=mymorlet(net_ab(j)); for k=1:N
y(k)=y(k)+Wij(k,j)*temp ; end end
yuce(i)=y(k); y=zeros(1,N); net=zeros(1,n); net_ab=zeros(1,n); end
%预测输出反归一化
ynn=mapminmax('reverse',yuce,outputps);
%% 结果分析 figure(1) plot(ynn,'r*:') hold on
plot(output_test,'bo--')
title('预测交通流量','fontsize',12) legend('预测交通流量','实际交通流量') xlabel('时间点') ylabel('交通流量')
%这里面用到的两个子程序分别是: function y=mymorlet(t)
y = exp(-(t.^2)/2) * cos(1.75*t); function y=d_mymorlet(t)
y = -1.75*sin(1.75*t).*exp(-(t.^2)/2)-t* cos(1.75*t).*exp(-(t.^2)/2) ;
%这里面用到的两个子程序分别是: function y=mymorlet(t)
y = exp(-(t.^2)/2) * cos(1.75*t); function y=d_mymorlet(t)
y = -1.75*sin(1.75*t).*exp(-(t.^2)/2)-t* cos(1.75*t).*exp(-(t.^2)/2) ;
正在阅读:
2018年中考英语:情景交际01-21
Excel关于账务处理05-17
电视包装的字幕系统08-13
三年级盈亏问题练习题06-22
蝶作文800字07-10
季节性施工措施(雨季、夏季、冬季)05-11
数据库系统概论试题及答案123410-03
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 预测
- 时间序列
- 短时
- 神经网络
- 流量
- 交通