CPN故障诊断(MATLAB)

CPN(Colored Petri Net,彩色Petri网)是在传统Petri网的基础上进行扩展的高级Petri网。它在故障诊断领域有着广泛的应用。

CPN故障诊断的主要思想和步骤如下:

建模:根据系统的结构和功能,采用CPN构建系统的模型。将系统不同组件表示为网的位置,数据/信号流表示为网的转换,故障表示为额外的转换。

状态空间分析:对CPN模型进行状态空间分析,枚举系统所有可能的状态。确定正常和故障状态。

仿真:对CPN模型进行仿真,通过给模型输入不同的事件序列,分析状态和标识的变化。

故障检测:通过对比正常模型和故障模型的仿真结果,判断系统是否发生故障以及故障类型。

诊断:追踪故障状态对应的事件序列,分析故障发生的原因,给出诊断报告。

相比传统方法,CPN故障诊断通过视觉化建模和仿真,能够直观高效地分析系统的故障,是一种有效的现代故障诊断方法。

%% 对向传播网络:CPN神经网络对轴承故障类型判断主程序

clc;close all;clear all;%清除空间

%% --- (1)预处理开始--

%% 产生样本

[PMatrix,T]=gendataFun();

[L01,L02]=size(PMatrix);

%对权值进初始化

PData=PMatrix;%输入数据

%% 样本转换为CPN需要的结果

TData=trancT2TData(T);%输出数据转换为CPN需要的结构

[k31,L03]=size(TData);%测量数据的矩阵大小

%% --- 预处理结束--

T_out01=TData;

MaxIte=1000;%学习次数

%% (3)开始CPN训练---

B0=0.01;

TrainNumber=100;

alfa=0.1;

[Out,w,v,com_Num]=cpns(PData,TData,B0,alfa,TrainNumber);%训练

Out;

%% 开始CPN训练结束---

%开始网络回想,其输入模式为Ptest01

n=0;%计算准确率的计数器

PredictionAll=zeros(L01,1);%记录预测值

for t01=1:L01

    Ptest01=PMatrix(t01,:);%载入预测样本的输入数据

    Ttest01=TData(t01,:);%载入预测样本的输出数据

    %初始化Pc

    PredictionAll(t01,1)=CPNPrediction(Ptest01,L03,w,v,com_Num);

    %     disp('真实结果');

    Treal=T(t01);

    %     disp('预测结果');

    Prediction=PredictionAll(t01,1);

    if Treal==Prediction

        n=n+1;

    end

end

%% 把CPN的结果转化为自然语言

FaultTypes={'第一缸喷油器针阀磨损','正常','第一缸喷油器压力过小','供油提前角提前','其他'};

disp('诊断结果');

fprintf('     %s     %s     %s       %s     %s\n', '样本序号','实际类别','预测类别','正/误','故障类型');

for i=1:L01

    s1=num2str(i);

    s2=num2str(T(i));

    s3=num2str(PredictionAll(i,1));

    if T(i)==PredictionAll(i,1)

        s4='正确';

    else

        s4='错误';

    end

    s5=FaultTypes{PredictionAll(i,1)};

    fprintf('        %s          %s             %s          %s      %s \n', s1,s2,s3,s4,s5);

end

disp('正确率')

[num2str(n/L01*100),'%']

figure;

plot(1:L01,PredictionAll,'bo');

hold on;

plot(1:L01,T,'r*');

legend('预测故障类型','实际故障类型');

s22=['CPN神经网络对轴承故障类型的预测与实际类型对比, 误差='];

title(s22);

诊断结果

     样本序号     实际类别     预测类别       正/误     故障类型

        1          1             1          正确      第一缸喷油器针阀磨损

        2          1             1          正确      第一缸喷油器针阀磨损

        3          1             1          正确      第一缸喷油器针阀磨损

        4          1             1          正确      第一缸喷油器针阀磨损

        5          1             1          正确      第一缸喷油器针阀磨损

        6          1             1          正确      第一缸喷油器针阀磨损

        7          1             1          正确      第一缸喷油器针阀磨损

        8          1             1          正确      第一缸喷油器针阀磨损

        9          1             1          正确      第一缸喷油器针阀磨损

        10          1             1          正确      第一缸喷油器针阀磨损

        11          2             2          正确      正常

        12          2             2          正确      正常

        13          2             2          正确      正常

        14          2             2          正确      正常

        15          2             2          正确      正常

        16          2             2          正确      正常

        17          2             2          正确      正常

        18          2             2          正确      正常

        19          2             2          正确      正常

        20          2             2          正确      正常

        21          3             3          正确      第一缸喷油器压力过小

        22          3             3          正确      第一缸喷油器压力过小

        23          3             3          正确      第一缸喷油器压力过小

        24          3             3          正确      第一缸喷油器压力过小

        25          3             3          正确      第一缸喷油器压力过小

        26          3             3          正确      第一缸喷油器压力过小

        27          3             3          正确      第一缸喷油器压力过小

        28          3             3          正确      第一缸喷油器压力过小

        29          3             3          正确      第一缸喷油器压力过小

        30          3             3          正确      第一缸喷油器压力过小

        31          4             4          正确      供油提前角提前

        32          4             4          正确      供油提前角提前

        33          4             4          正确      供油提前角提前

        34          4             4          正确      供油提前角提前

        35          4             4          正确      供油提前角提前

        36          4             4          正确      供油提前角提前

        37          4             4          正确      供油提前角提前

        38          4             4          正确      供油提前角提前

        39          4             4          正确      供油提前角提前

        40          4             4          正确      供油提前角提前

        41          5             5          正确      其他

        42          5             5          正确      其他

        43          5             5          正确      其他

        44          5             5          正确      其他

        45          5             5          正确      其他

        46          5             5          正确      其他

        47          5             5          正确      其他

        48          5             5          正确      其他

        49          5             5          正确      其他

        50          5             5          正确      其他

正确率

ans =

100%

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【百度Apollo】轨迹绘制:探索路径规划和可视化技术的应用

🎬 鸽芷咕:个人主页 🔥 个人专栏: 《linux深造日志》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! ⛳️ 推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下…

中移(苏州)软件技术有限公司面试问题与解答(5)—— Linux进程调度参数调优是如何通过代码实际完成的1

接前一篇文章:中移(苏州)软件技术有限公司面试问题与解答(0)—— 面试感悟与问题记录 本文对于中移(苏州)软件技术有限公司面试问题中的“(11)Linux进程调度参数调优是如…

面向对象编程(高级)(上)

下篇链接见:面向对象编程(高级)(下) 文章目录 一. 关键字:static1.1 类属性、类方法的设计思想1.2 static关键字1.3 静态变量1.3.1 语法格式1.3.2 静态变量的特点1.3.3 举例1.3.4 内存解析 1.4 静态方法1.4.1 语法格式…

1 月 30 日算法练习-思维和贪心

文章目录 重复字符串翻硬币乘积最大 重复字符串 思路&#xff1a;判断是否能整除&#xff0c;如果不能整除直接退出&#xff0c;能整除每次从每组对应位置中找出出现最多的字母将其他值修改为它&#xff0c;所有修改次数即为答案。 #include<iostream> using namespace …

AI新工具(20240126) 夸克 AI PPT-夸克 AI PPT,一键自动生成PPT;GeminiPro Next Web-一键免费部署

夸克 AI PPT-夸克 AI PPT,一键自动生成PPT 夸克AI PPT是夸克App推出的全新产品&#xff0c;用户只需输入PPT主题&#xff0c;就能在几十秒内生成一份精美且专业的PPT文档。夸克AI PPT具有更智能、更专业、更易操作的特点&#xff0c;让用户在手机端完成PPT创作&#xff0c;并提…

【C/C++】C/C++编程——整型(一)

整型 C 中的整型是基本的数据类型之一&#xff0c;用于表示没有小数部分的数。这包括正整数、负整数以及零。C 提供了多种整型&#xff0c;以适应不同大小的数值需求和优化内存使用。 整型的种类 C 中的整型可以根据其大小&#xff08;即占用的字节数&#xff09;和能够表示…

蓝桥杯2024/1/31----第十届省赛题笔记

题目要求&#xff1a; 1、 基本要求 1.1 使用大赛组委会提供的国信长天单片机竞赛实训平台&#xff0c;完成本试题的程序设计 与调试。 1.2 选手在程序设计与调试过程中&#xff0c;可参考组委会提供的“资源数据包”。 1.3 请注意&#xff1a; 程序编写、调试完成后选手…

RocksDB是如何实现存算分离的

核心参考文献&#xff1a; Dong, S., P, S. S., Pan, S., Ananthabhotla, A., Ekambaram, D., Sharma, A., Dayal, S., Parikh, N. V., Jin, Y., Kim, A., Patil, S., Zhuang, J., Dunster, S., Mahajan, A., Chelluri, A., Datye, C., Santana, L. V., Garg, N., & Gawde,…

Flink CEP实现10秒内连续登录失败用户分析

1、什么是CEP&#xff1f; Flink CEP即 Flink Complex Event Processing&#xff0c;是基于DataStream流式数据提供的一套复杂事件处理编程模型。你可以把他理解为基于无界流的一套正则匹配模型&#xff0c;即对于无界流中的各种数据(称为事件)&#xff0c;提供一种组合匹配的…

Python完善APC netbotz 250报告功能实现主动式运维。

首先介绍一下APC netbotz 250, 这是施耐德推出的一款机架式监控主机&#xff0c;能够对所有IT环境进行经济有效而且灵活的监控&#xff0c;号称APC史上性价比最高的环境监测方案&#xff0c;这可不是我吹的&#xff0c;是APC官网的介绍&#xff0c;可参考下面的官网截图。 我们…

【原创】VMware创建子网,并使用软路由获得访问互联网的能力,并通过静态路由让上层网络访问位于虚拟机的子网

前言 一看标题就很离谱&#xff0c;确实内容也有点复杂&#xff0c;我的初衷是为后面搞软路由做准备&#xff0c;先通过VMware进行可行性验证&#xff0c;确定方案是否可行&#xff0c;再做下一步的计划。结论当然可以的&#xff0c;能通能访问&#xff0c;强的不行。 网络拓…

重大进展:国产200层存储芯片实现量产,超越国际领先企业

近日&#xff0c;中国芯片技术领域迎来了一项历史性突破&#xff1a;200层以上的存储芯片率先实现量产&#xff0c;这一成就不仅超越了国外存储芯片巨头&#xff0c;更预示着中国有望成为全球行业的领军者。 后起之秀&#xff0c;鱼跃龙门 在这场技术的赛跑中&#xff0c;中国…

“死“社群先不要扔,想办法激活一下,隔壁的运营都馋哭了

私域运营已成为当下很多企业寻求增长的标配。在这过程中&#xff0c;社群运营就是极为重要的一个环节。过去我们为了流量&#xff0c;疯狂建群拉人。但建社群容易活跃难&#xff0c;活跃一段时间后&#xff0c;社群会越来越安静。 不仅如此&#xff0c;群主和管理员也渐渐疏于…

行为型设计模式—迭代器模式

迭代器模式&#xff1a;也叫作游标模式&#xff0c;能在不暴露复杂数据结构内部细节的情况下遍历其中所有的元素。在迭代器的帮助下&#xff0c; 客户端可以用一个迭代器接口以相似的方式遍历不同集合中的元素。 当集合背后为复杂的数据结构&#xff0c;且希望对客户端隐藏其复…

双非本科准备秋招(12.2)—— 力扣栈与队列

复习一下栈和队列的基础知识&#xff0c;刷几道题上上手。 1、102. 二叉树的层序遍历 广度优先遍历嘛&#xff0c;每次拓展一个新结点&#xff0c;就把新结点加入队列&#xff0c;这样遍历完队列中的元素&#xff0c;顺序就是层序遍历。 class Solution {public List<Lis…

分布式搜索引擎_学习笔记_3

分布式搜索引擎03 0.学习目标 1.数据聚合 **聚合&#xff08;aggregations&#xff09;**可以让我们极其方便的实现对数据的统计、分析、运算。例如&#xff1a; 什么品牌的手机最受欢迎&#xff1f;这些手机的平均价格、最高价格、最低价格&#xff1f;这些手机每月的销售…

91 C++对象模型探索。RTTI运行时类型识别回顾 与 存储位置介绍

一&#xff0c;RTTI 运行时类型识别&#xff0c;简单回顾 C运行时类型识别RTTI&#xff0c;要求父类这种必须 至少有一个虚函数&#xff0c;如果父类中没有虚函数&#xff0c;那么得到的RTTI就不准确&#xff1b; RTTI就可以在执行期间查询一个多态指针&#xff0c;或者多态应…

C++:第十四讲动态规划初步

每日C知识 想要在做C小游戏里实现等待效果&#xff0c;可以用Sleep。 Sleep函数可以使计算机程序&#xff08;进程&#xff0c;任务或线程&#xff09;进入休眠&#xff0c;使其在一段时间内处于非活动状态。 一般需要头文件windows.h。 注意"Sleep"首字母要大写…

k8s Sidecar filebeat 收集容器中的trace日志和app日志

目录 一、背景 二、设计 三、具体实现 Filebeat配置 K8S SideCar yaml Logstash配置 一、背景 将容器中服务的trace日志和应用日志收集到KAFKA&#xff0c;需要注意的是 trace 日志和app 日志需要存放在同一个KAFKA两个不同的topic中。分别为APP_TOPIC和TRACE_TOPIC 二、…

LLM之Agent(十)| 本地安装Microsoft AutoGen Studio 2.0教程

2021年3月&#xff0c;微软发布了AutoGen[2]&#xff0c;这是一个使用多个代理开发LLM应用程序的框架&#xff0c;这些代理可以协作解决任务。 2024年1月&#xff0c;微软推出了一款新的应用程序&#xff0c;它名为AutoGen Studio[3]&#xff0c;可以简化AI Agent执行过程。 一…