电源设计应用
本文应用一种自适应递阶遗传算法同时优化神经网络结构和连接权重进行三相桥式全控整流电路故障诊断。利用自适应递阶遗传算法同时优化神经网络结构和连接权重,很好地解决了以往利用神经网络进行故障诊断的不足,并用三相桥式全控整流电路故障诊断仿真实例证明了该方法的正确性和有效性。
1 基于改进递阶遗传算法BP网络分类器的设计
1.1 递阶遗传算法
K.F.Man等根据染色体中的基因结构存在递阶形式,即一些基因控制另一些基因的活动,提出了递阶遗传算法(Hierarchical Genetic Algorithm,HGA)。
为了简要说明控制基因的活动,用整数“1”表示每一个正在激活的控制基因;用整数“0”表示每一个没有激活的控制基因。当控制基因用整数“1”标识时,表示其相连的下级结构的基因处于活动状态;当控制基因用整数“0”标识时,表示其相连的下级结构的基因处于不活动状态。这种递阶结构意味着染色体比普通遗传算法中的染色体包含的信息多,从而能够处理更为复杂的问题。因此,称编码为递阶结构染色体的遗传算法为递阶遗传算法。
如图1所示,两条染色体各是由5个控制基因和5个整数表示的参数基因组成。
其表示分别为:
从图1可以看出,XA,XB表示染色体的长度分别为3和2,这意味着在递阶染色体结构中,虽然两条染色体的长度相同,而其表示的长度可能不同。因此,递阶遗传算法能够搜索出所有参数中适合最终目标函数的参数的长度。而且,根据具体问题,染色体可以设计为多级递阶结构,从而形成多层的染色体结构。
本文采用二级递阶结构染色体描述BP网络结构和参数,其中,控制基因串表示隐节点,参数基因串表示网络的权重和相应的阈值。递阶遗传算法在操作过程中,不仅改变控制基因串的状况,而且改变参数基因串的取值。因此,训练过程中网络参数和拓扑结构可同时优化。
1.2 编码结构
染色体递阶结构及编码如图2所示,其中,控制基因按设定的比较大的初始隐节点数(可以根据经验公式得到,其中,d为输入神经元个数,n为输出神经元个数,a为1~10之间的常数)由遗传算法随机生成0,1编码,1的个数即为有效的隐节点个数,参数基因为隐节点对应的权值及阈值,由遗传算法随机生成实数编码。另外,在参数基因串的最后附加上不受控制基因控制的输出节点的阈值参数。当达到训练代数或停止准则时,控制基因串中1的个数即为最佳隐节点个数,1所对应的参数基因串即为该隐节点对应的最优结构参数。
1.3 适应值函数
训练神经网络的目标是使神经网络的精确度和复杂度都达到最小,这是一个双目标优化问题。BP网络的复杂度由隐层节点数决定,精度由网络输出与期望输出之间的误差决定,考虑到训练的目标,建立适值函数如下:
式中:m为隐节点数;d为网络输入节点数;a,b和c为待定系数;表示第i个输入样本对应的网络输出;yi为期望输出;N为样本数。根据大量实验结果,适值函数的系数分别如下取值效果是比较好的,即a=0.95,b=0.05,c=3。神经网络训练误差为:
1.4 无回放余数随机选择
无回放余数随机选择法结合了基于概率的选择方法和确定方式的选择方法,可确保适应度比平均适应度大的一些个体一定能被遗传到下一代群体,选择误差比较小。其具体步骤如下:
(1)计算群体中每个个体在下一代群体中的生存期望数目(N为种群规模,fiti为个体i的适应值):
(2)取Ni的整数部分int Ni为对应个体在下一代群体中的生存数目。这样共可确定出下一代群体中的个个体
(3)以为各个个体的新的适应度,再用基本的比例选择方法来随机确定下一代群体中还未确定的个个体。
1.5 交叉和变异算子
由前述介绍可知递阶遗传算法染色体的结构是固定的,所以与常规遗传算法的操作运算相比没有多大差异。因此,标准的交叉和变异算子同样分别适用于染色体中不同级别的染色体串,即对不同级别的染色体串,交叉和变异遗传算法中的交叉概率和变异概率是两个极为重要的控制参数,它们的选择是影响遗传算法行为和性能的关键所在。选取固定的交叉概率和变异概率易使遗传算法产生早熟收敛,陷入局部极值。
Srinivas等提出了自适应遗传算法(Adaptive GA,AGA):
式中:fmax表示种群个体的最大适应度;favg表示种群的平均适应度;f’表示参与交叉的两个个体中较大的适应度;f表示变异个体的适应度。
调整思想是,当群体适应度比较集中时,使交叉概率pc和变异概率pm增大;当群体适应度比较分散时,使pc和pm减小,同时,适应度值高于群体平均值的个体对应于较低的pc和pm,使该解得以保护从而进入下一代;低于群体平均值的个体,对应于较高的pc和pm,使该解被淘汰。因此,交叉、变异概率的自适应调整能够提供给某个解较佳的pc和pm组合。自适应递阶遗传算法在保持群体多样性的同时,保证算法的收敛性,提高算法的收敛速度。
2 三相桥式全控整流电路建模与仿真
研究分析表明,整流输出电压包含了电路的故障信息,是一个关键的测试点,通过适当的变换可以实现故障诊断。运用Matlab 7.1软件中的Simulink构建三相桥式全控整流主电路故障模型如图3所示。并对几种常见故障进行了仿真研究,其部分仿真结果如图4(a)~(e)所示,分别为正常工作时负载电压,单管VT5断路,两只管子同时断路故障包括同一支路不同桥臂(VT1和VT4)、不同支路不同桥臂(VT4和VT5)和不同支路同一桥臂(VT1和VT5)的断路故障仿真波形。
3 三相桥式全控整流电路的故障诊断
图5所示为三相桥式全控整流电路原理图。考虑到实际系统运行时出现故障的情况,同时为简化分析过程,假定整流电路晶闸管故障分为单管故障或两支管子同时故障共22种,要使神经网络能区分所有的故障,必须对这些故障类型进行编码,用六位编码表示,也就是神经网络的输出。每位编码对应一个晶闸管,所有晶闸管均正常时对应编码为000000。
以A相电压正向过零处为基准,对控制角从0~120°每隔7.5°依次对22种故障状态下的输出电压ud进行一个周期(20 ms)的数据采集,采集到的数据个数为50个,以此组成训练样本,共有22×17=374个样本。用同样的方法对控制角从6.5~113.5°每隔10.7°对ud进行采样,以获得测试样本。根据主成分分析特征提取的算法对训练和测试样本进行故障特征提取,获取的新样本从50维降为10维,大大减少了神经网络的计算量,改善了网络的复杂程度。
本文运用Matlab工具箱,采用自适应递阶遗传算法对神经网络进行了优化。得到了神经网络的最简结构(隐含层神经元个数m=14)和最优的权值、阈值。优化后的神经网络训练误差曲线如图6所示。
采用测试样本数据对所训练好的BP神经网络进行仿真验证,分别选用负载变化、输入电压变化得到的特征向量数据去验证已建立的BP神经网络,故障诊断正确率达到97.67%,并且故障诊断有误都发生在负载和输入电压同时变化时。
4 结论
本文将一种自适应递阶遗传算法应用于神经网络的优化,解决了以往神经网络结构、权值、阈值同时优化效率不高的难题。通过仿真实验,证明了算法的准确性和实用性,并将优化的神经网络用于三相桥式全控整流电路的故障诊断,得到了令人满意的结果。
全部0条评论
快来发表一下你的评论吧 !