在线等matlab的BP神经网络预测问题?

2024-05-05 22:36

1. 在线等matlab的BP神经网络预测问题?

关于神经网络(matlab)归一化的整理
由于采集的各数据单位不一致,因而须对数据进行[-1,1]归一化处理,归一化方法主要有如下几种,供大家参考:(by james)
1、线性函数转换,表达式如下:
y=(x-MinValue)/(MaxValue-MinValue)
说明:x、y分别为转换前、后的值,MaxValue、MinValue分别为样本的最大值和最小值。
2、对数函数转换,表达式如下:
y=log10(x)
说明:以10为底的对数函数转换。
3、反余切函数转换,表达式如下:
y=atan(x)*2/PI
归一化是为了加快训练网络的收敛性,可以不进行归一化处理
归一化的具体作用是归纳统一样本的统计分布性。归一化在0-1之间是统计的概率分布,归一化在-1--+1之间是统计的坐标分布。归一化有同一、统一和合一的意思。无论是为了建模还是为了计算,首先基本度量单位要同一,神经网络是以样本在事件中的统计分别几率来进行训练(概率计算)和预测的,归一化是同一在0-1之间的统计概率分布;
当所有样本的输入信号都为正值时,与第一隐含层神经元相连的权值只能同时增加或减小,从而导致学习速度很慢。为了避免出现这种情况,加快网络学习速度,可以对输入信号进行归一化,使得所有样本的输入信号其均值接近于0或与其均方差相比很小。
归一化是因为sigmoid函数的取值是0到1之间的,网络最后一个节点的输出也是如此,所以经常要对样本的输出归一化处理。所以这样做分类的问题时用[0.9 0.1 0.1]就要比用[1 0 0]要好。
但是归一化处理并不总是合适的,根据输出值的分布情况,标准化等其它统计变换方法有时可能更好。
关于用premnmx语句进行归一化:
premnmx语句的语法格式是:[Pn,minp,maxp,Tn,mint,maxt]=premnmx(P,T)
其中P,T分别为原始输入和输出数据,minp和maxp分别为P中的最小值和最大值。mint和maxt分别为T的最小值和最大值。
premnmx函数用于将网络的输入数据或输出数据进行归一化,归一化后的数据将分布在[-1,1]区间内。
我们在训练网络时如果所用的是经过归一化的样本数据,那么以后使用网络时所用的新数据也应该和样本数据接受相同的预处理,这就要用到tramnmx。
下面介绍tramnmx函数:
[Pn]=tramnmx(P,minp,maxp)
其中P和Pn分别为变换前、后的输入数据,maxp和minp分别为premnmx函数找到的最大值和最小值。
(by terry2008)
matlab中的归一化处理有三种方法
1. premnmx、postmnmx、tramnmx
2. restd、poststd、trastd
3. 自己编程
具体用那种方法就和你的具体问题有关了
(by happy)
pm=max(abs(p(i,:))); p(i,:)=p(i,:)/pm;
和
for i=1:27
p(i,:)=(p(i,:)-min(p(i,:)))/(max(p(i,:))-min(p(i,:)));
end 可以归一到0 1 之间
0.1+(x-min)/(max-min)*(0.9-0.1)其中max和min分别表示样本最大值和最小值。
这个可以归一到0.1-0.9

在线等matlab的BP神经网络预测问题?

2. 求一个bp神经网络预测模型的MATLAB程序

BP神经网络预测的步骤:
1、输入和输出数据。
2、创建网络。fitnet()
3、划分训练,测试和验证数据的比例。net.divideParam.trainRatio; net.divideParam.valRatio;net.divideParam.testRatio
4、训练网络。 train()
5、根据图表判断拟合好坏。ploterrcorr();parcorr();plotresponse()
6、预测往后数据。net()
7、画出预测图。plot()
执行下列命令
BP_prediction
得到结果:
[ 2016, 14749.003045557066798210144042969]
[ 2017, 15092.847215188667178153991699219]
[ 2018, 15382.150005970150232315063476562]
[ 2019,  15398.85769711434841156005859375]
[ 2020, 15491.935150090605020523071289062]

3. MATLAB神经网络30个案例分析的介绍

《MATLAB神经网络30个案例分析》是史峰、王小川、郁磊、李洋编著的一本图书。该书是MATLAB中文论坛神经网络版块数千个帖子的总结,充分强调“案例实用性、程序可模仿性”。所有案例均来自于论坛会员的切身需求,保证每一个案例都与实际课题相结合。

MATLAB神经网络30个案例分析的介绍

4. 小小白求MATLAB的BP神经网络预测程序年

运行BP,得到26—35时段的EUR/USD汇率值。
[ 26, 1.1232901292657970770960673689842]
[ 27, 1.1233369030683206801768392324448]
[ 28, 1.1233598598792013945057988166809]
[ 29, 1.1233470231852606957545503973961]
[ 30, 1.1233184637383146764477714896202]
[ 31,  1.123305963829125175834633409977]
[ 32, 1.1233151128687950404128059744835]
[ 33, 1.1233352813649162271758541464806]
[ 34, 1.1233436771844935719855129718781]
[ 35,    1.1233339656746466062031686306]

5. MATLAB下神经网络的设计

我来说下我的理解,不一定对,一起讨论下吧
1.100个字母,400个数字组成的训练样本应该是可以的,因为训练样本多的话会使整个网络的权值更加接近准确的权值,500个训练样本对于图像处理来说应该不算多。
2.因为预处理后的每个字母/图片为250的向量值,所有训练样本可以组成250*500的输入矩阵,因为一共有10+26=36个分类,所以3层的神经网络为输入层250,输出层36,隐层选20左右,最终得到的输出矩阵为36*500。(期望矩阵中需要归为一类的可以设为1,其余35个向量值为0)
3.和4.应该都可以归为2中
5.图片可以用特征提取的方法来减少输入向量的维数,经典有容易理解的如PCA。

MATLAB下神经网络的设计

6. MATLAB神经网络的介绍

MATLAB中文论坛神经网络版块数千个帖子的总结,充分强调“案例实用性、程序可模仿性”。所有案例均来自于论坛会员的切身需求,保证每一个案例都与实际课题相结合。读者调用案例的时候,只要把案例中的数据换成自己需要处理的数据,即可实现自己想要的网络。如果在实现过程中有任何疑问,可以随时在MATLAB中文论坛与作者交流,作者每天在线,有问必答。该书共有30个MATLAB神经网络的案例(含可运行程序),包括BP、RBF、SVM、SOM、Hopfield、LVQ、Elman、小波等神经网络;还包含PSO(粒子群)、灰色神经网络、模糊网络、概率神经网络、遗传算法优化等内容。该书另有31个配套的教学视频帮助读者更深入地了解神经网络。《MATLAB神经网络30个案例分析》可作为本科毕业设计、研究生项目设计、博士低年级课题设计参考书籍,同时对广大科研人员也有很高的参考价值。

7. MATLAB神经网络30个案例分析的内容简介

读者调用案例的时候,只要把案例中的数据换成自己需要处理的数据,即可实现自己想要的网络。如果在实现过程中有任何疑问,可以随时在MATLAB中文论坛与作者交流,作者每天在线,有问必答。该书共有30个MATLAB神经网络的案例(含可运行程序),包括BP、RBF、SVM、SOM、Hopfield、LVQ、Elman、小波等神经网络;还包含PSO(粒子群)、灰色神经网络、模糊网络、概率神经网络、遗传算法优化等内容。该书另有31个配套的教学视频帮助读者更深入地了解神经网络。本书可作为本科毕业设计、研究生项目设计、博士低年级课题设计参考书籍,同时对广大科研人员也有很高的参考价值。

MATLAB神经网络30个案例分析的内容简介

8. MATLAB线性神经网络的程序,跪求。。

美国Michigan 大学的 Holland 教授提出的遗传算法(GeneticAlgorithm, GA)是求解复杂的组合优化问题的有效方法 ,其思想来自于达尔文进化论和门德尔松遗传学说 ,它模拟生物进化过程来从庞大的搜索空间中筛选出较优秀的解,是一种高效而且具有强鲁棒性方法。所以,遗传算法在求解TSP和 MTSP问题中得到了广泛的应用。
 
matlab程序如下:
function[opt_rte,opt_brk,min_dist] =mtspf_ga(xy,dmat,salesmen,min_tour,pop_size,num_iter)
%%
%实例
%     n = 20;%城市个数
%     xy = 10*rand(n,2);%城市坐标  随机产生,也可以自己设定
%     salesmen = 5;%旅行商个数
%     min_tour = 3;%每个旅行商最少访问的城市数
%     pop_size = 80;%种群个数
%     num_iter = 200;%迭代次数
%     a = meshgrid(1:n);
%     dmat =reshape(sqrt(sum((xy(a,:)-xy(a',:)).^2,2)),n,n);
%     [opt_rte,opt_brk,min_dist] = mtspf_ga(xy,dmat,salesmen,min_tour,...
%         pop_size,num_iter);%函数
 
%%
 
[N,dims]= size(xy); %城市矩阵大小
[nr,nc]= size(dmat); %城市距离矩阵大小
 
n = N -1;% 除去起始的城市后剩余的城市的数
 
% 初始化路线、断点的选择
num_brks= salesmen-1;
dof = n- min_tour*salesmen;       %初始化路线、断点的选择
addto =ones(1,dof+1);
for k =2:num_brks
    addto = cumsum(addto);
end
cum_prob= cumsum(addto)/sum(addto);
 
%% 初始化种群
pop_rte= zeros(pop_size,n);          %   种群路径
pop_brk= zeros(pop_size,num_brks);    % 断点集合的种群
for k =1:pop_size
    pop_rte(k,:) = randperm(n)+1;
    pop_brk(k,:) = randbreaks();
end
 
%  画图路径曲线颜色
clr =[1 0 0; 0 0 1; 0.67 0 1; 0 1 0; 1 0.5 0];
ifsalesmen > 5
    clr = hsv(salesmen);
end
 
%%
 
% 基于遗传算法的MTSP
global_min= Inf;        %初始化最短路径
total_dist= zeros(1,pop_size);
dist_history= zeros(1,num_iter);
tmp_pop_rte= zeros(8,n);%当前的路径设置
tmp_pop_brk= zeros(8,num_brks); %当前的断点设置
new_pop_rte= zeros(pop_size,n);%更新的路径设置
new_pop_brk= zeros(pop_size,num_brks);%更新的断点设置
 
foriter = 1:num_iter
    % 计算适应值
    for p = 1:pop_size
        d = 0;
        p_rte = pop_rte(p,:);
        p_brk = pop_brk(p,:);
        rng = [[1 p_brk+1];[p_brk n]]';
        for s = 1:salesmen
            d = d + dmat(1,p_rte(rng(s,1)));% 添加开始的路径
            for k = rng(s,1):rng(s,2)-1
                d = d + dmat(p_rte(k),p_rte(k+1));
            end
            d = d + dmat(p_rte(rng(s,2)),1); % 添加结束的的路径
        end
        total_dist(p) = d;
    end
 
    % 找到种群中最优路径
    [min_dist,index] = min(total_dist);
    dist_history(iter) = min_dist;
    if min_dist < global_min
        global_min = min_dist;
        opt_rte = pop_rte(index,:); %最优的最短路径
        opt_brk = pop_brk(index,:);%最优的断点设置
        rng = [[1 opt_brk+1];[opt_brk n]]';%设置记录断点的方法
 
            figure(1);
            for s = 1:salesmen
                rte = [1 opt_rte(rng(s,1):rng(s,2))1];
              
            plot(xy(rte,1),xy(rte,2),'.-','Color',clr(s,:));
                title(sprintf('城市数目为 = %d,旅行商数目为 = %d,总路程 = %1.4f, 迭代次数 =%d',n+1,salesmen,min_dist,iter));
                hold on
                grid on
            end
          
            plot(xy(1,1),xy(1,2),'ko');
            hold off
 
    end
 
    % 遗传操作
    rand_grouping = randperm(pop_size);
    for p = 8:8:pop_size
        rtes = pop_rte(rand_grouping(p-7:p),:);
        brks = pop_brk(rand_grouping(p-7:p),:);
        dists =total_dist(rand_grouping(p-7:p));
        [ignore,idx] = min(dists);
        best_of_8_rte = rtes(idx,:);
        best_of_8_brk = brks(idx,:);
        rte_ins_pts = sort(ceil(n*rand(1,2)));
        I = rte_ins_pts(1);
        J = rte_ins_pts(2);
        for k = 1:8 %产生新种群
            tmp_pop_rte(k,:) = best_of_8_rte;
            tmp_pop_brk(k,:) = best_of_8_brk;
            switch k
                case 2% 倒置操作
                    tmp_pop_rte(k,I:J) =fliplr(tmp_pop_rte(k,I:J));
                case 3  % 互换操作
                    tmp_pop_rte(k,[I J]) =tmp_pop_rte(k,[J I]);
                case 4 % 滑动平移操作
                    tmp_pop_rte(k,I:J) =tmp_pop_rte(k,[I+1:J I]);
                case 5% 更新断点
                    tmp_pop_brk(k,:) = randbreaks();
                case 6  % 倒置并更新断点
                    tmp_pop_rte(k,I:J) =fliplr(tmp_pop_rte(k,I:J));
                    tmp_pop_brk(k,:) =randbreaks();
                case 7 % 互换并更新断点
                    tmp_pop_rte(k,[I J]) =tmp_pop_rte(k,[J I]);
                    tmp_pop_brk(k,:) =randbreaks();
                case 8 % 评议并更新断点
                    tmp_pop_rte(k,I:J) =tmp_pop_rte(k,[I+1:J I]);
                    tmp_pop_brk(k,:) =randbreaks();
                otherwise
            end
        end
        new_pop_rte(p-7:p,:) = tmp_pop_rte;
        new_pop_brk(p-7:p,:) = tmp_pop_brk;
    end
    pop_rte = new_pop_rte;
    pop_brk = new_pop_brk;
end
 
 
   figure(2)
    plot(dist_history,'b','LineWidth',2);
    title('历史最优解');
    xlabel('迭代次数')
  ylabel('最优路程')
 
 
 
   % 随机产生一套断点 的集合
    function breaks = randbreaks()
        if min_tour == 1 % 一个旅行商时,没有断点的设置
            tmp_brks = randperm(n-1);
            breaks =sort(tmp_brks(1:num_brks));
        else % 强制断点至少找到最短的履行长度
            num_adjust = find(rand <cum_prob,1)-1;
            spaces =ceil(num_brks*rand(1,num_adjust));
            adjust = zeros(1,num_brks);
            for kk = 1:num_brks
                adjust(kk) = sum(spaces == kk);
            end
            breaks = min_tour*(1:num_brks) +cumsum(adjust);
        end
    end
disp('最优路径为:/n')
disp(opt_rte);
disp('其中断点为为:/n')
disp(opt_brk);
end