数学建模 MATLAB学习 vol.1

突然被室友拉着参加数学建模比赛,就当是一点学习笔记吧 杂七杂八的

BP神经网络
一、Matlab中BP神经网络的构建和初始化

训练前馈网络的第一步是建立网络对象。函数newff建立一个可训练的前馈网络。这需要4个输入参数。第一个参数是一个Rx2的矩阵以定义R个输入向量的最小值和最大值。第二个参数是一个网络每层神经元个数的数组。第三个参数是包含每层用到的转移函数名称的细胞数组。最后一个参数是用到的训练函数的名称。

下面命令将创建一个二层网络。它的输入是两个元素的向量,第一层有三个神经元,第二层有一个神经元。第一层的转移函数是tan-sigmoid,输出层的转移函数是linear。输入向量的第一个元素的范围是-1到2,输入向量的第二个元素的范围是0到5,训练函数是traingd。

net=newff([-1 2; 0 5],[3,1],{‘tansig’,‘purelin’},‘traingd’);

    这个命令建立了网络对象并且初始化了网络权重和偏置,因此网络就可以进行训练了。我们可能要多次重新初始化权重或者进行自定义的初始化。下面就是初始化的详细步骤。

    在训练前馈网络之前,权重和偏置必须被初始化。初始化权重和偏置的工作用命令init来实现。这个函数接收网络对象并初始化权重和偏置后返回网络对象。下面就是网络如何初始化的: 

net = init(net);

我们可以通过设定网络参数net.initFcn和net.layer{i}.initFcn这一技巧来初始化一个给定的网络。net.initFcn用来决定整个网络的初始化函数。前馈网络的缺省值为initlay,它允许每一层用单独的初始化函数。设定了net.initFcn,那么参数net.layer{i}.initFcn 也要设定用来决定每一层的初始化函数。

对前馈网络来说,有两种不同的初始化方式经常被用到:initwb和initnw。initwb函数根据每一层自己的初始化参数(net.inputWeights{i,j}.initFcn)初始化权重矩阵和偏置。前馈网络的初始化权重通常设为rands,它使权重在-1到1之间随机取值。这种方式经常用在转换函数是线性函数时。initnw通常用于转换函数是曲线函数。它根据Nguyen和Widrow[NgWi90]为层产生初始权重和偏置值,使得每层神经元的活动区域能大致平坦的分布在输入空间。它比起单纯的给权重和偏置随机赋值有以下优点:

(1)减少神经元的浪费(因为所有神经元的活动区域都在输入空间内)。

(2)有更快的训练速度(因为输入空间的每个区域都在活动的神经元范围中)。

初始化函数被newff所调用。因此当网络创建时,它根据缺省的参数自动初始化。init不需要单独的调用。可是我们可能要重新初始化权重和偏置或者进行自定义的初始化。例如,我们用newff创建的网络,它缺省用initnw来初始化第一层。如果我们想要用rands重新初始化第一层的权重和偏置,我们用以下命令:

net.layers{1}.initFcn = ‘initwb’;
net.inputWeights{1,1}.initFcn = ‘rands’;
net.biases{1,1}.initFcn = ‘rands’;
net.biases{2,1}.initFcn = ‘rands’;
net = init(net);

粒子群算法模型

影响粒子群算法性能的参数主要有,粒子群的规模、惯性权重w、学习因子c1,c2、最大限制速度Vmax

惯性权重w
较大的w有利于提高算法的全局搜索能力
较小的w会增加算法的局部搜索能力
在权重改进的PSO算法中,w随进化的代数的增加而线性递减的方式,有效解决PSO算法早熟和算法后期容易在全局最优解附近产生振荡的现象

C-PSO算法 改进参数

罚函数 基本思想 将约束优化问题变为无约束问题。约束函数的某种组合组成的一个惩罚项,加在原来的目标函数来迫使迭代点逼近可行域。

启发式算法
粒子群算法PSO
遗传算法GA
人群搜索算法SOA
模拟退火算法SA
蚁群算法ACO
鱼群算法FSA

你可能感兴趣的:(数学建模 MATLAB学习 vol.1)