2024最新算法:鹦鹉优化算法(Parrot optimizer,PO)求解23个基准函数(提供MATLAB代码)

一、鹦鹉优化算法

鹦鹉优化算法(Parrot optimizer,PO)由Junbo Lian等人于2024年提出的一种高效的元启发式算法,该算法从驯养的鹦鹉中观察到的觅食、停留、交流和对陌生人行为的恐惧中汲取灵感。这些行为被封装在四个不同的公式中,以促进寻找最佳解决方案。与遵循单独探索和开发阶段的传统元启发式算法相比,PO 群体中的每个个体在每次迭代期间都会随机表现出这四种行为中的一种。这种方法更恰当地表示了在驯化鹦鹉中观察到的行为随机性,并显着增强了种群多样性。通过偏离传统的勘探-开采两阶段结构,PO有效地降低了被困在局部最优值中的风险,同时保持了解决方案的质量。PO的随机结构使其与传统算法区分开来,使其特别适合避免局部最优,并适用于现实世界的问题解决,特别是在医学领域。

参考文献:

1\]Lian, Junbo, et al. "Parrot Optimizer: Algorithm and Applications to Medical Problems." Computers in Biology and Medicine, Elsevier BV, Feb. 2024, p. 108064, doi:10.1016/j.compbiomed.2024.108064. ### 二、23个函数介绍 ![](https://file.jishuzhan.net/article/1764089893417390081/3ea3af6a4cb623b78dd28fe776bae638.webp) 参考文献: \[1\] Yao X, Liu Y, Lin G M. Evolutionary programming made faster\[J\]. IEEE transactions on evolutionary computation, 1999, 3(2):82-102. ### 三、PO求解23个函数 #### 3.1部分代码 ``` close all ; clear clc Npop=30;                 Function_name='F1';     % Name of the test function that can be from F1 to F23 (  Tmax=300;               [lb,ub,dim,fobj]=Get_Functions_details(Function_name); [Best_fit,Best_pos,Convergence_curve]=PO(Npop,Tmax,lb,ub,dim,fobj); figure('Position',[100 100 660 290]) %Draw search space subplot(1,2,1); func_plot(Function_name); title('Parameter space') xlabel('x_1'); ylabel('x_2'); zlabel([Function_name,'( x_1 , x_2 )']) %Draw objective space subplot(1,2,2); semilogy(Convergence_curve,'Color','r','linewidth',3) title('Search space') xlabel('Iteration'); ylabel('Best score obtained so far'); axis tight grid on box on legend('PO') saveas(gca,[Function_name '.jpg']); display(['The best solution is ', num2str(Best_pos)]); display(['The best fitness value is ', num2str(Best_fit)]); ``` #### 3.2部分结果 ![](https://file.jishuzhan.net/article/1764089893417390081/e64bc1055489677bbb2866be2ac5a7cb.webp) ![](https://file.jishuzhan.net/article/1764089893417390081/238f2956223841d06df286912d19a0ae.webp) ![](https://file.jishuzhan.net/article/1764089893417390081/c2823995abf94c4ae55a8564d4510cbb.webp) ![](https://file.jishuzhan.net/article/1764089893417390081/83c254c2524584de8407ef1725dd3830.webp) ![](https://file.jishuzhan.net/article/1764089893417390081/324e82240c542e7449458ebc974eb2c1.webp) ![](https://file.jishuzhan.net/article/1764089893417390081/af15eeaf129cd0026a571b528de3670e.webp) ![](https://file.jishuzhan.net/article/1764089893417390081/5e88160ed9db787d06d4660bb62beb37.webp) ![](https://file.jishuzhan.net/article/1764089893417390081/c188bd05635ee6e5ba294d61c9d75a9e.webp) ### 四、完整MATLAB代码

相关推荐
思麟呀3 小时前
Linux的基础IO流
linux·运维·服务器·开发语言·c++
星释3 小时前
Rust 练习册 :Pythagorean Triplet与数学算法
开发语言·算法·rust
星释3 小时前
Rust 练习册 :Nth Prime与素数算法
开发语言·算法·rust
lkbhua莱克瓦244 小时前
Java基础——集合进阶3
java·开发语言·笔记
多喝开水少熬夜4 小时前
Trie树相关算法题java实现
java·开发语言·算法
QT 小鲜肉4 小时前
【QT/C++】Qt定时器QTimer类的实现方法详解(超详细)
开发语言·数据库·c++·笔记·qt·学习
WBluuue4 小时前
数据结构与算法:树上倍增与LCA
数据结构·c++·算法
lsx2024065 小时前
MySQL WHERE 子句详解
开发语言
bruk_spp5 小时前
牛客网华为在线编程题
算法
Tony Bai5 小时前
【Go模块构建与依赖管理】09 企业级实践:私有仓库与私有 Proxy
开发语言·后端·golang