news 2026/4/16 9:08:41

基于时频谱图特征提取和改进型UNet卷积神经网络的机械故障诊断(Pytorch)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于时频谱图特征提取和改进型UNet卷积神经网络的机械故障诊断(Pytorch)

首先,将原始一维振动信号通过短时傅里叶变换转换为时频谱图,形成二维图像特征;接着构建了一个改进的UNet神经网络架构,该网络在保留UNet编码器-解码器结构的基础上移除了时间嵌入模块,增加了注意力机制和残差连接,专门用于谱图特征提取和分类;然后采用数据增强技术扩充训练样本,通过分层抽样划分数据集;模型训练阶段使用交叉熵损失函数、Adam优化器和学习率调度策略,并在验证集上监控性能保存最佳模型;最后在测试集上评估模型性能,计算准确率、混淆矩阵等指标,并可视化训练过程、预测结果和诊断报告,实现对轴承正常、滚珠故障、内圈故障和外圈故障四种状态的准确分类诊断。

import numpy as np import pandas as pd import matplotlib.pyplot as plt from pathlib import Path import warnings warnings.filterwarnings('ignore') import torch import torch.nn as nn from torch.utils.data import Dataset, DataLoader from torch.nn import functional as F import torch.optim as optim from torch.optim.lr_scheduler import ReduceLROnPlateau import math from sklearn.metrics import confusion_matrix, classification_report from sklearn.model_selection import train_test_split import seaborn as sns from scipy import signal import scipy.stats as stats # 设置随机种子确保可重复性 def set_seed(seed=42): torch.manual_seed(seed) torch.cuda.manual_seed_all(seed) if torch.cuda.is_available() else None np.random.seed(seed) torch.backends.cudnn.deterministic = True torch.backends.cudnn.benchmark = False set_seed(42) # 定义设备 device = torch.device("cuda" if torch.cuda.is_available() else "cpu") print(f"Using device: {device}") # ==================== 原始UNet组件 ==================== class Swish(nn.Module): """Swish激活函数""" def forward(self, x): return x * torch.sigmoid(x) class TimeEmbedding(nn.Module): """时间嵌入层(在原始UNet中用于扩散模型,这里保留但会简化)""" def __init__(self, T, d_model, dim): assert d_model % 2 == 0 super().__init__() emb = torch.arange(0, d_model, step=2) / d_model * math.log(10000) emb = torch.exp(-emb) pos = torch.arange(T).float() emb = pos[:, None] * emb[None, :] assert list(emb.shape) == [T, d_model // 2] emb = torch.stack([torch.sin(emb), torch.cos(emb)], dim=-1) assert list(emb.shape) == [T, d_model // 2, 2] emb = emb.view(T, d_model) self.timembedding = nn.Sequential( nn.Embedding.from_pretrained(emb), nn.Linear(d_model, dim), Swish(), nn.Linear(dim, dim), ) self.initialize() def initialize(self): """初始化权重""" for module in self.modules(): if isinstance(module, nn.Linear): nn.init.xavier_uniform_(module.weight) nn.init.zeros_(module.bias) def forward(self, t): emb = self.timembedding(t) return emb

详细算法步骤

数据采集与预处理阶段:从西储大学轴承数据集中加载四种不同故障状态的原始振动信号文件,对每一类信号进行标准化处理消除量纲影响,然后将长时信号按照固定长度和重叠率分割成多个短时信号片段,为后续分析准备基础数据单元。

特征工程构建阶段:对每个信号片段应用短时傅里叶变换算法,将一维时域信号转换为二维时频谱图,通过对数变换增强特征对比度,再统一缩放至固定尺寸形成标准化图像特征,同时提取信号的时域统计特征和频域特征作为补充信息。

数据集划分阶段:采用分层抽样策略将特征数据集按比例划分为训练集、验证集和测试集,确保每个子集中各类别样本分布均衡,避免因数据划分不当导致的模型评估偏差。

数据增强处理阶段:在训练集上应用随机噪声添加和随机幅度缩放等数据增强技术,人工扩充训练样本多样性,提高模型对实际工况变化的适应能力和泛化性能。

神经网络模型构建阶段:设计改进型UNet分类网络架构,保留编码器-解码器对称结构用于多尺度特征提取,引入注意力机制增强关键特征识别能力,使用残差连接缓解梯度消失问题,最后接入全局平均池化层和全连接分类器输出故障类别概率。

模型训练优化阶段:初始化网络权重参数,设置交叉熵损失函数和自适应矩估计优化器,采用动态学习率调整策略,在训练过程中实施梯度裁剪防止梯度爆炸,通过前向传播计算预测输出,反向传播更新网络参数,迭代优化模型性能。

模型验证与选择阶段:在独立验证集上定期评估模型表现,监控验证损失和分类准确率变化趋势,保存验证性能最优的模型权重,避免过拟合现象发生,确保模型具备良好泛化能力。

模型测试评估阶段:加载最佳模型权重,在未见过的测试集上进行全面性能评估,计算总体分类准确率、每类故障的精确率和召回率,生成混淆矩阵可视化分类错误分布,定量分析模型诊断能力。

参考文章:

基于时频谱图特征提取和改进型UNet卷积神经网络的机械故障诊断(Pytorch) - 哥廷根数学学派的文章 -
https://zhuanlan.zhihu.com/p/1998402980043583749

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 11:11:05

导师严选9个一键生成论文工具,研究生论文写作必备!

导师严选9个一键生成论文工具,研究生论文写作必备! AI 工具助力论文写作,效率与质量并重 在当前研究生论文写作过程中,AI 工具的应用已经逐渐成为一种趋势。随着 AIGC 技术的不断进步,许多学生开始借助 AI 工具来提升…

作者头像 李华
网站建设 2026/4/7 15:03:31

本地win系统和vmware 虚拟机 ubuntu实现文件共享

在实际的工作开发中,经常会运用到虚拟机的情况。当然,随着win系统版本地提升,从win10开始,本身win系统也自带了虚拟机的功能。但有一些老式的机子,是不支持的。为此,我就以 vmware 安装 ubuntu 来实现它与本…

作者头像 李华
网站建设 2026/4/12 23:19:40

Linux(ubuntu)如何锁定cpu频率工作在最低能耗模式下

最低频率最省电最省钱 三部曲: 1 sudo apt install -y cpufrequtils linux-tools-common linux-tools-generic 2 sudo cpupower frequency-set -g powersave 3 cpufreq-info 性能对比 https://blog.csdn.net/ZhangRelay/article/details/157299108 最高性…

作者头像 李华
网站建设 2026/4/3 7:38:11

论文答辩时,评审组导师一旦开始问问题,通常会问哪些问题?

先说一句你可能不爱听、但非常重要的话:评审组导师一问问题, 其实已经在心里对你的论文有了一个初步判断。接下来的提问, 不是临时发挥, 而是围绕几个固定维度,快速确认三件事:这篇论文是不是你真正理解的研…

作者头像 李华
网站建设 2026/4/13 14:15:46

读研方法-2026

文献综述 ① 读综述起手,快速扫清盲区 构建文献图谱-Connected Papers | Find and explore academic papers 提供真实文献的-Paper Digest – AI-Powered Research Platform 知网-硕博论文综述部分-中国知网 边看边记,构建自己的关键词语录&#xff…

作者头像 李华