EI论文故障识别程序:DBN深度置信/信念网络的故障识别Matlab程序,数据由Excel导入,直接运行!

​适用平台:Matlab2021b版及以上

本程序参考中文EI期刊《基于变分模态分解和改进灰狼算法优化深度置信网络的自动转换开关故障识别》中的深度置信网络(Deep Belief Network,DBN)部分进行故障识别,程序注释清晰,干货满满,下面对文章和程序做简要介绍。

这篇文献使用深度置信网络(DBN)来进行自动转换开关故障识别。DBN的训练过程分为预训练和反向微调两个阶段。预训练阶段中,通过RBMs的逐层预训练,数据从底层输入并逐层传递。每个RBM包含一个视觉层和一个隐藏层,并通过权重连接。在反向微调阶段,采用梯度下降算法对DBN进行有监督的训练,减小每层的预测误差。在RBMs中,使用对比度发散算法近似获得模型的无偏生成概率。通过合适的设置学习率和动量系数,优化DBN算法的网络结构参数,最终实现DBN在自动转换开关故障识别中的应用。

DBN结合电力系统故障识别的创新点主要体现在其对复杂、非线性系统进行建模和特征提取方面。以下是DBN在电力系统故障识别方面的创新点的详细介绍:

分层学习结构:DBN采用了分层学习的结构,包含输入层、隐含层(多个)和输出层。每一层的节点都与下一层的节点相连接,形成一个前馈的结构。这种结构使得DBN能够逐层学习数据的抽象表示,有助于捕捉电力系统数据中的复杂特征和模式。

非监督学习和有监督学习相结合:DBN的训练过程包含两个阶段:首先是无监督的贪婪逐层预训练,然后是有监督的调整网络参数。通过无监督学习,DBN可以从数据中提取高层次的特征表示,然后通过有监督学习来调整这些特征表示以完成具体任务,如故障识别。

适应性特征提取:DBN通过多层次的特征提取,能够适应复杂的电力系统数据模式。这些特征对于故障识别任务而言更具有表征能力,使得系统可以更好地区分正常运行和故障状态。

对抗性训练和鲁棒性:DBN在训练中引入对抗性训练的思想,通过使网络在面对不同情况时更具鲁棒性。这对于电力系统,面对可能的噪声和干扰,以及未知的故障模式,都具有重要的意义。

大数据处理能力:DBN在处理大规模数据方面表现出色,而电力系统通常会产生大量的实时数据。DBN的能力使其能够有效地处理这些数据,并从中提取对于故障识别有关键意义的信息。

潜在变量的建模:DBN通过潜在变量的建模,能够更好地理解电力系统中的隐含关系。这些潜在变量可以捕获系统中的复杂动态和非线性关系,从而提高故障识别的准确性。

总结:DBN在电力系统故障识别中的创新点主要体现在其深度学习结构、分层特征提取、对抗性训练等方面,使其能够更好地应对电力系统数据的复杂性和多变性。

适用于各种数据分类场景,如滚动轴承故障、变压器油气故障、电力系统输电线路故障、绝缘子、配网、电能质量扰动,等领域的识别、诊断和分类。

以下是程序的输出:

测试集的混淆矩阵:(右下角为最终准确率,精确率是混淆矩阵的最下面一行,召回率是混淆矩阵的最右边一列)

精确率:是指在所有被模型预测为正类别的样本中,有多少是真正的正类别。

召回率:是指在所有实际正类别的样本中,有多少被模型正确地预测为正类别。

训练集的实际故障类别和模型识别的故障类别:

模型的训练曲线:

数据格式:一行为一个故障波形样本,最后一列为该样本所属的故障类别。

DBN建模部分代码:

%% 建立DBN
dbn.sizes = [10 5];                   % DBN各层神经元个数 第二层10 第三层5
opts.numepochs = 300;                 % RBM 训练时 迭代次数
opts.batchsize = 30;                  % 每批次使用30个样本进行训练
opts.momentum  =  0;                  % 学习率的动量
opts.alpha     =  0.01;               % 学习率因子
dbn = dbnsetup(dbn, p_train, opts);   % 建立DBN模型
dbn = dbntrain(dbn, p_train, opts);   % 训练DBN模型%% DBN移植到深层NN
nn = dbnunfoldtonn(dbn, 8);              % 反向微调(8代表有8种输出)
nn.activation_function = 'sigm';         % 激活函数%% 反向调整DBN
opts.numepochs = 500;                    % 反向微调次数
opts.alpha     = 0.001;                  % 学习率因子
opts.batchsize = 30;                     % 反向微调每次样本数
opts.output = 'softmax';                 % 激活函数
nn = nntrain(nn, p_train, t_train, opts);% 训练%% 预测 
T_sim1 = nnpredict(nn, p_train); 
T_sim2 = nnpredict(nn, p_test);%% 完整代码:https://mbd.pub/o/bread/ZZeTlpZw

部分图片来源于网络,侵权联系删除!

欢迎感兴趣的小伙伴关注我们的公众号,或点击上方链接获得完整版代码哦~,关注小编会继续推送更有质量的学习资料、文章程序代码~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/211478.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Action!录屏工具免费完整版,录屏软件,打开即可解锁最新完整可用版本,支持GPU加速HDR视频录制和播放

一、软件简介 本次带来的录屏工具已升级为【完整版本】,所有功能全部可用。该录屏工具支持GPU硬件加速,可以智能识别主流硬件设备,支持通过GPU进行HDR视频录制和播放进行。视频录制帧率最高支持360FPS,直播视频帧率最高支持60FPS…

C语言--给出一个点的坐标判断它在单位圆的内部外部还是上面

一.题目描述 给出一个点的坐标判断它在单位圆的内部外部还是上面 例如输入1,0,输出在圆上 二.思路分析 首先,单位圆是以坐标系原点为圆心、半径为1的圆。 给定一个点坐标 (x,y),我们可以使用勾股定理计算该点到坐标系原点的距…

注意:怎么用JMeter操作MySQL数据库?看完秒懂!

近期用JMeter做接口测试,遇到了一个需要用到数据数据库的场景:一个关于数据报告的页面,需要将数据库里面的数据求和或者取均值之后,展示出来。 如果要断言的话,需要连接数据库,通过写sql语句,将…

gRPC之gRPC负载均衡(客户端负载均衡)(etcd)

1、gRPC负载均衡(客户端负载均衡)(etcd) 本篇将基于etcd的服务发现前提下,介绍如何实现gRPC客户端负载均衡。 1.1 gRPC负载均衡 gRPC官方文档提供了关于gRPC负载均衡方案Load Balancing in gRPC https://github.com/grpc/grpc/blob/master/doc/load-balancing.m…

【数据结构/C++】栈和队列_链队列

#include <iostream> using namespace std; // 链队列 typedef int ElemType; typedef struct LinkNode {ElemType data;struct LinkNode *next; } LinkNode; typedef struct {LinkNode *front, *rear; } LinkQueue; // 初始化 void InitQueue(LinkQueue &Q) {Q.fron…

听GPT 讲Rust源代码--src/tools(2)

题图来自AI生成 File: rust/src/tools/rust-analyzer/crates/hir-def/src/src.rs rust-analyzer 是一个 Rust 语言的语法分析器和语义分析器&#xff0c;用于提供代码补全、导航、重构等开发工具。而 rust-analyzer 的代码实现存储在 rust/src/tools/rust-analyzer 这个文件夹中…

经典滑动窗口试题(一)

&#x1f4d8;北尘_&#xff1a;个人主页 &#x1f30e;个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上&#xff0c;不忘来时的初心 文章目录 一、将x减到0的最小操作数1、题目讲解2、讲解算法原理3、代码实现 二、无重复的最长子串1、题…

力扣:178. 分数排名(Python3)

题目&#xff1a; 表: Scores ---------------------- | Column Name | Type | ---------------------- | id | int | | score | decimal | ---------------------- 在 SQL 中&#xff0c;id 是该表的主键。 该表的每一行都包含了一场比赛的分数。Score …

gmapping仿真

文章目录 获取源码安装依赖项编译简单场景运行gmapping开启键盘控制通过launch文件来启动gmappingGmapping建图的参数设置地图的保存和加载参考 获取源码 cd ~/catkin_ws/src/ git clone https://gitcode.com/weixin_42990464/wpr_simulation.git git clone https://gitcode.c…

跨境电商包装的可持续性:EPR的视角

跨境电商的崛起已经改变了我们购物的方式&#xff0c;使我们能够轻松购买来自世界各地的产品。然而&#xff0c;这种便捷也伴随着一个不容忽视的问题&#xff1a;包装和废物管理。 跨境电商平台通常需要在全球范围内运送产品&#xff0c;这意味着大量的包装材料和废弃物。在这…

相比其他关系型数据库,AntDB JDBC驱动特性有哪些不同之处

摘要&#xff1a;使用Java语言进行各类应用程序的快速开发成为目前比较主要且流行的开发方式。JDBC是 Java 语言中用来连接和操作关系型数据库的 API&#xff0c;在业务程序与关系型数据库通信时&#xff0c;必然会使用JDBC驱动。 本文将通过国产关系型数据库AntDB中的JDBC为大…

千梦网创:创业,一场游戏一场梦

创业这件事就好比一场养成类游戏&#xff0c;而我们自己就是游戏主角。 这个游戏有一个特殊之处在于&#xff1a;SSS级装备有穿戴等级设定&#xff0c;就算你氪重金买到了一把神器&#xff0c;自身阅历不够也根本无法发挥它的强大威力而只能当个装饰。 这就要求我们真正沉浸在…