本文主要是介绍蜣螂优化算法(DBO)优化VMD参数,最小包络熵、样本熵、信息熵、排列熵(适应度函数可自行选择,一键修改)包含MATLAB源代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
蜣螂优化算法是华大学沈波教授团队,继麻雀搜索算法(Sparrow Search Algorithm,SSA)之后,于2022年11月27日又提出的一种全新的群体智能优化算法。已有很多学者将算法用于实际工程问题中,今天咱们用蜣螂优化算法优化一下VMD参数。
同样以西储大学数据集为例,选用105.mat中的X105_BA_time.mat数据中1000个数据点。没有数据的看我这篇文章。西储大学轴承数据处理--附MATLAB代码_西储大学轴承数据matlab分析_今天吃饺子的博客-CSDN博客
本文选取四种适应度函数进行优化,以此确定VMD的最佳k和α参数。四种适应度函数分别是:最小包络熵,最小样本熵,最小信息熵,最小排列熵。
1.最小包络熵作为适应度函数
2.最小样本熵作为适应度函数
3.最小信息熵作为适应度函数
4.最小排列熵作为适应度函数
代码:
%% 以最小包络熵、最小样本熵、最小信息熵、最小排列熵为目标函数(任选其一),采用DBO算法优化VMD,求取VMD最佳的两个参数
clear all
clc
close all
xz = 1; %xz=1,2,3 or 4, %选择1,以最小包络熵为适应度函数;%选择2,以最小样本熵为适应度函数;%选择3,以最小信息熵为适应度函数;选择4,以最小排列熵为适应度函数。
if xz == 1 fobj=@EnvelopeEntropyCost; %最小包络熵
elseif xz == 2fobj=@SampleEntropyCost; %最小样本熵
elseif xz == 3fobj=@infoEntropyCost; %最小信息熵
elseif xz == 4fobj=@PermutationEntropyCost; %最小排列熵
end%% 选取数据
load 105.mat
da = X105_DE_time(6001:8000); %这里选取105的DEtime数据,注意这里替换为自己的数据即可,数据形式为n行*1列,列数必须为1。%% 设置参数
lb = [100 3]; %惩罚因子和K的下限
ub = [2500 10]; %惩罚因子和K的上限
dim = 2; % 优化变量数目
Max_iter=20; % 最大迭代数目
SearchAgents_no=25; % 种群规模%% 调用DBO函数
[fMin , bestX, Convergence_curve ] = DBO(SearchAgents_no,Max_iter,lb,ub,dim,fobj,da);%% 画适应度函数曲线图,并输出最佳参数
figure
plot(Convergence_curve,'Color',[0.9 0.5 0.1],'Marker','>','LineStyle','--','linewidth',1);
title('Objective space')
xlabel('Iteration');
ylabel('Best score obtained so far');
legend('DBO优化VMD')
display(['The best solution obtained by DBO is : ', num2str(round(bestX))]); %输出最佳位置
display(['The best optimal value of the objective funciton found by DBO is : ', num2str(fMin)]); %输出最佳适应度值
大家注意看到xz这个变量,当选择1,以最小包络熵为适应度函数,选择2,以最小样本熵为适应度函数,选择3,以最小信息熵为适应度函数,选择4,以最小排列熵为适应度函数。这样大家切换起来就很方便了。
完整代码获取,电机下方卡片回复关键词:DBOVMD
觉着不错的给博主留个小赞吧!您的一个小赞就是博主更新的动力,谢谢!
这篇关于蜣螂优化算法(DBO)优化VMD参数,最小包络熵、样本熵、信息熵、排列熵(适应度函数可自行选择,一键修改)包含MATLAB源代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!