当前位置: 首页 > article >正文

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

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

平均排序图作用参考:秦兴宝,叶春明.嵌入蝴蝶算法及多策略融合的蜣螂优化器及应用[J/OL].计算机工程与应用.
在这篇文章中,提到了关于算法排序的问题,原文描述为:
“为对比分析改进算法的寻优能力,对各算法的平均适应度结果进行排序,若相等则比较标准差。若均值与标 准差均相等则并列排名。算法的平均性能排序结果越小,代表算法的优化能力越优越,寻优性能越好”

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

以下是对上述函数的调用代码:

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)

结果如下图所示:
在这里插入图片描述


http://www.kler.cn/news/365698.html

相关文章:

  • vue计算属性报错:Computed property “energyTotal“ was assigned to but it has no setter.
  • Helper types and functions (libevent
  • volatile 关键字的作用学习
  • SQL实战测试
  • 【Android】JNI报错 non-zero capacity for nullptr pointer分析
  • 【GISBox使用指南】免费实现影像切片的工具,还支持多种格式服务发布!
  • Redis对象共享池,性能优化小细节
  • 设计模式(七)桥接模式详解
  • Linux之实战命令53:mtr应用实例(八十七)
  • 将获取的数据存储到Excel文件中
  • 动态规划之子数组系列(下)
  • 分行或者分列计算数组中各元素的累积numpy.cumproduct()
  • vue中标签的ref和id的用法和区别优缺点
  • UE5蓝图中忽略触发区域进行碰撞
  • 【Java】输入十个整数,从小到大输出
  • ATom:2016-2018 年来自 CAPS 仪器的云和粗气溶胶测量数据
  • 【C++篇】栈的层叠与队列的流动:在 STL 的韵律中探寻数据结构的优雅之舞
  • 深度学习技术演进:从 CNN、RNN 到 Transformer 的发展与原理解析
  • input标签v-model属性失效
  • softmax回归从零实现
  • 怎么压缩ppt大小?压缩PPT文件非常简单的几种方法
  • Python 语法与数据类型详解
  • 易泊车牌识别相机在智慧工地的应用
  • 中间件之Seata
  • 中小企业设备管理效率提升:Spring Boot系统设计
  • 铜业机器人剥片 - SNK施努卡