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)

结果如下图所示:

相关推荐
努力学习的小廉几秒前
我爱学算法之—— 递归回溯综合(二)
开发语言·算法
sheji52612 分钟前
JSP基于信息安全的读书网站79f9s--程序+源码+数据库+调试部署+开发环境
java·开发语言·数据库·算法
2301_763472462 分钟前
C++网络编程(Boost.Asio)
开发语言·c++·算法
毕设源码-邱学长3 分钟前
【开题答辩全过程】以 基于Java Web的电子商务网站的用户行为分析与个性化推荐系统为例,包含答辩的问题和答案
java·开发语言
依依yyy7 分钟前
沪深300指数收益率波动性分析与预测——基于ARMA-GARCH模型
人工智能·算法·机器学习
程序员清洒8 分钟前
Flutter for OpenHarmony:Text — 文本显示与样式控制
开发语言·javascript·flutter
摇滚侠18 分钟前
Java项目教程《尚庭公寓》java项目从开发到部署,技术储备,MybatisPlus、MybatisX
java·开发语言
轩情吖29 分钟前
Qt的窗口
开发语言·c++·qt·窗口·工具栏·桌面级开发
€81130 分钟前
Java入门级教程24——Vert.x的学习
java·开发语言·学习·thymeleaf·数据库操作·vert.x的路由处理机制·datadex实战
hcnaisd240 分钟前
深入理解C++内存模型
开发语言·c++·算法