Matlab中实现智能优化算法的平均排序图
平均排序图作用参考:秦兴宝,叶春明.嵌入蝴蝶算法及多策略融合的蜣螂优化器及应用[J/OL].计算机工程与应用.
在这篇文章中,提到了关于算法排序的问题,原文描述为:
"为对比分析改进算法的寻优能力,对各算法的平均适应度结果进行排序,若相等则比较标准差。若均值与标 准差均相等则并列排名。算法的平均性能排序结果越小,代表算法的优化能力越优越,寻优性能越好"
matlab
function plotAvgRank(alg_rank,alg_name,xlabel_name,ylable_name)
% 这个函数是用于画算法的平均排序图
% 示例数据
% alg_name = {'SSA', 'HHO', 'PSO', 'CSO', 'MPA', 'DE','CSD','ABO'};
% alg_rank = [2.1, 4.5, 3.2, 5.1, 2.9, 3.5, 4.5, 4.2];
% xlabel_name = 'Algorithm';
% ylable_name = 'Average rank';
% 该方法最多支持8种算法的平均排序
figure()
% 绘制条形图
colors = [
1 0 0;
0 0.4470 0.7410;
0 1 0;
0.9290 0.6940 0.1250;
0.4940 0.1840 0.5560;
0.4660 0.6740 0.1880;
0.3010 0.7450 0.9330;
0.6350 0.0780 0.1840;
];
b = bar(alg_rank,0.3,'FaceColor','flat','EdgeColor','flat'); % 1.0表示宽度
for i = 1:numel(alg_rank)
b.CData(i,:) = colors(i,:);
end
xtips1 = b(1).XEndPoints;
ytips1 = b(1).YEndPoints + 0.15;
labels1 = string(b(1).YData);
text(xtips1,ytips1,labels1,'HorizontalAlignment','center','VerticalAlignment','bottom')
hold on;
% 插值点数量(比原数据点多,以生成更平滑的曲线)
num_points = 100;
x = 1:numel(alg_rank);
xq = linspace(min(x), max(x), num_points);
% 使用样条插值
yq = interp1(x, alg_rank, xq, 'spline');
% 绘图
plot(x, alg_rank, 'o', 'MarkerFaceColor', '#D95319'); % 原始数据点
plot(xq, yq, 'LineStyle','-', 'Color','#D95319', 'LineWidth',2); % 插值后的光滑曲线
hold off;
% 设置X轴标签
set(gca, 'XTickLabel', alg_name);
xlabel(xlabel_name);
ylabel(ylable_name);
end
以下是对上述函数的调用代码:
matlab
clear;clc;
alg_name = {'SSA', 'HHO', 'PSO', 'CSO', 'MPA', 'DE'};
alg_rank = round(1+4*rand(1,6),2);
xlabel_name = 'Algorithm';
ylable_name = 'Average rank';
plotAvgRank(alg_rank,alg_name,xlabel_name,ylable_name)
结果如下图所示: