混合模拟退火和教与学的鸽群优化算法-附代码

2023-10-28 10:59

本文主要是介绍混合模拟退火和教与学的鸽群优化算法-附代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

混合模拟退火和教与学的鸽群优化算法

文章目录

  • 混合模拟退火和教与学的鸽群优化算法
    • 1.鸽群算法
    • 2.改进鸽群优化算法
      • 2.1 模拟退火鸽群优化算法
      • 2.2 线性递减的惯性权重和速度更新
      • 2.3 教与学优化算法
    • 3.实验结果
    • 4.参考文献
    • 5.Matlab代码
    • 6.python代码

摘要:为了改善鸽群优化算法(PIO)容易陷入局部最优和解精度较低的特点,提出一种混合模拟退火和教与学的鸽群优化算法。首先,将鸽群优化算法和模拟退火相结合,可以利用模拟退火跳出局部最优,得到较为精确的解。然后,在鸽群优化算法的速度更新公式中加入惯性权重,并采用线性递减的策略,与教与学算法相结合,增加种群的多样性。

1.鸽群算法

基础鸽群算法的具体原理参考,我的博客:https://blog.csdn.net/u011835903/article/details/109774886

2.改进鸽群优化算法

2.1 模拟退火鸽群优化算法

模拟退火 [ 4 ] { }^{[4]} [4] 是模拟物体从高温降为低温的过程, 根据 Metropolis 准则, 由于降温操作, 物体从状态 i \mathrm{i} i 变为状态 j \mathrm{j} j, 能 量也从 E ( i ) E(i) E(i) 变为 E ( j ) E(j) E(j), 能量的变化量为 Δ E = E ( i ) − E ( j ) \Delta E=E(i)-E(j) ΔE=E(i)E(j), 当 Δ E > 0 \Delta E>0 ΔE>0, 接受变化的新状态; 当 Δ E < 0 \Delta E<0 ΔE<0, 以一定的概率接 受当前的新状态。当概率 p = exp ⁡ ( E ( i ) − E ( j ) / T ) > p=\exp (E(i)-E(j) / T)> p=exp(E(i)E(j)/T)> rand 时, 接受 当前的新状态, 否则保留旧的状态。其中, T = T ⋅ \mathrm{T}=\mathrm{T} \cdot T=T decayscale, decayscale 为退火系数。
模拟退火鸽群优化算法(SAPIO ) 是以鸽群优化算法为主 流程, 加人了模拟退火机制, 对每个鸽子的位置进行局部寻优, 使算法在接受较优解的同时, 以一定的概率接受较差解, 能够 使算法跳出局部最优。随着物体的降温, 能量逐渐趋于稳定状 态,算法达到全局最优。

2.2 线性递减的惯性权重和速度更新

在鸽群优化算法中, 前期需要较大的速度, 有利于全局搜 索, 能较快地定位最优解的大致位置。随着惯性权重的减小, 速度减小, 能够进行精细的局部搜索和得到更精确的解, 该方 法加快了算法的收敛速度, 提高了算法性能 [ 5 ] { }^{[5]} [5] 。惯性权重的调 节和速度公式如下:
w = w start  − w start  − w end  T 1 × t (6) w=w_{\text {start }}-\frac{w_{\text {start }}-w_{\text {end }}}{T 1} \times t \tag{6} w=wstart T1wstart wend ×t(6)

v i t = w ∗ v i t − 1 ⋅ e − R t + rand ⁡ ⋅ ( x gbest  − x i t − 1 ) (7) \begin{gathered} v_i^t=w * v_i^{t-1} \cdot e^{-R t}+\operatorname{rand} \cdot\left(x_{\text {gbest }}-x_i^{t-1}\right) \end{gathered}\tag{7} vit=wvit1eRt+rand(xgbest xit1)(7)

2.3 教与学优化算法

教与学优化算法(TLBO) [6] 包括教师阶段和学习阶段。在教师阶段,选择种群中最好的个体作为教师,通过教行为提高学生的平均成绩。设 x teacher  x_{\text {teacher }} xteacher  是教师, α \alpha α 是学习因子, 且 α = \alpha= α= round ( 1 + (1+ (1+ rand ( 0 , 1 ) ) , x mean  (0,1)), x_{\text {mean }} (0,1)),xmean  种群内所有个体的平均值。教 师阶段的更新公式如下:
x i t = x i t − 1 + rand ⁡ ( 0 , 1 ) × ( x teacher  − α × x mean  ) (8) x_i^t=x_i^{t-1}+\operatorname{rand}(0,1) \times\left(x_{\text {teacher }}-\alpha \times x_{\text {mean }}\right) \tag{8} xit=xit1+rand(0,1)×(xteacher α×xmean )(8)
在学习阶段, 从种群中随机选出两个不同的个体 x p x_p xp x q x_q xq, 比较两个个体之间的差异。令 x i x_i xi 向其中优秀的个体进行学习。 学生阶段的更新公式如下:
x i t = { x i t − 1 + rand ⁡ ( 0 , 1 ) × ( x p t − x i t − 1 ) , f ( x p ) < f ( x q ) x i t − 1 + rand ⁡ ( 0 , 1 ) × ( x q t − x i t − 1 ) , f ( x p ) > f ( x q ) (9) x_i^t= \begin{cases}x_i^{t-1}+\operatorname{rand}(0,1) \times\left(x_p^t-x_i^{t-1}\right), & f\left(x_p\right)<f\left(x_q\right) \\ x_i^{t-1}+\operatorname{rand}(0,1) \times\left(x_q^t-x_i^{t-1}\right), & f\left(x_p\right)>f\left(x_q\right)\end{cases} \tag{9} xit={xit1+rand(0,1)×(xptxit1),xit1+rand(0,1)×(xqtxit1),f(xp)<f(xq)f(xp)>f(xq)(9)
TLSAPIO 算法实现

输入: 种群规模 N \mathrm{N} N, 最大迭代次数 T 1 + T 2 \mathrm{T} 1+\mathrm{T} 2 T1+T2
输出:最优个体 x gbest 。  x_{\text {gbest 。 }} xgbest  
Step1: 初始化鸽群算法相关的参数, 包括速度和位置。
Step2: 计算鸽子的适应度值, 找出个体极值 x p x_p xp 和全局极值 x gbest  ∘ x_{\text {gbest } \circ} xgbest 

Step3: 执行地图和指南针算子, 并根据公式(1)和(2) 更新鸽子的速度和位置。

Step4: 当 t > T 1 t>\mathrm{T} 1 t>T1 时, 停止执行地图和指南针算子, 转而去执 行地标算子。否则继续 Step3。

Step5: 执行地标算子, 对鸽子的适应度值进行排序, 适应 度值较低的鸽子执行教与学优化算法, 并根据公式 (7) 、(8) 和(9)更新速度和位置, 同时计算适应度值。

Step6: 当 t > T 2 t>\mathrm{T} 2 t>T2 时, 停止执行地标算子, 输出最后结果。否 则继续 Step5。

Step7: 计算两次位置变化引起的适应度值的变化量 Δ f = f i ( x i ( t + 1 ) ) − f i ( x i ( t ) ) \Delta f=f_i\left(x_i(t+1)\right)-f_i\left(x_i(t)\right) Δf=fi(xi(t+1))fi(xi(t)), 如果 Δ f < 0 \Delta f<0 Δf<0 exp ⁡ ( − Δ f / T ) > \exp (-\Delta f / T)> exp(Δf/T)> rand, 则接受新位置, 否则保留旧位置。
Step8: 执行降温操作, T = T ⋅ \mathrm{T}=\mathrm{T} \cdot T=T decayscale。
Step9: 判断是否满足终止条件, 若满足, 则结束算法, 输 出全局最优值。否则转 Step2。

3.实验结果

请添加图片描述

4.参考文献

[1]未建英,张丽娜,付发.混合模拟退火和教与学的鸽群优化算法[J].科技经济导刊,2019,27(12):153-155.

5.Matlab代码

6.python代码

这篇关于混合模拟退火和教与学的鸽群优化算法-附代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/292743

相关文章

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.