【智能优化算法】基于扇区搜索机制的果蝇优化算法求解单目标优化问题附matlab代码

简介: 【智能优化算法】基于扇区搜索机制的果蝇优化算法求解单目标优化问题附matlab代码

1 简介

针对传统果蝇算法 (FOA)搜索方向不均匀导致算法求解高维问题时收敛稳定性差和收敛精度低的问题,对果蝇算法的搜索机制进行研究,用扇区搜索机制替代传统搜索机制产生新型果蝇算法 (SS-FOA)。分析果蝇群搜索机制对果蝇飞行方向的影响,提出扇区搜索机制;提出再优化概念,将扇区搜索机制用于参考文献中优化算法再优化。对6个经典测试函数的实验结果表明,扇区搜索机制可用于果蝇优化算法再优化,有效提高被优化算法的收敛精度和稳定性。

果蝇算法通过模拟果蝇两种觅食行为寻找全局最优解。嗅觉搜索:果蝇会在空间中捕捉气味并逼近气味源;视 觉搜索:果蝇个体之间相互交流,记录最优位置设为种群坐标,其余果蝇通过视觉搜索向种群坐标靠近。

为了避免因果蝇群搜索不均匀所导致果蝇飞行方向单一的问题,提出一种均匀的果蝇群搜索机制。首先将以种群坐标为中心,搜索步长为半径的虚拟圆划分成多个扇区。再使每个果蝇都沿着属于自己的扇区飞行,每个果蝇的飞行步长都为 [0,L]的随机值,这样使果蝇飞向各个方向的概率相同。果蝇群只会向着味道浓度最大的方向前进,不会受到果蝇群分布不均匀的影响,从而提高算法的稳定性与收敛精度。

2 部分代码

%% FOA封装程序clc;clear allclose all%% 初始化参数maxgen=100; %最大迭代次数sizepop=50;dim=2;L=1;%% 初始化矩阵X_best=zeros(maxgen,dim);Y_best=zeros(maxgen,dim);Smell_best=zeros(1,maxgen);%% 初始化果蝇坐标;X_axis=10*rand(1,dim);Y_axis=10*rand(1,dim);%% 生成果蝇群[Si,X,Y]=gengrate_foa(X_axis,Y_axis,sizepop,dim,L);%% 寻找最优个体[BestSmell,Index]=find_Schaffer(Si);SmellBest=BestSmell;               %SmellBest为全局最优%% 取出最优个体的两个维度的X,Y坐标X_axis=X(Index,:);Y_axis=Y(Index,:);for g=1:maxgen    %% 生成果蝇群    [Si,X,Y]=gengrate_foa(X_axis,Y_axis,sizepop,dim,L);    %% 寻找最优个体    [BestSmell,Index]=find_Schaffer(Si);    if BestSmell<SmellBest        X_axis=X(Index,:);        Y_axis=Y(Index,:);            %更新极值        SmellBest=BestSmell;            end    Smell_best(g)=SmellBest;    X_best(g,:)=X_axis;    Y_best(g,:)=Y_axis;end%% 输出最终值SmellBest%% 绘制图像figure(1)plot(Smell_best,'b');title('最佳个体适应度值变化趋势')xlabel('迭代次数')ylabel('适应度值')img =gcf;  %获取当前画图的句柄print(img, '-dpng', '-r600', './img.png')         %即可得到对应格式和期望dpi的图像

3 仿真结果

4 参考文献

[1]曹珍贯, 李智威, 余俊峰. 扇区搜索机制的果蝇优化算法[J]. 计算机工程与设计, 2019, 40(6):5.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

部分理论引用网络文献,若有侵权联系博主删除。

相关文章
|
13天前
|
算法 数据安全/隐私保护
基于GA遗传算法的悬索桥静载试验车辆最优布载matlab仿真
本程序基于遗传算法(GA)实现悬索桥静载试验车辆最优布载的MATLAB仿真(2022A版)。目标是自动化确定车辆位置,使加载效率ηq满足0.95≤ηq≤1.05且尽量接近1,同时减少车辆数量与布载时间。核心原理通过优化模型平衡最小车辆使用与ηq接近1的目标,并考虑桥梁载荷、车辆间距等约束条件。测试结果展示布载方案的有效性,适用于悬索桥承载能力评估及性能检测场景。
|
13天前
|
算法 机器人 数据安全/隐私保护
基于双向RRT算法的三维空间最优路线规划matlab仿真
本程序基于双向RRT算法实现三维空间最优路径规划,适用于机器人在复杂环境中的路径寻找问题。通过MATLAB 2022A测试运行,结果展示完整且无水印。算法从起点和终点同时构建两棵随机树,利用随机采样、最近节点查找、扩展等步骤,使两棵树相遇以形成路径,显著提高搜索效率。相比单向RRT,双向RRT在高维或障碍物密集场景中表现更优,为机器人技术提供了有效解决方案。
|
13天前
|
算法 JavaScript 数据安全/隐私保护
基于GA遗传优化的最优阈值计算认知异构网络(CHN)能量检测算法matlab仿真
本内容介绍了一种基于GA遗传优化的阈值计算方法在认知异构网络(CHN)中的应用。通过Matlab2022a实现算法,完整代码含中文注释与操作视频。能量检测算法用于感知主用户信号,其性能依赖检测阈值。传统固定阈值方法易受噪声影响,而GA算法通过模拟生物进化,在复杂环境中自动优化阈值,提高频谱感知准确性,增强CHN的通信效率与资源利用率。预览效果无水印,核心程序部分展示,适合研究频谱感知与优化算法的学者参考。
|
5天前
|
机器学习/深度学习 算法 Python
matlab思维进化算法优化BP神经网络
matlab思维进化算法优化BP神经网络
|
9月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
356 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
9月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
219 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
9月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
308 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)

热门文章

最新文章