1、智能控制基础研究生课程设计报告题 目 基于 BP 神经网络的故障诊断方法 学 院 机械与汽车工程学院 专业班级 车辆工程 学 号 221601852020 学生姓名 李跃轩 指导教师 武晓莉 完成日期 2016 年 12 月 10 日 目录1 设计概述 21.1 研究对象介绍 .21.2 设计内容及目标 .22 设计原理、方法及步骤 32.1 基于 BP 算法的神经网络模型 32.2 神经网络信息融合故障诊断步骤 43 结果及分析 63.1 数据仿真 .63.2 结果分析 84 设计小结 9参考文献 10附录程序 111 设计概述1.1 研究对象介绍信息融合是多源信息综合处理的一项新技术,是将
2、来自某一目标(或状态)的多源信息加以智能化合成,产生比单一信息源更精确、更完全的估计和判决。信息融合所处理的多传感器信息具有更为复杂的形式,可以在不同的信息层次上出现。多传感器信息融合的优点突出地表现在信息的冗余性、容错性、互补性、实时性和低成本性。神经网络是由大量互联的处理单元连接而成,它是基于现代神经生物学以及认知科学在信息处理领域应用的研究成果。它具有大规模并行模拟处理、连续时间动力学和网络全局作用等特点,有很强的自适应学习和非线性拟合能力,从而可以替代复杂耗时的传统算法,使信号处理过程更接近人类思维活动。柴油机故障具有相似性,故障与征兆的关系不明确,具有较强的模糊性,故障特征相互交织,
3、柴油机故障诊断是一个复杂的问题。综合柴油机故障的特点以及神经网络的优势,采用基于 BP 神经网络的多传感器信息融合技术对柴油机机械故障进行诊断。1.2 设计内容及目标设计内容:针对传统故障诊断方法存在的诊断准确性不高的问题,提出了BP 神经网络信息融合的方法,实现对柴油机的机械故障诊断。由多个传感器采集信号,分别经过快速傅里叶变换后获得故障频域特征值,再经 BP 神经网络对柴油机进行故障局部诊断,能够对相应传感器的不同故障类型做出一个准确地分类,最终完成对汽轮机机械故障的准确诊断。实验结果表明,该方法克服了单个传感器的局限性和不确定性,是一种有效的故障诊断方法。采用方法:通过 BP 神经网络进
4、行局部诊断,最终判定故障及故障类型。基于 BP 神经网络多传感器信息融合,故障诊断方法是特征层状态属性融合,并利用 MATLAB 仿真。2 设计原理、方法及步骤基于神经网络多传感器信息融合故障诊断方法是特征层状态属性融合,也就是特征层联合识别方法,多传感器检测系统为识别提供了比单传感器更多的有关目标( 状态 )的特征信息, 增大了特征空间维数。本文运用神经网络多传感器信息融合方法对机械设备运行状态进行诊断识别,是基于这样一种思想:设备运行状态与其各种征兆参数(温度、压力、电压、电流、振动信号等)之间存在着因果关系,而这种关系之复杂是难用公式表达的,由于神经网络所具有的信息分布式存储方式、大规模
5、自适应并行处理、高度的容错能力等是其可用于模式识别的基础,特别是其学习能力、容错能力和高度的非线性映射能力对机械设备运行状态的不确定性模式识别具有独到之处。2.1 基于 BP 算法的神经网络模型本文采用的是 3 层 BP 神经网络模型,由输入层、隐层和输出层构成,图 1所示为一个典型的三层 BP 神经网络模型图 1 一个简单的 BP 神经网络模型网络的前馈意义在于每一层节点的输入仅来自前面一层节点的输出。对于输入信号,先前向传播到隐层节点,经过激活函数后,再把隐层节点的输出信息传播到输出节点,最后得到输出结果。(1)输入层节点 其输出 等于输入 ,将变量值传送到第(1,2.),iniOiX二层
6、。 (2)隐层节点 其输入 ,输出 分别为:(,.),jpjIj(2-1)1njjijiIO(2-2)()/exp()jj jfI式中, 为隐层节点 与输入层节点 之间的权值, 为隐层节点 的偏jiijj置, 为 sigmoid 函数,其表达式为:f(2-3)()1/exp()f(3)输出层节点 其输入 ,输出 分别为:,2.,kmkIky(2-4)1pkkjkjIO(2-5)()/ex()kkkyfI式中, 为输入层节点 与隐层节点 之间的连接权值, 为输出层节点kjj k的偏置。k对于给定的训练样本 , 为样本数 ,网络输出1,2(.)ppnx(1,2.)pP与训练目标之间的均方误差可表示
7、为: (2-6)1pPE(2-7)21()lPpllty其中 为样本数, 为第 个样本的第 l 个输出单元的目标输出结果,pplt为第 个样本的第 l 个输出单元的网络运算结果。BP 网络训练的过程包括ply网络内部的前向计算和误差的反向传播,其目的就是通过调整网络内部连接权值使网络输出误差最小。对于多层前馈网络中输入层与隐层之间、隐层与输出层之间连接权值利用 BP 算法调整。2.2 神经网络信息融合故障诊断步骤神经网络知识表示是一种知识的隐式表示,知识表现为网络的拓扑结构和连接权值,采用神经网络技术的专家系统,由于神经网络是一种信息存储和处待测原件压 力 传 感 器温 度 传 感 器信号采集
8、特征提取归一化特征关联 神 经 网 络分 类 器诊断结果理统一的网络系统,因此,在采用神经网络技术的专家系统中,知识的存储与问题求解过程中的推理过程均在系统的神经网络模块中进行,是推理机和知识库的统一。首先从已有的设备特征信号提取特征数据,经过数据预处理(归一化处理)后作为神经网络输入,从已知的故障结果提取数据作为神经网络输出,构建 BP 神经网络,利用已有的特征数据和已知的故障结果数据形成的训练样本集对构建的 BP 神经网络进行训练和网络自学习,使 BP 神经网络的权值、阀值与已知的故障结果之间存在对应关系达到期望的故障结果输出。当 BP 神经网络训练完毕后,就可以利用训练成功的 BP 神经
9、网络进行故障诊断。故障诊断的过程如下:1)将故障样本输入给输入层各节点,同时它也是该层神经元的输出。2)由式 (2-2)求出隐层神经元的输出,并将其作为输出层的输入。3)从式 (2-5)求得输出层神经元的输出。4)由阈值函数判定输出层神经元的最终输出结果。 柴油机的故障诊断首先从待诊断的故障信号中提取数据并进行数据预处理,而后将待诊断故障数据输入训练成功的神经网络。利用神经网络信息融合进行故障诊断步骤如图 2 所示:图 2 信息融合进行故障诊断步骤3 结果及分析3.1 数据仿真以某种柴油机中的 4 个实际故障样本为例,每个故障样本有 5 个故障特征值,因此选取网络的输入节点为 5。将样本输入到
10、神经网络模型中,每个输出节点代表一种故障类型,则这 4 种故障类型和一个正常状态共需 5 个输出节点与之相对应,因此网络的输出节点为 5。表 3-1 训练数据。表 3-1 训练数据故障特征值 X样本序号 温度 压力 电压 电流 振动信号1234560.00000.00740.00430.00560.00630.00490.00000.03350.02230.03150.02050.03000.00130.00150.00000.00120.00200.00180.00000.00320.00470.00270.00330.00260.00000.01060.00530.00860.00660.
11、00787891011120.55200.54520.55020.54060.56040.55250.31070.27930.24580.28620.30280.31250.25810.26110.27170.26450.28350.27780.30940.29880.31150.30090.31250.30050.23160.20360.23470.21450.22250.21641314151617180.24620.25350.26650.25560.26280.25620.15080.10610.08940.14650.14320.09990.09470.09680.09370.098
12、80.308990.09000.09640.09710.09440.10000.09650.09990.09990.08100.09080.10000.08990.09981920212223240.66150.67380.66650.66890.67000.66230.52510.44130.47490.46520.47480.48320.51950.52250.52550.52000.52350.52680.47100.47320.47690.47560.48250.46691.0000.96670.97580.98991.00000.988725 1.0000 1.0000 0.9812
13、 1.0000 0.820626272829300.97970.98460.98000.99651.00000.97770.97270.98250.99340.99121.00000.98470.98350.98620.99380.99600.98570.98870.98990.99610.82060.76000.80000.78000.8014在表 3-1 训练数据中,样本序号 16 是正常状态;样本序号 712 是故障 1状态;样本序号 1318 是故障 2 状态;样本序号 1924 是故障 3 状态;样本序号 2530 是故障 4 状态。表 3-2 是测试数据。表 3-2 测试数据故障特
14、征值 X样本序号 温度 压力 电压 电流 振动信号1234560.54930.00310.99200.67040.25720.98000.26260.02350.98990.49720.10060.98250.26590.00050.99790.52350.09580.98350.30880.00300.99370.47410.09810.98870.22210.00450.79790.97910.08900.8000根据故障诊断的特点建立 BP 神经网络模型,网络的输入层节点、隐层节点和输出层节点个数分别为 5、60 和 5,设置系统误差为 1e-3,学习率为 1,最大迭代次数为 1000
15、次,其中输入层到隐层之间的激活函数为双曲正切函数,隐层到输出层之间的激活函数设置为 logsig 的 S 型传递函数,在输出端设置的阈值为 0.85,即网络输出值大于 0.85 的置 1,小于等于 0.85 的置 0 来处理,利用MATLAB 神经网络工具箱建立 BP 神经网络模型。3.2 结果分析在本文中将正常状态设置为1 0 0 0 0 ,故障 1 设置为0 1 0 0 0 ,故障 2设置为0 0 1 0 0 ,故障 3 设置为0 0 0 1 0 ,故障 4 设置为0 0 0 0 1 ,输出阈值设置为 0.85,即在输出值大于 0.85 即为 1,否则为 0。根据输出数据的分析判断属于哪种
16、故障,表 3-3 为仿真输出。表 3-3 仿真输出网络输出 y样本序号 正常 故障 1 故障 2 故障 3 故障 41234560.0006 1.0139 -0.0014 0.0410 -0.0014 -0.00021.0008 0.0007 -0.0019 -0.0090 -0.0020 0.00040.0021 -0.0115 0.0010 -0.0159 1.0039 0.0025-0.0096 0.0021 -0.0019 0.9811 -0.0027 0.00090.0011 -0.0024 0.9923 -0.0144 0.0015 0.9970将表 3-2 中“样本序号 1”的
17、5 个故障特征值输给网络的输入层节点,则网络输出层节点与其对应的输出为表 3-3 中“样本序号 1”所在行的 5 个输出值,其中只有 y2=1.00080.85,其他 5 个输出均远小于 0.85,所以,网络故障诊断的结果为故障 1;表 3-2 中“样本序号 2”的 5 个故障特征值输给网络的输入层节点,则网络输出层节点与其对应的输出为表 3-3 中“样本序号 2”所在行的 5个输出值,其中只有 y1=1.01390.85,其他 5 个输出均远小于 0.85,所以,网络故障诊断的结果为正常状态;表 3-2 中“样本序号 3”的 5 个故障特征值输给网络的输入层节点,则网络输出层节点与其对应的输
18、出为表 3-3 中“样本序号3”所在行的 5 个输出值,其中只有 y4=0.99230.85,其他 5 个输出均远小于0.85,所以,网络故障诊断的结果为故障 4,其他类型的故障诊断以此类推。4 设计小结因为学习的专业是车辆工程,因此选择了对柴油机故障诊断这一研究对象。此篇设计经过查阅文献资料,对 BP 神经网络的故障诊断及 Matlab 仿真有了一定的认识。柴油机故障诊断是一个非常复杂的过程,其故障与征兆关系不是很明确,存在一种非线性映射关系。BP 神经网络具有良好的学习能力,利用 BP网络信息融合方法,能够在足够多的样本数目前提下网络保证良好的容错性和鲁棒性是比较好的。所以在故障诊断的过程
19、中,神经网络信息融合发挥其联想记忆和分布并行处理能力,不仅能够诊断出已有的故障还能对故障进行一个预测,从而满足柴油机故障断的要求。人工神经网络信息融合为智能诊断提供了良好的方法,为自适应学习和决策高度智能化控制系统提供了强有力的基础,并具有广泛的应用潜力和发展前景。参考文献1 朱大奇 ,于盛林基于 D-S 证据理论的数据融合算法及其在电路故障诊断中的应用J.电子学报,2002, 30(2):221-223.2 王万良.人工智能及其应用( 第 3 版)(附光盘)(BZ)M. 高等教育出版社, 2016.3 朱大奇 ,于盛林电子电路故障诊断的神经网络数据融合算法J.东南大学学报(自然科学版),20
20、01,31(2):87-90.4 何友,王国宏多传感器信息融合及应用M. 北京: 电子工业出版社,2000.5 张绪锦,谭剑波,韩江洪基于 BP 神经网络的故障诊断方法J.系统工程理论与实践,2002,22(6):61-66.6 Y.G. Lei, Z.J. He, Y.Y. Zi, Q. Hu, Fault diagnosis of rotating machinery based on multiple ANFIS combination with GasJ.Mech. Syst. Signal Process.2007(21)22802294.7 V.T. Tran, F. AlThob
21、iani, A. Ball, An approach to fault diagnosis of reciprocating compressor valves using TeagerKaiser energy operator and deep belief networksJ.Expert Syst.Appl.2014(41)41134122.附录程序clcclear%输入训练数据(包括正常数据和故障数据)%训练样本中,每一列分别代表:“温度” , “压力” , “电压” , “电流”和“振动信号” ;每一行分别代表一个样本p11=0.0000 0.0000 0.0013 0.0000
22、0.0000;p12=0.0074 0.0335 0.0015 0.0032 0.0106;p13=0.0043 0.0223 0.0000 0.0047 0.0053;p14=0.0056 0.0315 0.0012 0.0027 0.0086;p15=0.0063 0.0205 0.0020 0.0033 0.0066;p16=0.0049 0.0300 0.0018 0.0026 0.0078; %正常数据p21=0.5520 0.3107 0.2581 0.3094 0.2316;p22=0.5452 0.2793 0.2611 0.2988 0.2036;p23=0.5502 0.2
23、458 0.2717 0.3115 0.2347;p24=0.5406 0.2862 0.2645 0.3009 0.2145;p25=0.5604 0.3028 0.2835 0.3125 0.2225;p26=0.5525 0.3125 0.2778 0.3005 0.2164; % 故障 1p31=0.2462 0.1508 0.0947 0.0964 0.0999;p32=0.2535 0.1061 0.0968 0.0971 0.0810;p33=0.2665 0.0894 0.0937 0.0994 0.0908;p34=0.2556 0.1465 0.0988 0.1000 0.
24、1000;p35=0.2628 0.1432 0.0899 0.0965 0.0899;p36=0.2562 0.0999 0.0900 0.0999 0.0998; % 故障 2p41=0.6615 0.5251 0.5195 0.4710 1.0000;p42=0.6738 0.4413 0.5225 0.4732 0.9667;p43=0.6665 0.4749 0.5255 0.4769 0.9758;p44=0.6689 0.4652 0.5200 0.4756 0.9899;p45=0.6700 0.4748 0.5235 0.4825 1.0000;p46=0.6623 0.48
25、32 0.5268 0.4669 0.9887; %故障 3p51=1.000 1.0000 0.9812 1.0000 0.8206;p52=0.9797 0.9777 1.0000 0.9960 0.7759;p53=0.9846 0.9727 0.9847 0.9857 0.7600;p54=0.9800 0.9825 0.9835 0.9887 0.8000;p55=0.9965 0.9934 0.9862 0.9899 0.7800;p56=1.0000 0.9912 0.9938 0.9961 0.8014; %故障 4p=p11 p12 p13 p14 p15 p16 p21 p
26、22 p23 p24 p25 p26 p31 p32 p33 p34 p35 p36 p41 p42 p43 p44 p45 p46 p51 p52 p53 p54 p55 p56;%将所有的数据:包括正常数据和异常数据放在一个数据集中,将该数据集设置为输入神经网络的特征值%对被检测对象类别进行编码(设置目标值,即标签,用二进制类型表示)t11=1 0 0 0 0;t12=1 0 0 0 0;t13=1 0 0 0 0;t14=1 0 0 0 0;t15=1 0 0 0 0;t16=1 0 0 0 0; % normalt21=0 1 0 0 0;t22=0 1 0 0 0;t23=0 1 0
27、 0 0;t24=0 1 0 0 0;t25=0 1 0 0 0;t26=0 1 0 0 0; % fault1t31=0 0 1 0 0;t32=0 0 1 0 0;t33=0 0 1 0 0;t34=0 0 1 0 0;t35=0 0 1 0 0;t36=0 0 1 0 0;% fault2t41=0 0 0 1 0;t42=0 0 0 1 0;t43=0 0 0 1 0;t44=0 0 0 1 0;t45=0 0 0 1 0;t46=0 0 0 1 0;% fault3t51=0 0 0 0 1;t52=0 0 0 0 1;t53=0 0 0 0 1;t54=0 0 0 0 1;t55=
28、0 0 0 0 1;t56=0 0 0 0 1;% fault4t=t11 t12 t13 t14 t15 t16 t21 t22 t23 t24 t25 t26 t31 t32 t33 t34 t35 t36 t41 t42 t43 t44 t45 t46 t51 t52 t53 t54 t55 t56;p, s1 = mapminmax(p);%输入样本归一化 归一化的范围是(-1,1) ,s1 记录归一化的参数net=newff(minmax(p),60,5,tansig,purelin,trainlm);%新建 BP 网络,p 为样本输入:p=martric(5*30) 分别表示 5
29、个传感器,30 个样本% 隐层神经元个数为 60,根据输出目标 t 确定输出层神经元个数为 5,% 从输入层到隐层的激励函数为双曲正切,隐层到输出层的激励函数为线性函数,训练方法利用 LM(Levenberg-Marquardt)算法进行网络参数 sita=W,b的更新%设置网络训练参数 net.trainParam.show=10; %设置数据显示刷新频率,学习次刷新一次图象net.trainParam.epochs=1000; %最大 训练次数net.trainParam.goal=1e-5; % 设置训练误差net=init(net);%网络初始化net tr=train(net,p,t
30、);%训练网络%testingp1=0.5493 0.2626 0.2659 0.3088 0.2221;p2=0.0031 0.0235 0.0005 0.0030 0.0045;p3=0.9920 0.9899 0.9979 0.9937 0.7979;p4=0.6704 0.4972 0.5235 0.4741 0.9791;p5=0.2572 0.1006 0.0958 0.0981 0.0890; p6=0.9800 0.9825 0.9835 0.9887 0.8000;%测试数据pp= p1 p2 p3 p4 p5 p6;pp = mapminmax(apply,pp,s1);%
31、测试样本归一化result_test=sim(net,pp)%测试样本仿真result_test( result_test0.85)=1;result_test( result_test=0.85)=0; disp(网络输出:)result_testpp_lab=2 1 5 4 3 5;% 测试样本标签(正确类别)res=vec2ind(result_test)%向量值变索引值strr = cell(1,6);for i=1:6if res(i) = pp_lab(i)strri = 正确;elsestrri = 错误;endenddiag = 正常,故障 1, 故障 2, 故障 3, 故障 4 ;disp(诊断结果:)fprintf( 样本序号 实际类别 判断类别 正/误 故障类型 n);for i =1:6fprintf( %d %d %d %s %sn,.i, pp_lab(i), res(i), strri, diagres(i); endfigureplot(pp_lab,-g*);hold onplot(res,-ro)legend(期望类型,预测数出类型)xlabel(样本)ylabel(类型)title(故障类型)