小波神经网络的时间序列预测——短时交通流量预测

        大家好,我是带我去滑雪!

       小波神经网络(Wavelet Neural Network,WNN)结合了小波变换和神经网络的特性,是一种在信号处理和模式识别领域应用广泛的神经网络模型。它的设计灵感来自于小波变换的多尺度分析特性和神经网络的非线性映射能力,通过将小波变换与神经网络结合,旨在更好地处理复杂的信号和数据。小波变换是一种数学工具,用于将信号分解为不同尺度的成分。小波变换的多尺度分析能力使得小波神经网络能够更好地捕捉信号的局部特征。小波神经网络的基础是神经元和神经网络的结构。神经元的激活函数通常采用小波函数,以利用小波的局部特性。

      本期将利用小波神经网络实现短时交通流量预测。

目录

一、问题背景与模型建立

(1)小波理论

(2)小波神经网络

 (3)数据

二、代码实现与结果分析

(1)小波神经网络初始化

(2)小波神经网络训练

(3)小波函数及小波函数偏导数

(4) 小波神经网络预测

(5) 结果分析


一、问题背景与模型建立

(1)小波理论

       小波分析是针对傅里叶变换的不足发展而来的。傅里叶变换是信号处理领域中应用最广泛的一种分析手段,然而它有一个严重的不足,就是变换时抛弃了时间信息,通过变换结果无法判断某个信号发生的时间,即傅里叶变换在时域中没有分辨能力。小波是一种长度有限、平均值为0的波形,它的特点包括:时域都具有紧支集或近似紧支集;直流分量为0。小波函数是由一个母小波函数经过平移与尺寸伸缩得到,小波分析把信号分解成一系列小波函数的叠加。

(2)小波神经网络

        小波神经网络的基础是神经元和神经网络的结构。神经元的激活函数通常采用小波函数,以利用小波的局部特性。小波神经网络权值参数修正算法类似于BP神经网络权值修正算法,采用梯度修正法修正网络的权值和小波基函数参数,从而使小波神经网络预测输出不断逼近期望输出。小波神经网络算法训练步骤如下:

小波神经网络(Wavelet Neural Network,WNN)的训练步骤通常包括以下几个关键步骤:

  • 数据准备: 收集并准备用于训练和测试的数据集。数据集应包含输入特征和相应的目标输出。确保数据的质量和合理性是训练成功的基础。
  • 小波变换: 对输入信号进行小波变换,以获取多尺度的表示。这有助于网络更好地捕捉信号的局部特征。常用的小波函数有Haar、Daubechies、和Gaussian等。
  • 网络结构设计: 定义小波神经网络的结构,包括网络的层数、每层的神经元数量、激活函数的选择等。这一步涉及到确定网络的拓扑结构,以便有效地学习输入与输出之间的映射。
  • 权重初始化: 对网络的权重进行初始化。合适的权重初始化有助于加速网络的收敛过程。一般来说,可以采用随机初始化的方法。
  • 前向传播: 将输入信号通过网络进行前向传播,得到网络的输出。这涉及到将输入信号通过每一层的神经元,最终得到网络的输出结果。
  • 误差计算: 计算网络输出与实际目标之间的误差。这可以使用各种损失函数来衡量,例如均方误差(Mean Squared Error,MSE)。
  • 反向传播: 使用反向传播算法来调整网络的权重,以减小误差。这涉及计算梯度并使用梯度下降或其他优化算法来更新权重。
  • 迭代训练: 重复进行前向传播、误差计算和反向传播的步骤,直到网络的性能满足预定的标准或训练次数达到预定值。
  • 验证和调优: 使用验证集对网络进行评估,检查模型的泛化性能。根据验证结果,可能需要调整网络结构、学习率等超参数,以优化模型的性能。
  • 测试: 使用测试集对最终训练好的网络进行评估,以评估模型在新数据上的性能。

 (3)数据

       首先采集4天的交通流量数据,每隔15分钟记录一次该段时间内的交通流量,一共记录384个时间点的数据,用3天共288个交通流量的数据训练小波神经网络,最后用训练好的小波神经网络预测第4天的交通流量。

二、代码实现与结果分析

(1)小波神经网络初始化

load traffic_flux input output input_test output_testM=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';

(2)小波神经网络训练

for i=1:maxgen%误差累计error(i)=0;% 循环训练for kk=1:size(input,1)x=inputn(kk,:);yqw=outputn(kk,:);for j=1:nfor k=1:Mnet(j)=net(j)+Wjk(j,k)*x(k);net_ab(j)=(net(j)-b(j))/a(j);endtemp=mymorlet(net_ab(j));for k=1:Ny=y+Wij(k,j)*temp;   %小波函数endend%计算误差和error(i)=error(i)+sum(abs(yqw-y));%权值调整for j=1:n%计算d_Wijtemp=mymorlet(net_ab(j));for k=1:Nd_Wij(k,j)=d_Wij(k,j)-(yqw(k)-y(k))*temp;end%计算d_Wjktemp=d_mymorlet(net_ab(j));for k=1:Mfor l=1:Nd_Wjk(j,k)=d_Wjk(j,k)+(yqw(l)-y(l))*Wij(l,j) ;endd_Wjk(j,k)=-d_Wjk(j,k)*temp*x(k)/a(j);end%计算d_bfor k=1:Nd_b(j)=d_b(j)+(yqw(k)-y(k))*Wij(k,j);endd_b(j)=d_b(j)*temp/a(j);%计算d_afor k=1:Nd_a(j)=d_a(j)+(yqw(k)-y(k))*Wij(k,j);endd_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

(3)小波函数及小波函数偏导数

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) ;

(4) 小波神经网络预测

x=mapminmax('apply',input_test',inputps);
x=x';
yuce=zeros(92,1);
%网络预测
for i=1:92x_test=x(i,:);for j=1:1:nfor k=1:1:Mnet(j)=net(j)+Wjk(j,k)*x_test(k);net_ab(j)=(net(j)-b(j))/a(j);endtemp=mymorlet(net_ab(j));for k=1:Ny(k)=y(k)+Wij(k,j)*temp ; endendyuce(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('预测交通流量','实际交通流量','fontsize',12)
xlabel('时间点')
ylabel('交通流量')

(5) 结果分析

        小波神经网络预测与实际情况比较图:

通过图像可以发现,小波神经网络能够比较精确地预测短时交通流量,网络预测值接近期望值。 

需要数据集的家人们可以去百度网盘(永久有效)获取:

链接:
提取码:2138 


更多优质内容持续发布中,请移步主页查看。

   点赞+关注,下次不迷路!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/177134.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JSP注释方式演示 讲解显式与隐式注释

好 今天我们来了解一下jsp中的注释哦 它支持两种注释: 显式注释/隐式注释 显式注释 是 允许被客户端看到的 就是 打开浏览器 用查看源码方式能看到的注释 与之对应 隐式注释 就是 在客户端 是无法看到这些注释信息的 显式注释 的语法就是html的注释语法 <!-- 显式注释 --…

AdaBoost:提升机器学习的力量

一、介绍 机器学习已成为现代技术的基石&#xff0c;为从推荐系统到自动驾驶汽车的一切提供动力。在众多机器学习算法中&#xff0c;AdaBoost&#xff08;Adaptive Boosting的缩写&#xff09;作为一种强大的集成方法脱颖而出&#xff0c;为该领域的成功做出了重大贡献。AdaBoo…

node将package.json中的包降为低版本或者升级为高版本

前言 比如现在你用某个包的当前版本&#xff0c;但是你安装的版本高了&#xff0c;那么你应该这么做 1.首先删除node项目中的node_modules目录&#xff0c;防止安装时的包不一致 如果没安装就忽略 例如将package.json中的view-design包降为^4.6.1,当前view-design的版本为^4.…

解决LX音乐切换音乐来源失败问题

之前免费听歌神器落雪音乐不能用了&#xff0c;原因懂得都懂 LX音乐Github链接 可以通过切换音乐来源进行解决 一、下载自定义音源文件 免费下载链接 下载一 百度网盘&#xff1a;1o7v 下载二 CSDN资源&#xff1a;自定义音源 全部音源文件来源 蓝奏云&#xff1a;8mno 下…

QT QDockWidget

QDockWidget是Qt中的一个容器类&#xff0c;用于在主窗口上创建可停靠的子窗口。 设置停靠窗口的一般流程如下: (1)创建一个QDockWidget 对象的停靠窗体。 (2)设置此停靠窗体的属性&#xff0c;通常调用setFeatures()及setAllowedAreas()两种方法。 (3)新建一个要插入停靠窗…

CentOS修改root用户密码

一、适用场景 1、太久没有登录CentOS系统&#xff0c;忘记管理密码。 2、曾经备份的虚拟化OVA或OVF模板&#xff0c;使用模板部署新系统后&#xff0c;忘记root密码。 3、被恶意攻击修改root密码后的紧急修复。 二、实验环境 1、VMware虚拟化的ESXI6.7下&#xff0c;通过曾经…

探索SOLIDWORKS 3DE云平台:产品数据管理与协作的新时代

SOLIDWORKS 3DE云平台为企业提供了基于云端的全方位解决方案&#xff0c;涵盖了产品设计、仿真验证、制造与生产、市场与营销、数据管理和生命周期等领域。通过这一平台&#xff0c;企业能够将创意转化为现实所需的一切资源。同时&#xff0c;3DE云平台还帮助企业摆脱了IT限制&…

图数据库Neo4j详解

文章目录 第一章 图和Neo4j1.1 图数据库概念1.1.1 图论起源1.1.2 节点-关系及图1.1.3 图数据库1.1.4 图数据库分类1.1.4 图数据库应用场景1.1.5 与关系型数据库对比1.1.6 图数据库优势 1.2 Neo4j介绍1.2.1 Neo4j是什么1.2.2 Neo4j特点1.2.3 Neo4j的优势1.2.4 Neo4j的限制1.2.5 …

【python】单词接龙

题目&#xff1a; 这是一个关于“单词接龙”的算法题目。在这个游戏中&#xff0c;我们需要从给定的一组单词中&#xff0c;以特定的开头字母构造出一条最长的“龙”。每个单词在这条“龙”中最多出现两次。当两个单词相连时&#xff0c;它们的重合部分被合并成一个。例如&…

VS2017新建.hpp文件

目录 1、新建h文件的方法&#xff1a;2、新建对用的cpp文件&#xff1a;3、在main.cpp中调用 1、新建h文件的方法&#xff1a; 2、新建对用的cpp文件&#xff1a; 3、在main.cpp中调用 参见大佬博客

锐捷网络NBR700G 信息泄露漏洞复现 [附POC]

文章目录 锐捷网络NBR700G 信息泄露漏洞复现 [附POC]0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现 0x06 修复建议 锐捷网络NBR700G 信息泄露漏洞复现 [附POC] 0x01 前言 免责声明&#xff1a;请勿利用文章内的相关技术从事非…

充电台灯好还是插电的好?五款热门插电护眼台灯推荐

选择充电式台灯还是插电式台灯需要根据不同的需求和考虑因素进行权衡&#xff0c;如果需要在没有电源插座的地方使用或者需要频繁移动&#xff0c;充电式台灯是更好的选择&#xff1b;如果需要长时间稳定使用&#xff0c;插电式台灯是更好的选择。同时&#xff0c;我们还应该注…