news 2026/4/23 15:38:57

基于时频谱图特征提取和改进型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/4/23 15:34:08

Redis 核心:概念理解与五大数据结构

Redis(Remote Dictionary Server) NoSQL(非关系型数据库) 非关系型数据库的数据是非结构化的(没有固定的结构)、无关联的(没有关系的创建和维护)、非sql(没有固定的语法)、事务特性…

作者头像 李华
网站建设 2026/4/22 18:58:22

连锁门店数字化平台核心功能与适用场景解析

当下,零售行业竞争越发激烈,连锁门店的运营效率,以及管理精细化程度,直接决定了它的市场竞争力。传统管理模式依靠人工操作,还有分散的系统,常常致使信息孤岛出现,数据滞后,协同困难…

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

Reactor线程池切换publishOn与subscribeOn

在 Reactor(Project Reactor)中,publishOn 和 subscribeOn 是用于 切换执行线程(调度器) 的两个操作符,但它们的行为和用途 截然不同。下面是它们的详细区别与使用说明。 🧠 一句话理解 **subs…

作者头像 李华
网站建设 2026/4/17 3:53:23

亲测好用10个AI论文网站,继续教育学生轻松搞定毕业论文!

亲测好用10个AI论文网站,继续教育学生轻松搞定毕业论文! AI 工具让论文写作不再难 在当前的学术环境中,越来越多的继续教育学生开始借助 AI 工具来提升论文写作效率。尤其是 AI 降重工具的出现,不仅有效降低了 AIGC 率&#xff…

作者头像 李华
网站建设 2026/4/23 13:03:59

一文掌握 Spring AI:集成主流大模型的完整方案与思考

一文掌握 Spring AI:集成主流大模型的完整方案与思考 Spring AI 是 Spring 生态中一个新兴的框架,旨在简化 Java/Spring Boot 应用与主流大语言模型(Large Language Models, LLM)的集成。它提供了一套统一的抽象接口,…

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

面了十几家公司测试岗,我终于悟了,面试无非就是这些题

测试岗的面试其实都是大同小异的,这里我收集整理了185道高频面试题,希望对在找工作或者准备跳槽的各位小伙伴有所帮助! 一. 测试基础 1.如何制定测试计划 参考答案: 测试计划包括测试目标、测试范围、测试环境的说明、测试类型…

作者头像 李华