将一维机械振动信号构造为训练集和测试集(Python)

2024-06-24 12:04

本文主要是介绍将一维机械振动信号构造为训练集和测试集(Python),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

从如下链接中下载轴承数据集。

https://www.sciencedirect.com/science/article/pii/S2352340918314124


import numpy as np
import scipy.io as sio
import matplotlib.pyplot as plt
import statistics as stats
import pandas as pd
from sklearn.model_selection import train_test_split
A1 = sio.loadmat('./Data/H-A-1.mat')
channel1HA1 = HA1['Channel_1']
n = len(channel1HA1) # Número de muestrascanal1HA1 = channel1HA1.T[0]
f = 200000 # Hz #graba a 200000 por s
t = np.linspace(0, 10, n)
dt = t[1] - t[0]HA2 = sio.loadmat('./Data/H-A-2.mat')
channel1HA2 = HA2['Channel_1']
canal1HA2 = channel1HA2.T[0]HA3 = sio.loadmat('./Data/H-A-3.mat')
channel1HA3 = HA3['Channel_1']
canal1HA3 = channel1HA3.T[0]
HB1 = sio.loadmat('./Data/H-B-1.mat')
channel1HB1 = HB1['Channel_1']
canal1HB1 = channel1HB1.T[0]HB2 = sio.loadmat('./Data/H-B-2.mat')
channel1HB2 = HB2['Channel_1']
canal1HB2 = channel1HB2.T[0]HB3 = sio.loadmat('./Data/H-B-3.mat')
channel1HB3 = HB3['Channel_1']
canal1HB3 = channel1HB3.T[0]
HC1 = sio.loadmat('./Data/H-C-1.mat')
channel1HC1 = HC1['Channel_1']
canal1HC1 = channel1HC1.T[0]HC2 = sio.loadmat('./Data/H-C-2.mat')
channel1HC2 = HC2['Channel_1']
canal1HC2 = channel1HC2.T[0]HC3 = sio.loadmat('./Data/H-C-3.mat')
channel1HC3 = HC3['Channel_1']
canal1HC3 = channel1HC3.T[0]
HD1 = sio.loadmat('./Data/H-D-1.mat')
channel1HD1 = HD1['Channel_1']
canal1HD1 = channel1HD1.T[0]HD2 = sio.loadmat('./Data/H-D-2.mat')
channel1HD2 = HD2['Channel_1']
canal1HD2 = channel1HD2.T[0]HD3 = sio.loadmat('./Data/H-D-3.mat')
channel1HD3 = HD3['Channel_1']
canal1HD3 = channel1HD3.T[0]
sanos = pd.DataFrame({'Sano1': canal1HA1, 'Sano2': canal1HA2, 'Sano3': canal1HA3,'Sano4': canal1HB1, 'Sano5': canal1HB2, 'Sano6': canal1HB3,'Sano7': canal1HC1, 'Sano8': canal1HC2, 'Sano9': canal1HC3,'Sano10': canal1HD1, 'Sano11': canal1HD2, 'Sano12': canal1HD3})
sanos

IA1 = sio.loadmat('./Data/I-A-1.mat')
channel1IA1 = IA1['Channel_1']
canal1IA1 = channel1IA1.T[0]IA2 = sio.loadmat('./Data/I-A-2.mat')
channel1IA2 = IA2['Channel_1']
canal1IA2 = channel1IA2.T[0]IA3 = sio.loadmat('./Data/I-A-3.mat')
channel1IA3 = IA3['Channel_1']
canal1IA3 = channel1IA3.T[0]
IB1 = sio.loadmat('./Data/I-B-1.mat')
channel1IB1 = IB1['Channel_1']
canal1IB1 = channel1IB1.T[0]IB2 = sio.loadmat('./Data/I-B-2.mat')
channel1IB2 = IB2['Channel_1']
canal1IB2 = channel1IB2.T[0]IB3 = sio.loadmat('./Data/I-B-3.mat')
channel1IB3 = IB3['Channel_1']
canal1IB3 = channel1IB3.T[0]
IC1 = sio.loadmat('./Data/I-C-1.mat')
channel1IC1 = IC1['Channel_1']
canal1IC1 = channel1IC1.T[0]IC2 = sio.loadmat('./Data/I-C-2.mat')
channel1IC2 = IC2['Channel_1']
canal1IC2 = channel1IC2.T[0]IC3 = sio.loadmat('./Data/I-C-3.mat')
channel1IC3 = IC3['Channel_1']
canal1IC3 = channel1IC3.T[0]
ID1 = sio.loadmat('./Data/I-D-1.mat')
channel1ID1 = ID1['Channel_1']
canal1ID1 = channel1ID1.T[0]ID2 = sio.loadmat('./Data/I-D-2.mat')
channel1ID2 = ID2['Channel_1']
canal1ID2 = channel1ID2.T[0]ID3 = sio.loadmat('./Data/I-D-3.mat')
channel1ID3 = ID3['Channel_1']
canal1ID3 = channel1ID3.T[0]
inners = pd.DataFrame({'Inner1': canal1IA1, 'Inner2': canal1IA2, 'Inner3': canal1IA3,'Inner4': canal1IB1, 'Inner5': canal1IB2, 'Inner6': canal1IB3,'Inner7': canal1IC1, 'Inner8': canal1IC2, 'Inner9': canal1IC3,'Inner10': canal1ID1, 'Inner11': canal1ID2, 'Inner12': canal1ID3})
inners

OA1 = sio.loadmat('./Data/O-A-1.mat')
channel1OA1 = OA1['Channel_1']
canal1OA1 = channel1OA1.T[0]OA2 = sio.loadmat('./Data/O-A-2.mat')
channel1OA2 = OA2['Channel_1']
canal1OA2 = channel1OA2.T[0]OA3 = sio.loadmat('./Data/O-A-3.mat')
channel1OA3 = OA3['Channel_1']
canal1OA3 = channel1OA3.T[0]
OB1 = sio.loadmat('./Data/O-B-1.mat')
channel1OB1 = OB1['Channel_1']
canal1OB1 = channel1OB1.T[0]OB2 = sio.loadmat('./Data/O-B-2.mat')
channel1OB2 = OB2['Channel_1']
canal1OB2 = channel1OB2.T[0]OB3 = sio.loadmat('./Data/O-B-3.mat')
channel1OB3 = OB3['Channel_1']
canal1OB3 = channel1OB3.T[0]
OC1 = sio.loadmat('./Data/O-C-1.mat')
channel1OC1 = OC1['Channel_1']
canal1OC1 = channel1OC1.T[0]OC2 = sio.loadmat('./Data/O-C-2.mat')
channel1OC2 = OC2['Channel_1']
canal1OC2 = channel1OC2.T[0]OC3 = sio.loadmat('./Data/O-C-3.mat')
channel1OC3 = OC3['Channel_1']
canal1OC3 = channel1OC3.T[0]
OD1 = sio.loadmat('./Data/O-D-1.mat')
channel1OD1 = OD1['Channel_1']
canal1OD1 = channel1OD1.T[0]OD2 = sio.loadmat('./Data/O-D-2.mat')
channel1OD2 = OD2['Channel_1']
canal1OD2 = channel1OD2.T[0]OD3 = sio.loadmat('./Data/O-D-3.mat')
channel1OD3 = OD3['Channel_1']
canal1OD3 = channel1OD3.T[0]
outers = pd.DataFrame({'Outer1': canal1OA1, 'Outer2': canal1OA2, 'Outer3': canal1OA3,'Outer4': canal1OB1, 'Outer5': canal1OB2, 'Outer6': canal1OB3,'Outer7': canal1OC1, 'Outer8': canal1OC2, 'Outer9': canal1OC3,'Outer10': canal1OD1, 'Outer11': canal1OD2, 'Outer12': canal1OD3})
outers

signals = []
for i in range(1, 13):signal = sanos['Sano' + str(i)].valuessignals.append(signal)for i in range(1, 13):signal = inners['Inner' + str(i)].valuessignals.append(signal)for i in range(1, 13):signal = outers['Outer' + str(i)].valuessignals.append(signal)tipo = ['Sano'] * 12 + ['Inner'] * 12 + ['Outer'] * 12
X = signals
y = tipo
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size = 0.25, train_size = 0.75, random_state = 0, stratify = y)
sio.savemat('./ProcessedData/signals_train.mat', {'Signal': X_train, 'Tipo': y_train})
sio.savemat('./ProcessedData/signals_test.mat', {'Signal': X_test, 'Tipo': y_test})知乎学术咨询:
https://www.zhihu.com/consult/people/792359672131756032?isMe=1

工学博士,担任《Mechanical System and Signal Processing》《中国电机工程学报》《控制与决策》等期刊审稿专家,擅长领域:现代信号处理,机器学习,深度学习,数字孪生,时间序列分析,设备缺陷检测、设备异常检测、设备智能故障诊断与健康管理PHM等。

这篇关于将一维机械振动信号构造为训练集和测试集(Python)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1090096

相关文章

【操作系统】信号Signal超详解|捕捉函数

🔥博客主页: 我要成为C++领域大神🎥系列专栏:【C++核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 ​ 如何触发信号 信号是Linux下的经典技术,一般操作系统利用信号杀死违规进程,典型进程干预手段,信号除了杀死进程外也可以挂起进程 kill -l 查看系统支持的信号

Python 字符串占位

在Python中,可以使用字符串的格式化方法来实现字符串的占位。常见的方法有百分号操作符 % 以及 str.format() 方法 百分号操作符 % name = "张三"age = 20message = "我叫%s,今年%d岁。" % (name, age)print(message) # 我叫张三,今年20岁。 str.format() 方法 name = "张三"age

一道经典Python程序样例带你飞速掌握Python的字典和列表

Python中的列表(list)和字典(dict)是两种常用的数据结构,它们在数据组织和存储方面有很大的不同。 列表(List) 列表是Python中的一种有序集合,可以随时添加和删除其中的元素。列表中的元素可以是任何数据类型,包括数字、字符串、其他列表等。列表使用方括号[]表示,元素之间用逗号,分隔。 定义和使用 # 定义一个列表 fruits = ['apple', 'banana

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

python 喷泉码

因为要完成毕业设计,毕业设计做的是数据分发与传输的东西。在网络中数据容易丢失,所以我用fountain code做所发送数据包的数据恢复。fountain code属于有限域编码的一部分,有很广泛的应用。 我们日常生活中使用的二维码,就用到foutain code做数据恢复。你遮住二维码的四分之一,用手机的相机也照样能识别。你遮住的四分之一就相当于丢失的数据包。 为了实现并理解foutain

python 点滴学

1 python 里面tuple是无法改变的 tuple = (1,),计算tuple里面只有一个元素,也要加上逗号 2  1 毕业论文改 2 leetcode第一题做出来

YOLO v3 训练速度慢的问题

一天一夜出了两个模型,仅仅迭代了200次   原因:编译之前没有将Makefile 文件里的GPU设置为1,编译的是CPU版本,必须训练慢   解决方案: make clean  vim Makefile make   再次训练 速度快了,5分钟迭代了500次

Python爬虫-贝壳新房

前言 本文是该专栏的第32篇,后面会持续分享python爬虫干货知识,记得关注。 本文以某房网为例,如下图所示,采集对应城市的新房房源数据。具体实现思路和详细逻辑,笔者将在正文结合完整代码进行详细介绍。接下来,跟着笔者直接往下看正文详细内容。(附带完整代码) 正文 地址:aHR0cHM6Ly93aC5mYW5nLmtlLmNvbS9sb3VwYW4v 目标:采集对应城市的

python 在pycharm下能导入外面的模块,到terminal下就不能导入

项目结构如下,在ic2ctw.py 中导入util,在pycharm下不报错,但是到terminal下运行报错  File "deal_data/ic2ctw.py", line 3, in <module>     import util 解决方案: 暂时方案:在终端下:export PYTHONPATH=/Users/fujingling/PycharmProjects/PSENe