Matlab中实现智能优化算法的平均排序图

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)

结果如下图所示:

相关推荐
代码中の快捷键5 分钟前
java开发面试有2年经验
java·开发语言·面试
Marzlam5 分钟前
sql server索引优化语句
开发语言·数据库
谢家小布柔10 分钟前
Java 中的字符串
java·开发语言
码老白10 分钟前
【老白学 Java】HashSet 应用 - 卡拉 OK(五)
java·开发语言
sjsjs1126 分钟前
【多维DP】力扣3122. 使矩阵满足条件的最少操作次数
算法·leetcode·矩阵
哲学之窗28 分钟前
齐次矩阵包含平移和旋转
线性代数·算法·矩阵
Code out the future35 分钟前
【C++——临时对象,const T&】
开发语言·c++
taoyong00139 分钟前
Java线程核心01-中断线程的理论原理
java·开发语言
一雨方知深秋40 分钟前
智慧商城:封装getters实现动态统计 + 全选反选功能
开发语言·javascript·vue2·foreach·find·every
海威的技术博客42 分钟前
关于JS中的this指向问题
开发语言·javascript·ecmascript