c++ 提取傅里叶描述子_工业数据:基于统计和信号的特征提取方法

在机械加工过程中,刀具铣削过程传感器监控数据均为时序数据,如下图所示,表现为一系列没有固定规律的随机离散值,不能有效识别数据特征与磨损度的关系,因此需要进行特征提取,把原有的低维时序数据映射到高维表示,挖掘和构造输入数据的新特征,进而找出最能帮助模型拟合的输入(X)和输出(Y)特征。

4e7e593945b4bd1cd614952fc4ef84c8.png

在很多预测性维护的场景(如旋转件、振动等)中,我们完全可以采用基于统计和信号的特征提取方法就能得到一些较好的特征。本文的特征提取方法主要包含三个角度:

  • 基于统计的时域特征
  • 基于频谱分析的频域特征
  • 基于小波包能量的时频联合域特征

1 基于统计的时域特征

基于统计的时域特征,就是使用统计学方法如均方根、方差、最大值、最小值、偏斜度、峰度、峰峰值等提取出的新数据。

1.1 均方根(Root Mean Square, RMS)

均方根(Root Mean Square, RMS),是信号有效值的反映:

1.2 方差(Variance)

方差(Variance),衡量随机变量或一组数据离散程度,是源数据和期望值相差的度量:

1.3 最大值(Max)和最小值(Min)

最大值(Max)和最小值(Min),表示在一定时间范围内数据的最强和最弱的程度:

1.4 偏度(Skewness)

偏度(Skewness)又称偏态系数,度量数据的概率密度曲线分布偏斜的方向和程度,即与平均值相比数据的非对称的程度特征。

其中, 是3阶中心距, 为标准差。

1.5 峰峰值(Peak to Peak, PP)

峰峰值(Peak to Peak, PP),即一个周期内数据最高值和最低值之间的差值,描述了数据的变化范围的大小:

1.6 峰度(Kurtosis)

峰度(Kurtosis)又称峰态系数,表示在平均值处数据的概率密度分布曲线的最大值大小。峰度直观地反映了曲线的峰部尖度,峰度越高,说明曲线底部厚度越大,会导致方差越大,原因是数据存在一定数量的显著比平均值大或小的差值。

其中, 是四阶中心矩, 是标准差。

2 基于频谱分析的频域特征

频域分析是信号领域中很重要的分析方法,具体包括了频谱分析、能量谱分析、功率谱分析和倒频谱分析等,其中以频谱分析最为常用也最为重要。频谱分析主要将信号数据通过傅里叶变换得到幅频谱和相频谱进行分析,有关傅里叶变换的内容网上有很多,就不赘述了。

通过计算机和传感器采集得到的信号是离散信号,可以采用离散傅里叶变换:

信号的幅值和相位可以表示为:

分别以幅值和相位为纵坐标,以频率作为横坐标,绘制出的二维坐标图为幅值谱图和相位谱图,幅值谱图表征信号的幅值随频率的分布情况,相位谱图表征了信号的相位随频率的变化情况。在铣刀磨损度预测任务中,可以通过幅值谱提取以下统计特征:

2.1 谱偏态系数

谱偏态系数(Spectral Skewness):统计频域上幅值的分布偏斜的方向和程度:

2.2 谱峰态系数

谱峰态系数(Spectral Kurtosis):表示频域上幅值波形的尖锐程度:

2.3 谱功率

谱功率(Spectral Power):表示单位频带内的信号功率:

3 基于小波包能量的时频联合域特征

小波变换(wavelet transform,WT)是一种新的变换分析方法,它继承和发展了短时傅立叶变换局部化的思想,同时又克服了窗口大小不随频率变化等缺点,能够提供一个随频率改变的“时间-频率”窗口,是进行信号时频分析和处理的理想工具。

小波变换过程简述如下:

  1. 原始输入信号X通过一组小波函数基经低通滤波器和高通滤波器分解后进行下采样,得到低频分量(又称为近似子带)和高频分量(又称为细节子带),
  2. 将低频分量作为输入信号,又进行小波分解,得到下一层的低频分量和高频分量,以此类推,可以得到层的小波分解,如图 (a)所示。 随着小波分解层数的增加,其在频域上的分辨率越高,这被称为多分辨率分析(MultiResolution Analysis, MRA)。

小波包分解(Wavelet Packet Decomposition)又称为最优子带树结构(Optimal Subband Tree Structuring),如图(b)所示,是对小波变换的进一步优化,具体为:在小波变换的基础上,也对细节子带进一步分解,最后通过最小化代价函数,计算出最优的信号分解路径,并以此路径对原始输入信号进行分解。

d29c14082bf41b846af1737986595d39.png

选择合适的小波函数基是进行信号分解的关键步骤。常用的小波函数基有哈尔小波函数基、多贝西小波和双正交小波等。

多贝西小波作为稀疏基引入信号的光滑误差不容易被察觉,因此具有较好的正则性,信号重构过程比较光滑,而且可以通过阶次N的来控制频域的局部化能力,使用较为灵活,因此本文的小波包分解过程采用多贝西小波函数基。

4 特征提取实际效果

介绍完枯燥的原理后,我们通过实际操作来看看这么常用的特征提取方法最终的效果如何。

4.1 时域特征提取效果

图中展示了PHM2010刀具磨损预测数据集C1数据的X轴的振动信号在铣刀磨损周期内的6个统计学特征与磨损度的关系图。

dc54ca38242c61f02fa6001583ac0700.png

4.2 频域特征提取效果

频域特征首先对预处理后的原始数据进行FFT处理,得到幅值谱图,然后分别计算谱偏态系数、谱峰态系数和谱功率,获得铣刀磨损度预测的频域特征。图中(a)展示的是C1数据的X轴振动信号预处理后的数据经过快速傅里叶变换得到的幅值谱图,图中(b)(c)(d)分别是谱偏态系数、谱峰态系数、谱功率与磨损度的关系图。

0365b1818ebea69299ccdf864649e623.png

4.3 时频联合域特征提取效果

在小波包分解过程中,小波函数基采用多贝西小波函数,采用分解层数的小波包,则最后一层小波包数量为,下图 (b)所示的是C1数据集X轴振动信号进行小波包分解提取的能量特征与磨损度关系的可视化结果,最后通过计算小波包分解结果的2-范数来提取能量特征,绘制出C1刀具磨损量与小波能量特征的关系如图 (c)。

eb6d91e75ff440f109525365795a2642.png

6 小结

至此,原始输入数据的基于统计的时域特征、基于频谱的频域特征和基于小波能量的时频域特征被提取出来,原来7个通道的数据扩展到70个通道,在更高维的数值空间表征了更多的过程数据信息,为铣刀磨损度预测提供了丰富的样本数据。

7 实验代码

import pandas as pdimport numpy as npimport matplotlib.pyplot as pltimport scipy.stats as stsimport timefrom pywt._wavelet_packets import WaveletPacketstart_time = time.time()# ****************************************#           特征提取函数# ****************************************def rms_fea(a):    return np.sqrt(np.mean(np.square(a)))def var_fea(a):    return np.var(a)    # 方差def max_fea(a):    return np.max(a)def skew_fea(a):        # 偏度    return sts.skew(a)def kurt_fea(a):        # 峰度    return sts.kurtosis(a)def pp_fea(a):          # 峰峰值    return np.max(a) - np.min(a)def wave_fea(a):    wp = WaveletPacket(a, 'db1', maxlevel=8)    nodes = wp.get_level(8, 'freq')    return np.linalg.norm(np.array([n.data for n in nodes]), 2)def spectral_skw(a):    n = a.shape[0]    mag = np.abs(np.fft.fft(a))    mag = mag[1:n//2]*2.00/n    return sts.skew(mag)def spectral_kurt(a):    n = a.shape[0]    mag = np.abs(np.fft.fft(a))    mag = mag[1:n//2]*2.00/n    return sts.kurtosis(mag)def spectral_pow(a):    n = a.shape[0]    mag = np.abs(np.fft.fft(a))    mag = mag[1:n//2]*2.00/n    return np.mean(np.power(mag, 3))def extract_fea(data, num_stat=10):    data_fea = []    dim_feature = 1    for i in range(dim_feature):        data_slice = data        data_fea.append(rms_fea(data_slice))        data_fea.append(var_fea(data_slice))        data_fea.append(max_fea(data_slice))        data_fea.append(pp_fea(data_slice))        data_fea.append(skew_fea(data_slice))        data_fea.append(kurt_fea(data_slice))        data_fea.append(wave_fea(data_slice))        data_fea.append(spectral_kurt(data_slice))        data_fea.append(spectral_skw(data_slice))        data_fea.append(spectral_pow(data_slice))    data_fea = np.array(data_fea)    return data_fea.reshape((1, dim_feature*num_stat))# ****************************************#           数据处理 -->> 生成特征# ****************************************sample_num = 315sensor_num = 7feature_num = 70print()print('-' * 30)print('         正在提取数据     ')print('-' * 30)print()# C1_normaldata = np.zeros((sample_num, feature_num), dtype=np.float32)for sample_index in range(0, sample_num):    print("Processing C1 set:" + str(sample_index + 1))    for m in range(0, sensor_num):        str1 = "%03d" % (sample_index + 1)        str2 = m + 1        read_path = 'C:/Users/Kaifeng Guan/Desktop/My Tool Wear rediction/Code/new_data/dataset1/c1/c_1_' \                    + str(str1) + '/f' + str(str2) + '.csv'        pre_data = np.array(pd.read_csv(read_path))        pre_data = np.reshape(pre_data, (len(pre_data),))        data[sample_index, m*10:(m+1)*10] = extract_fea(pre_data)C1_normal = data# C4_normaldata = np.zeros((sample_num, feature_num), dtype=np.float32)for sample_index in range(0, sample_num):    print("Processing C4 set:" + str(sample_index + 1))    for m in range(0, sensor_num):        str1 = "%03d" % (sample_index + 1)        str2 = m + 1        read_path = 'C:/Users/Kaifeng Guan/Desktop/My Tool Wear rediction/Code/new_data/dataset1/c4/c_4_' \                    + str(str1) + '/f' + str(str2) + '.csv'        pre_data = np.array(pd.read_csv(read_path))        pre_data = np.reshape(pre_data, (len(pre_data),))        data[sample_index, m*10:(m+1)*10] = extract_fea(pre_data)C4_normal = data# C6_normaldata = np.zeros((sample_num, feature_num), dtype=np.float32)for sample_index in range(0, sample_num):    print("Processing C6 set:" + str(sample_index + 1))    for m in range(0, sensor_num):        str1 = "%03d" % (sample_index + 1)        str2 = m + 1        read_path = 'C:/Users/Kaifeng Guan/Desktop/My Tool Wear rediction/Code/new_data/dataset1/c6/c_6_' \                    + str(str1) + '/f' + str(str2) + '.csv'        pre_data = np.array(pd.read_csv(read_path))        pre_data = np.reshape(pre_data, (len(pre_data),))        data[sample_index, m*10:(m+1)*10] = extract_fea(pre_data)C6_normal = data

8907dbd3672131ad291fda8023e88565.png

添加微信,和我一起讨论

9dd06bea40990e153851ad3f357088d7.png

扫一扫关注我们一起交流,共同进步

0775f840964635cd7b580d985370584f.png

点亮 ee4f54a9a2bf6fccf4577a473aff51b0.png,是对我们最大的赞赏ba03bc93071945775112d8a401cdff9c.gif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值