小波神经网络预测MATLAB代码模板(无需调试)

Posted 噢⊙▽⊙

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小波神经网络预测MATLAB代码模板(无需调试)相关的知识,希望对你有一定的参考价值。

按要求导入数据即可预测并画图,本文无数据提供 

多输入时间序列

%% 该代码为基于小波神经网络预测
%% 清空环境变量
clc
clear
%% 网络参数配置
%多元时间序列预测(高维时间序列数据),1列代表一个序列
%先自己划分好训练集与测试集,并区分输出(input,input_test)与目标输出(output,output_test)
input=readmatrix("input.xlsx");
input_test=readmatrix("input_test.xlsx");
output=readmatrix("output.xlsx");
output_test=readmatrix("output_test.xlsx");
%以上4个导入数据仅给的导入名称示例,数据根据自己的来
M=size(input,2);
%输入节点个数,size(A,k),A是矩阵,K是维数,
%相当于工作区276X4X6 double,这是三维数组,276是一维长度,4是二维长度,6是三维长度
N=size(output,2); %输出节点个数,
%"注意该程序默认输出节点只有一个,要么自己该一下,或者一个一个节点输出预测"

n=6; %隐形节点个数
lr1=0.01; %学习概率
lr2=0.001; %学习概率
maxgen=5000; %迭代次数

%权值初始化
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';

error=zeros(1,maxgen);
%% 网络训练
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';
yuce=zeros(size(output_test,1),1);
%网络预测
for i=1:size(output_test,1)
    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('预测交通流量','实际交通流量',"Location","best",'fontsize',12)
xlabel('时间点')
ylabel('交通流量')

运行结果:

 

以上是关于小波神经网络预测MATLAB代码模板(无需调试)的主要内容,如果未能解决你的问题,请参考以下文章

预测模型基于小波神经网络的短时交通流量预测matlab源码

开盘指数预测基于matlab遗传算法优化小波神经网络股票开盘指数预测含Matlab源码 2014期

预测模型基于matlab模糊小波神经网络目标威胁评估含Matlab源码 1621期

模糊小波神经网络预测基于matlab模糊小波神经网络的攻击目标优先级评估含Matlab源码 2342期

小波神经网络的matlab程序

MATLAB实战系列(三十五)-MATLAB基于BP神经网络的光伏发电太阳辐照度预测