凯斯西储大学轴承故障数据

一、项目简介

本文主要介绍如何使用python搭建:一个基于深度学习的滚动轴承故障诊断系统

项目中涉及使用了多种方法对比检测结果,包括:

传统机器学习方法:随机森林深度学习方法:CNN增加残差模块后的深度学习方法:CNN+ResBlock

如各位童鞋需要更换训练数据,完全可以根据源码将图像和标注文件更换即可直接运行。

博主也参考过网上故障检测的相关文章,但大多是理论大于方法。很多同学肯定对原理不需要过多了解,只需要搭建出一个基于深度学习的轴承故障预测系统即可。

也正是因为我发现网上大多的帖子只是针对原理进行介绍,功能实现的相对很少。

如果您有以上想法,那就找对地方了!

不多废话,直接进入正题!

二、数据介绍

本次项目的数据是使用的凯斯西储大学(Case Western Reserve University)轴承数据中心的开源数据集。

数据文件采用Matlab格式。每个文件都包含风扇和驱动端振动数据以及电机转速。对于所有文件,变量名称中的以下项表示:

DE – 驱动端加速计数据

FE – 风扇端加速计数据

BA – 基础加速计数据

time – 时间序列数据

RPM- 测试期间的转速

2.1 故障类型图示2.2 数据图示2.3 查看单个数据文件情况2.4 数据分布情况

博主对:

正常

内圈故障

外圈故障

滚动体故障

四种不同情况下轴承的数据分布进行了可视化展示,由于图示较多,这里只展示内圈故障的一个文件的数据分布情况,其他情况感兴趣的同学可以下载完整代码运行看看。

三、数据预处理

通过可视化观察发现数据波长周期基本上为100-200左右,博主这边使用1000作为采样长度,对所有轴承数据进行采样,并构建label。我们这次需要学习并预测的是输入的轴承数据是为:正常、内圈故障、外圈故障、滚动体故障。中哪一类,因此是一个4分类的任务。处理后数据分布如下:

正常样本:1696个

内圈故障样本:1455个

滚动体故障样本:1457个

外圈故障样本: 1457个

然后对数据进行采样,保证每类数据1400个。

data_train = np.asarray(data_normal[:1400] + data_inner[:1400] + data_ball[:1400] + data_outer[:1400],dtype = 'float64')label = np.asarray(label_normal[:1400] + label_inner[:1400] + label_ball[:1400] + label_outer[:1400],dtype = 'int64')print("处理后样本shape:",data_train.shape)print("处理后数据类别分布:",Counter(label))# 保存数据np.save("train_data/train_data.npy",data_train)np.save("train_data/label.npy",label)print("数据保存成功,位置:/train_data/")

四、模型训练及评估4.1 加载数据

def load_data(): # 读取数据 x = np.load('train_data/train_data.npy') y = np.load('train_data/label.npy') num = len(Counter(y)) print("类别数量为:", num) return x, y, num # 读取数据data, label, label_count = load_data()# 生成训练集测试集,70%用作训练,30%用作测试train_data, train_label, val_data, val_label = create_train_data(data, label, 0.7)print("*"*10)print("训练集数量:",len(train_label))print("测试集数量:",len(val_label))

4.2 随机森林

# 模型参数设置rfc = RandomForestClassifier(n_estimators = 50,min_samples_split = 5,min_samples_leaf = 4,max_depth = 5)# 模型准确率和损失值acc_list = []loss_list = []train_acc_list = []print("开始训练")for i in range(1,epoch +1): # 模型训练 rfc.fit(m_train,train_label) # # 训练集 # y_train = rfc.predict(m_train) # 测试集 y_pred = np.asarray(rfc.predict(m_val),dtype = 'int64') # 计算准确率 acc = round(accuracy_score(val_label, y_pred),3) # 训练集 y_pred = np.asarray(rfc.predict(m_train),dtype = 'int64') # 计算准确率 train_acc = round(accuracy_score(train_label, y_pred),3) # print('测试集准确率:', round(accuracy_score(val_label, y_pred),3)) acc_list.append(acc) train_acc_list.append(train_acc) # 计算损失值 # 使用one-hot编码计算损失值 noe_hot = OneHotEncoder(sparse = False) y_pred_o = noe_hot.fit_transform(y_pred.reshape(1, -1)) val_label_o = noe_hot.fit_transform(val_label.reshape(1, -1))# loss = round(log_loss(val_label_o,y_pred_o),3) # print("loss:",round(log_loss(val_label,y_pred),3))# loss_list.append(loss) print("完成第",i,"轮训练,测试集准确率:",acc)

4.2.1 模型训练4.2.2 模型测试4.3 CNN

构建一个CNN网络,结构如下:

4.3.1 模型训练4.3.2 模型测试

可以看到,使用原始cnn模型训练后准确率只有83。类标2即“内圈故障”的召回率较低,无法准确有效识别。

4.4 CNN+ResBlock

模型构建:

import n_model as mdimport tensorflow as tf# 模型参数model_param = { "a_shape": 1000, "b_shape": 2, "label_count": 4, "num_b":5}data_shape=(model_param['a_shape'],model_param['b_shape'])# 模型实例化model = md.CNN_ResNet_model(model_param['label_count'] , model_param['num_b'] , data_shape=data_shape)# 使用学习率进行训练res_model = model.model_create(learning_rate = 1e-4)# 模型网络结构print("实例化模型成功,网络结构如下:")print(res_model.summary())# 设置模型log输出地址log_dir = os.path.join("logs/ResNet")if not os.path.exists(log_dir): os.mkdir(log_dir)

4.4.1 模型训练4.4.2 模型测试

可以看到,增加了残差模块的CNN网络已经能准确对不同故障类型进行分类,准确率和召回率均在95分以上。

五、完整代码地址

由于项目代码量和数据集较大,感兴趣的同学可以下载完整代码,使用过程中如遇到任何问题可以在评论区评论或者私信我,我都会一一解答。

完整代码下载:

点击即可获取→→→→→AI鈥斺€擹iLiaoHuoQu←←←←←←

声明:壹贝网所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流,版权归原作者wangteng@admin所有,原文出处。若您的权利被侵害,请联系 756005163@qq.com 删除。

本文链接:https://www.ebaa.cn/36550.html

(0)
上一篇 2024年11月22日
下一篇 2024年11月22日

相关推荐

  • 澳大利亚景观设计就业

    随着科技的飞速发展,许多新兴专业逐渐进入人们的视野,地理信息科学(GIS)作为一门融合了地理学、计算机科学和遥感技术的交叉学科,近年来备受关注。在国内就业率、薪资水平连年齐升,在新西兰属于绿名单一类移民职业,非常紧缺。这个曾被称作"冷门"的专业,正在成为国际市场高薪就业的下一个风口。这一期我们就来了聊一聊这个专业的就业前景和留学课程选择。…

    2025年12月19日
  • 瓦格宁根大学土壤污染

    火星,它能种地吗? 今天我的一个朋友不自觉就开始思考起了这个问题,原因也很简单,喜大普奔,据央视报道: 「5月15日7时18分,天问一号探测器成功着陆火星,在火星上首次留下中国人的印迹。」 没错,在闯过重重障碍后,我国首次火星探测任务着陆火星取得圆满成功。 民以食为天。着陆成功后,让万千网友心心念念的下一步,便是在火星上种地建设农业基地。 但是,从地球长期往…

    2025年4月17日
  • 香港大学面试_香港大学面试题目

    一·需要面试的专业有哪些? 香港大学需要面试的专业比较多,文社科,建筑,教育,理工的大部分专业都需要面试。 二·面试的方式有哪些?现场还是视频? 面试过程全英文,视频面试和现场面试两种都有可能。 1.视频面试 香港硕士入学面试,绝大多数都是视频面试,一般会用skype或者zoom软件进行。 你需要做的是提前下载好软件(在正规网站下载),注册好账号,还有各种应…

    2024年3月16日
  • 东国大学研究生好录取吗

    东国大学(동국대학교,Dongguk University),简称“东大(DGU)”,取"东方之国"之意,韩国佛教宗派曹溪宗创办的一所的私立高等学校。东国大学始创于1906年,其前身是以“教育救国”为目的开办的明进学校。现设有13个单科大学和11个研究生院。[1] 我是一名18年7月入学的东大电子系在读博士生,已经在东国学习三年了,还算是…

    2025年3月31日
  • 澳洲詹姆斯库克大学留学

    北京外国语大学(教育部)出国人员培训部简介 1985 年教育部在北京外国语大学正式成立出国人员培训部,主要承担国家教委公派人员出国前的外语强化培训以及自费出国留学项目的招生、教学和管理工作。近年来,随着自费出国留学人员的不断增加,北京外国语大学出国人员培训部积极与海外大学开展合作,先后开设了英语国家国际名校预科课程、国际学分豁免课程,成功培养出数千名自费出国…

    2024年10月17日
  • 韩语思密达是什么意思

    不知道大家有没有这样的经历,碰到有人问会不会一门语言的时候,我们会去模仿这门语言的口气,再在结尾处加上这门语言特有又常见的词。比如假装自己会泰语。胡乱说上几句后加上一句“萨瓦迪卡”就很有泰语风味。 举一反三,如果是韩语,那你会想到什么?我猜绝对是“思密达”! “思密达”这样的词似乎也成为了韩语的标志,我们在观看韩剧韩综的时候就算完全不懂韩语,但会在对话中精准…

    2024年6月12日
  • 211大学排名最新排名录取分数线

    211与985大学都是国内公认的顶尖学府,是很多考生理想中的高校,更是他们梦寐以求都想考上的大学。本期,小编就为大家整理了全国211大学排名名单一览表,并附上录取分数汇总,供2021届高考生参考。 一、211大学排名 目前,全国共有116所211大学。国家在1995年启动“211工程”建设工程,211工程是国家实施科教兴国战略和人才强国战略的重大举措,国家2…

    2024年12月2日
  • 法国图卢兹第一大学怎么样

    在留学规划与暑期旅行计划(https://tbs-education.com.cn/2025-qs-city-ranking/)中,寻找一座兼具优质教育资源与独特旅游体验的城市并非易事。法国西南部的图卢兹,既是备受认可的留学目的地,也是《孤独星球》评选的 “2025 年全球最值得探索的城市” 中唯一入选的法国城市,平衡学术氛围与文旅魅力,成为 “留学国家 /…

    2025年9月11日
  • 世界最好的大学排名完整版

    近日,U.S. News公布了2025-2026年度世界大学学科排名。其中,江南大学食品科学与技术排名世界第一,农业科学排名世界第二。 本次的排名中 江南大学共有24个学科上榜 其中 3个学科排名前10 4个学科排名前50 6个学科排名前100 18个学科排名前300 2025-2026年U.S. News 世界大学学科中国内地高校学科 前五排名情况 U.S…

    2025年7月28日
  • 纽卡斯尔大学澳洲在哪

    一座城孕育一所大学,一所大学成就一座城,走进澳洲年轻名校,纽卡斯尔大学。 历史 纽卡斯尔是澳大利亚第七大城市,1951年新南威尔士州大学在此成立了纽卡斯尔大学学院(Newcastle University College),开设了数学、工程、应用科学和人文学科等学位课程。1965年纽卡斯尔大学学院从新南威尔士州大学独立出来,正式更名为纽卡斯尔大学。 科研综合…

    2025年5月7日

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信