【信号去噪】基于麻雀搜索算法优化VM实现信号去噪附matlab代码

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
简介: 【信号去噪】基于麻雀搜索算法优化VM实现信号去噪附matlab代码

 💥💥💥💞💞💞欢迎来到本博客❤️❤️❤️💥💥💥

📝目前更新:🌟🌟🌟智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真。

                       

                             🎉🎉欢迎您的到来🎉🎉


               ⛅⛅⛅ 📃CSDN主页:Matlab科研室🌈🌈🌈


             📚📚📚📋所有代码目录见微信公众号:天天Matlab👨•💻👨•💻👨•💻

1 内容介绍

为准确提取轴承故障特征信息,提出以样本熵为综合目标函数的变分模态分解(variational mode decomposition,VMD)参数优化方法,并改进了诊断流程实现了无需指定参数优化范围的自适应参数优化算法.通过麻雀算法对综合目标函数最小值进行搜索,以确定模态分量个数及惩罚参数的最佳组合.原始故障信号经最佳参数组合下的VMD方法分解为若干个本征模态函数,选择最小综合目标函数值对应的模态分量进行包络解调分析,进而通过模态分量的包络谱判断轴承故障类型.通过实测故障信号分析表明,该方法能够从噪声干扰中有效提取到早期故障信号的微弱故障特征,实现了轴承故障类型的准确判定,验证了该方法的有效性.

2 仿真代码

function SSA_VMD(varargin)

   SearchAgents_no = cell2mat(varargin(1));

   Max_iteration = cell2mat(varargin(2));

   dim = cell2mat(varargin(3));

   lb = cell2mat(varargin(4));

   ub = cell2mat(varargin(5));

   try

       imf_write = cell2mat(varargin(6));

   catch

       imf_write = 0;

   end

   t = evalin('base', 't');

   s = evalin('base', 's');

   fs = evalin('base', 'fs');

   ST = 0.6;

   PD = 0.7;

   SD = 0.2;

   PDNumber = round(SearchAgents_no * PD);

   SDNumber = round(SearchAgents_no - SearchAgents_no * SD);

   if (max(size(ub)) == 1)

       ub = ub .* ones(1, dim);

       lb = lb .* ones(1, dim);

   end

   X0 = initialization(SearchAgents_no, dim, ub, lb);

   X = X0;

   fitness = zeros(1, SearchAgents_no);

   for i = 1:SearchAgents_no

       fitness(i) = fun(X(i, :), s);

   end

   [fitness, index] = sort(fitness);

   BestF = fitness(1);

   WorstF = fitness(end);

   GBestF = fitness(1);

   for i = 1:SearchAgents_no

       X(i, :) = X0(index(i), :);

   end

   Convergence_curve = zeros(Max_iteration, 1);

   GBestX = X(1, :);

   X_new = X;

   gbest_array = zeros(Max_iteration, 2);

   for i = 1:Max_iteration

       BestF = fitness(1);

       WorstF = fitness(end);

       R2 = rand(1);

       for j = 1:PDNumber

           if (R2 < ST)

               X_new(j, :) = X(j, :) .* exp(- j / (rand(1) * Max_iteration));

           else

               X_new(j, :) = X(j, :) + randn() * ones(1, dim);

           end

       end

       for j = PDNumber + 1:SearchAgents_no

           if (j > (SearchAgents_no - PDNumber) / 2 + PDNumber)

               X_new(j, :) = randn() .* exp((X(end, :) - X(j, :)) / j^2);

           else

               A = ones(1, dim);

               for a = 1:dim

                   if (rand() > 0.5)

                       A(a) =- 1;

                   end

               end

               AA = A' * inv(A * A');

               X_new(j, :) = X(1, :) + abs(X(j, :) - X(1, :)) .* AA';

           end

       end

       Temp = randperm(SearchAgents_no);

       SDchooseIndex = Temp(1:SDNumber);

       for j = 1:SDNumber

           if (fitness(SDchooseIndex(j)) > BestF)

               X_new(SDchooseIndex(j), :) = X(1, :) + randn() .* abs(X(SDchooseIndex(j), :) - X(1, :));

           elseif (fitness(SDchooseIndex(j)) == BestF)

               K = 2 * rand() - 1;

               X_new(SDchooseIndex(j), :) = X(SDchooseIndex(j), :) + K .* (abs(X(SDchooseIndex(j), :) - X(end, :)) ./ (fitness(SDchooseIndex(j)) - fitness(end) + 10^ - 8));

           end

       end

       for j = 1:SearchAgents_no

           for a = 1:dim

               if (X_new(j, a) > ub(a))

                   X_new(j, a) = ub(a);

               end

               if (X_new(j, a) < lb(a))

                   X_new(j, a) = lb(a);

               end

           end

       end

       for j = 1:SearchAgents_no

           fitness_new(j) = fun(X_new(j, :), s);

       end

       for j = 1:SearchAgents_no

           if (fitness_new(j) < GBestF)

               GBestF = fitness_new(j);

               GBestX = X_new(j, :);

           end

       end

       X = X_new;

       fitness = fitness_new;

       [fitness, index] = sort(fitness);

       BestF = fitness(1);

       WorstF = fitness(end);

       for j = 1:SearchAgents_no

           X(j, :) = X(index(j), :);

       end

       disp(['current iteration is: ', num2str(i), ', best fitness is: ', num2str(GBestF)])

       gbest_array(i, :) = GBestX;

       Convergence_curve(i) = GBestF;

   end

   Best_pos = GBestX;

   flag = 1;

   figure(1)

   plot(Convergence_curve, 'k-.o', 'linewidth', 1)

   legend('最佳适应度')

   grid on

   xlabel('进化代数')

   ylabel('包络熵')

   title('SSA进化曲线')

   figure(2)

   plot(gbest_array(:, 1), 'ks-.', 'linewidth', 1)

   grid on

   xlabel('进化代数')

   ylabel('惩罚因子')

   title('惩罚因子的优化过程曲线')

   figure(3)

   plot(round(gbest_array(:, 2)), 'kv-.', 'linewidth', 1)

   grid on

   xlabel('进化代数')

   ylabel('分解的模态数')

   title('分解模态数的优化过程曲线')

   alpha = Best_pos(1);

   K = round(Best_pos(2));

   tau = 0;

   DC = 0;

   init = 1;

   tol = 1e-7;

   [u, u_hat, omega] = VMD(s, alpha, tau, K, DC, init, tol);

   [m, ~] = size(u);

   m = m + 1;

   figure(4)

   for i = 1:m - 1

       subplot(m, 1, i)

       plot(t, u(i, :), 'b-', 'linewidth', 1)

       ylabel(['IMF', num2str(i)]);

   end

   res = s' - sum(u, 1);

   subplot(m, 1, m)

   plot(t, res, 'b-', 'linewidth', 1)

   ylabel('Res');

   xlabel('t/s')

   figure(5)

   for i = 1:m - 1

       subplot(m, 1, i)

       [cc, y_f] = plot_fft(u(i, :), fs, 1);

       plot(y_f, cc, 'b', 'LineWIdth', 1);

       ylabel(['FFT of IMF', num2str(i)]);

   end

   subplot(m, 1, m)

   [cc, y_f] = plot_fft(res, fs, 1);

   plot(y_f, cc, 'b', 'LineWIdth', 1);

   ylabel('FFT of Res');

   xlabel('f/Hz')

   fig_text(flag)

%     figure(6)

%    

%     imshow(a. personal_id);

%     title( 'Color', 'red', 'FontSize', 16,...

%     'HorizontalAlignment', 'center',...

%     'Interpreter', 'none')

%

%     fprintf_result(Best_pos, s);

%

%     if imf_write == 1

%         xlswrite('imf结果.xlsx', u', 'u', 'A1');

%         xlswrite('imf结果.xlsx', u_hat, 'uhat', 'A1');

%         xlswrite('imf结果.xlsx', omega, 'omega', 'A1');

%     end

3 运行结果

image.gif编辑

4 参考文献

[1]胡鸿志, 覃畅, 管芳,等. 基于麻雀搜索算法优化支持向量机的刀具磨损识别[J]. 科学技术与工程, 2021, 21(25):7.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

部分理论引用网络文献,若有侵权联系博主删除。

5 往期回顾扫扫下方二维码


相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
7天前
|
存储 算法
基于HMM隐马尔可夫模型的金融数据预测算法matlab仿真
本项目基于HMM模型实现金融数据预测,包括模型训练与预测两部分。在MATLAB2022A上运行,通过计算状态转移和观测概率预测未来值,并绘制了预测值、真实值及预测误差的对比图。HMM模型适用于金融市场的时间序列分析,能够有效捕捉隐藏状态及其转换规律,为金融预测提供有力工具。
|
7天前
|
机器学习/深度学习 算法 信息无障碍
基于GoogleNet深度学习网络的手语识别算法matlab仿真
本项目展示了基于GoogleNet的深度学习手语识别算法,使用Matlab2022a实现。通过卷积神经网络(CNN)识别手语手势,如&quot;How are you&quot;、&quot;I am fine&quot;、&quot;I love you&quot;等。核心在于Inception模块,通过多尺度处理和1x1卷积减少计算量,提高效率。项目附带完整代码及操作视频。
|
12天前
|
算法
基于WOA鲸鱼优化的购售电收益与风险评估算法matlab仿真
本研究提出了一种基于鲸鱼优化算法(WOA)的购售电收益与风险评估算法。通过将售电公司购售电收益风险计算公式作为WOA的目标函数,经过迭代优化计算出最优购电策略。实验结果表明,在迭代次数超过10次后,风险价值收益优化值达到1715.1万元的最大值。WOA还确定了中长期市场、现货市场及可再生能源等不同市场的最优购电量,验证了算法的有效性。核心程序使用MATLAB2022a实现,通过多次迭代优化,实现了售电公司收益最大化和风险最小化的目标。
|
12天前
|
算法
通过matlab对比遗传算法优化前后染色体的变化情况
该程序使用MATLAB2022A实现遗传算法优化染色体的过程,通过迭代选择、交叉和变异操作,提高染色体适应度,优化解的质量,同时保持种群多样性,避免局部最优。代码展示了算法的核心流程,包括适应度计算、选择、交叉、变异等步骤,并通过图表直观展示了优化前后染色体的变化情况。
|
10天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于深度学习网络的宝石类型识别算法matlab仿真
本项目利用GoogLeNet深度学习网络进行宝石类型识别,实验包括收集多类宝石图像数据集并按7:1:2比例划分。使用Matlab2022a实现算法,提供含中文注释的完整代码及操作视频。GoogLeNet通过其独特的Inception模块,结合数据增强、学习率调整和正则化等优化手段,有效提升了宝石识别的准确性和效率。
|
4月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
216 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
4月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
139 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
4月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
105 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
7月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)