• 备战数学建模46-小波神经网络WNN(攻坚站11)


    我们之前学过BP神经网络,今天我们学习一下小波神经网络,和BP神经网络相比,小波神经网络拥有小波变换的优点,避免了 BP 网络设计结构上的盲目性,但是隐含层的节点数以及各层之间的权值、尺度因子的初始化参数难以确定,会影响网络的收敛速度。在后续的学习中,可以尝试其他小波函数的神经网络,通过比较其最优结果构造小波神经网络。

    目录

    一、小波神经网络案例

    1.1、比较BP神经网络和小波神经网络

    1.2、小波神经网络建立

     1.3、小波神经网络的预测流程图

    1.4、数据集准备

     1.5、小波神经网络预测短时交通流MATLAB代码及结果分析

    1.6、小结


    一、小波神经网络案例

    1.1、比较BP神经网络和小波神经网络

    我们首先看一下BP神经网络,BP 网络的实现过程主要分成两个阶段,第一阶段是信号的前向传播,从输入层经过隐含层到达输出层,第二阶段是误差的反向传播,从输出层经过隐含层到达输入层。误差传递完后,依次调节输入层和隐含层之间的权值和偏置,以及隐含层和输出层之间的权值和偏置。如图所示:

     BP神经网络的神经元如下所示,一般使用的激活函数是sigmoid函数,如下:

     

    小波变换是以 Fourier 分析为基础的一种新的数学变换手段,它克服了 Fourier变换的局限性以及加窗 Fourier 变换的窗口不变的缺点。小波变换主要通过伸缩和平移实现多尺度细化,突出所要处理的问题细节,有效提取局部信息。小波神经网络是改进的BP网络,将原先的隐含层的Sigmiod激活函数替换为小波函数——Morlet小波,其表达式为:


    1.2、小波神经网络建立

    我们看一下这个小波神经网络,相比BP神经网络,将原先的隐含层的Sigmiod激活函数替换为小波函数。

     

     

     1.3、小波神经网络的预测流程图

    小波神经网络的预测过程如下,初始化网络权值和伸缩平移尺度等参数,计算误差,根据误差调整参数,根据训练集训练出较好的网络,然后根据网络进行预测。

     

    1.4、数据集准备

    数据划分为训练集数据和测试集数据,训练276组,测试集92组,输入为交通相关的四个参数,输出是交通流量。

     1.5、小波神经网络预测短时交通流MATLAB代码及结果分析

     下面看一下小波神经网络的matlab代码:

    1. %% 清空环境变量
    2. clc
    3. clear
    4. %% 网络参数配置
    5. load traffic_flux input output input_test output_test
    6. M=size(input,2); %输入节点个数
    7. N=size(output,2); %输出节点个数
    8. n=6; %隐藏层节点个数
    9. lr1=0.01; %学习速率
    10. lr2=0.001; %学速率速率
    11. maxgen=100; %迭代次数
    12. %初始化输入层到隐含层,隐含层到输出层的权值
    13. Wjk=randn(n,M);Wjk_1=Wjk;Wjk_2=Wjk_1;
    14. Wij=randn(N,n);Wij_1=Wij;Wij_2=Wij_1;
    15. %初始化伸缩因子
    16. a=randn(1,n);a_1=a;a_2=a_1;
    17. b=randn(1,n);b_1=b;b_2=b_1;
    18. %节点初始化
    19. y=zeros(1,N);
    20. net=zeros(1,n);
    21. net_ab=zeros(1,n);
    22. %权值学习增量初始化
    23. d_Wjk=zeros(n,M);
    24. d_Wij=zeros(N,n);
    25. d_a=zeros(1,n);
    26. d_b=zeros(1,n);
    27. %% 输入输出数据归一化
    28. [inputn,inputps]=mapminmax(input');
    29. [outputn,outputps]=mapminmax(output');
    30. inputn=inputn';
    31. outputn=outputn';
    32. %% 网络训练
    33. for i=1:maxgen
    34. %误差累计
    35. error(i)=0;
    36. % 循环训练
    37. for kk=1:size(input,1)
    38. x=inputn(kk,:);
    39. yqw=outputn(kk,:);
    40. for j=1:n
    41. for k=1:M
    42. net(j)=net(j)+Wjk(j,k)*x(k);
    43. net_ab(j)=(net(j)-b(j))/a(j);
    44. end
    45. temp = exp(-(net_ab(j).^2)/2) * cos(1.75*net_ab(j));
    46. %temp=mymorlet(net_ab(j)); %小波函数
    47. for k=1:N
    48. y=y+Wij(k,j)*temp; %计算输出
    49. end
    50. end
    51. %计算误差和
    52. error(i)=error(i)+sum(abs(yqw-y));
    53. %权值调整
    54. for j=1:n
    55. %计算d_Wij,隐藏层和输出层权值调整
    56. temp=exp(-(net_ab(j).^2)/2) * cos(1.75*net_ab(j));
    57. for k=1:N
    58. d_Wij(k,j)=d_Wij(k,j)-(yqw(k)-y(k))*temp;
    59. end
    60. %计算d_Wjk,输入层到隐藏层权值调整
    61. temp = -1.75*sin(1.75*net_ab(j)).*exp(-(net_ab(j).^2)/2)-net_ab(j)* cos(1.75*net_ab(j)).*exp(-(net_ab(j).^2)/2) ;
    62. for k=1:M
    63. for l=1:N
    64. d_Wjk(j,k)=d_Wjk(j,k)+(yqw(l)-y(l))*Wij(l,j) ;
    65. end
    66. d_Wjk(j,k)=-d_Wjk(j,k)*temp*x(k)/a(j);
    67. end
    68. %计算d_b,伸缩因子
    69. for k=1:N
    70. d_b(j)=d_b(j)+(yqw(k)-y(k))*Wij(k,j);
    71. end
    72. d_b(j)=d_b(j)*temp/a(j);
    73. %计算d_a,伸缩因子
    74. for k=1:N
    75. d_a(j)=d_a(j)+(yqw(k)-y(k))*Wij(k,j);
    76. end
    77. d_a(j)=d_a(j)*temp*((net(j)-b(j))/b(j))/a(j);
    78. end
    79. %权值参数更新
    80. Wij=Wij-lr1*d_Wij;
    81. Wjk=Wjk-lr1*d_Wjk;
    82. b=b-lr2*d_b;
    83. a=a-lr2*d_a;
    84. d_Wjk=zeros(n,M);
    85. d_Wij=zeros(N,n);
    86. d_a=zeros(1,n);
    87. d_b=zeros(1,n);
    88. y=zeros(1,N);
    89. net=zeros(1,n);
    90. net_ab=zeros(1,n);
    91. Wjk_1=Wjk;Wjk_2=Wjk_1;
    92. Wij_1=Wij;Wij_2=Wij_1;
    93. a_1=a;a_2=a_1;
    94. b_1=b;b_2=b_1;
    95. end
    96. end
    97. %% 网络预测
    98. %预测输入归一化
    99. x=mapminmax('apply',input_test',inputps);
    100. x=x';
    101. %网络预测
    102. for i=1:92
    103. x_test=x(i,:);
    104. for j=1:1:n
    105. for k=1:1:M
    106. net(j)=net(j)+Wjk(j,k)*x_test(k);
    107. net_ab(j)=(net(j)-b(j))/a(j);
    108. end
    109. temp=exp(-(net_ab(j).^2)/2) * cos(1.75*net_ab(j));
    110. for k=1:N
    111. y(k)=y(k)+Wij(k,j)*temp ;
    112. end
    113. end
    114. yuce(i)=y(k);
    115. y=zeros(1,N);
    116. net=zeros(1,n);
    117. net_ab=zeros(1,n);
    118. end
    119. %预测输出反归一化
    120. ynn=mapminmax('reverse',yuce,outputps);
    121. %% 结果分析
    122. figure(1)
    123. plot(ynn,'r*:')
    124. hold on
    125. plot(output_test,'bo--')
    126. title('预测交通流量','fontsize',12)
    127. legend('预测交通流量','实际交通流量')
    128. xlabel('时间点')
    129. ylabel('交通流量')

    这次使用了两个Morlet小波函数:用来更新各层之间的权重和伸缩因子。

    y = exp(-(t.^2)/2) * cos(1.75*t);

    y = -1.75*sin(1.75*t).*exp(-(t.^2)/2)-t* cos(1.75*t).*exp(-(t.^2)/2) ;

    预测的效果如下所示,可以发现使用测试集进行预测,预测的交通流量和实际的交通流量较为接近,网络模型的泛化能力较好。

     

    1.6、小结

    小波神经网络(Wavelet Neural Network, WNN)是在小波分析研究获得突破的基础上提出的一种人工神经网络。它是基于小波分析理论以及小波变换所构造的一种分层的、多分辨率的新型人工神经网络模型。即用非线性小波基取代了通常的非线性Sigmoid 函数,其信号表述是通过将所选取的小波基进行线性叠加来表现的。它避免了BP 神经网络结构设计的盲目性和局部最优等非线性优化问题,大大简化了训练,具有较强的函数学习能力和推广能力及广阔的应用前景。

  • 相关阅读:
    dpdk ring多/单生产者、多/单消费者
    UGUI交互组件ScrollView
    Delaunay三角剖分算法
    [问题记录]Qt使用QPainter在QImage、QBitmap、QPixmap上面绘图时出现杂色
    三、python Django模板[jinja2模板]
    【FAQ】【ArkUI】ETS 怎么创建实体类和引用
    MATLAB点云处理(二十六):将无序点云转换为有序点云(pcorganize),删除无效点(removeInvalidPoints)
    目前的网络情况与特点
    37. UE5 RPG创建自定义的Ability Task
    把ipa文件上传到App Store教程步骤
  • 原文地址:https://blog.csdn.net/nuist_NJUPT/article/details/126820813