演化算法:乌鸦搜索算法 (Crow Search Algorithm)
前言
如果你对这篇文章感兴趣,可以点击「【访客必读 - 指引页】一文囊括主页内所有高质量博客」,查看完整博客分类与对应链接。
在机器学习中,我们所要优化的问题很多时候难以求导,因此通常会采用一些演化算法(又称零阶优化 / 黑盒优化)来近似求解。
这些演化算法通常是根据一些生物的行为置顶,有如下分类:

本文所要介绍的乌鸦搜索算法 (CSA) 就是其中的一种,属于演化算法。
乌鸦搜索算法
乌鸦搜索算法受乌鸦的行为所启发,即在乌鸦种群中,每只乌鸦都在干三件事:
- 寻找藏食物的地点;
- 想要发现其它乌鸦藏食物的地点;
- 不想被其它乌鸦发现自己藏食物的地点。
每只乌鸦 iii 在每一轮会选择一只乌鸦 jjj 进行跟踪,此时有两种情况:
- 乌鸦 jjj 未发现乌鸦 iii,则乌鸦 iii 向乌鸦 jjj 藏食物的地点前进;
- 乌鸦 jjj 发现了乌鸦 iii,决定进行误导,即乌鸦 iii 的位置变成随机位置。
为进一步说明上述过程,定义如下符号:
- 向量 xitx_i^{t}xit 表示第 iii 只乌鸦第 ttt 轮的位置;
- memitmem_i^tmemit 表示第 iii 只乌鸦第 ttt 轮的历史最优解;
- APitAP_i^tAPit 表示第 iii 只乌鸦第 ttt 轮的警觉概率;
- flitfl_i^tflit 表示第 iii 只乌鸦第 ttt 轮的跟随步长;
- rir_iri 表示第 iii 只乌鸦的随机概率,范围在 (0,1)(0,1)(0,1) 之间。
将 xitx_i^{t}xit 理解为第 ttt 轮搜索到的位置,memitmem_i^tmemit 即为到第 ttt 轮时的历史最优解。具体迭代过程如下:
- 一共有 tMAXt_{MAX}tMAX 轮迭代,NNN 只乌鸦;
- 每一轮迭代,遍历每一只乌鸦;
- 当遍历到第 iii 只乌鸦时,随机选择第 jjj 只乌鸦进行跟踪;
- 如果 rj≥APjtr_j\geq AP_j^trj≥APjt,即乌鸦 jjj 未发现,则乌鸦 iii 进行如下更新:
xit+1=xit+ri⋅flit⋅(memjt−xit),x_i^{t+1}=x_i^t+r_i\cdot fl_i^t \cdot (mem_j^t-x_i^t), xit+1=xit+ri⋅flit⋅(memjt−xit), - 如果 rj<APjtr_j<AP_j^trj<APjt,则 xit+1x_i^{t+1}xit+1 变为随机值;
- 如果 rj≥APjtr_j\geq AP_j^trj≥APjt,即乌鸦 jjj 未发现,则乌鸦 iii 进行如下更新:
- 每一轮迭代结束后,遍历每一只乌鸦,若 f(xit+1)>f(memit)f(x_i^{t+1})>f(mem_i^t)f(xit+1)>f(memit),则更新 memit+1=xit+1mem_i^{t+1}=x_i^{t+1}memit+1=xit+1,否则不更新,即 memit+1=memitmem_i^{t+1}=mem_i^{t}memit+1=memit。
完整算法如下:

参考资料
- Learn Crow Search Algorithm Step-by-Step with Example
- [ESWA22 - Behrouz Samieiyan] Novel optimized crow search algorithm for feature selection
相关文章:
演化算法:乌鸦搜索算法 (Crow Search Algorithm)
前言 如果你对这篇文章感兴趣,可以点击「【访客必读 - 指引页】一文囊括主页内所有高质量博客」,查看完整博客分类与对应链接。 在机器学习中,我们所要优化的问题很多时候难以求导,因此通常会采用一些演化算法(又称零…...
基于open62541的OPC UA服务器和客户端开发技术
一、OPC UA的基本概念 1、OPC(OLE for Process Control),是一个工业标准,管理这个标准的国际组织是OPC基金会; 2、OPC通信结构:是指包含一个或多个OPC客户端与服务器相互通信的集合。以下是一个简单的流程图:标准的C/S结构。 3、OPC服务器:TOPC基金会定义了四种;...
测试测开面试要知道的那些事01
列表与元组的区别列表是动态数组,它们可变且可以重设长度(改变其内部元素的个数)。元组是静态数组,它们不可变,且其内部数据一旦创建便无法改变。元组缓存于Python运行时环境,这意味着我们每次使用元组时无…...
物联网毕设 -- 智能厨房监测系统(改)
前言 在家庭生活中,厨房是必不可少的,所以厨房的安全问题关乎着我们大家的生命,所以提出智能厨房监测系统,目的就是为我们减少不必要的安全问题 ⚠️⚠️(本文章仅提供思路和实现方法,并不包含代码&#x…...
macOS 13.3 Beta 3 (22E5236f)发布
系统介绍3 月 8 日消息,苹果今日向 Mac 电脑用户推送了 macOS 13.3 开发者预览版 Beta 3 更新(内部版本号:22E5236f),本次更新距离上次发布隔了 7 天。macOS Ventura 带来了台前调度、连续互通相机、FaceTime 通话接力…...
Failed to configure a DataSource: ‘url‘ attribute
一 完整的错误信息 *************************** APPLICATION FAILED TO START *************************** Description: Failed to configure a DataSource: url attribute is not specified and no embedded datasource could be configured. Reason: Failed to dete…...
Mysql高级——锁
锁 mysql锁的分类 从性能上分为:乐观锁、悲观锁从锁的粒度上分:行锁、间隙锁、页锁、悲观锁从对数据库的操作分类:读锁、写锁 乐观锁需要我们自己通过version字段来实现,如果更新失败则在代码中进行where重试。而我们常见的读锁…...
Spring的Async注解线程池扩展方案
目录- [Spring的Async注解线程池扩展方案]- [目录]- [1. 扩展目的]- [2. 扩展实现]- [2.1 扩展Async注解的执行拦截器AnnotationAsyncExecutionInterceptor]- [2.2 扩展Async注解的Spring代理顾问AsyncAnnotationAdvisor]- [2.3 扩展Async注解的 Spring Bean 后置处理器AsyncAn…...
wfb-ng 锁定WiFi接口
wfb-ng 锁定WiFi接口1. 源由2. 需求3. 分析4. 步骤4.1 确认网卡MAC地址4.2 修改udev配置文件4.3 配置重载&重启4.4 确认逻辑网卡接口4.6 修改wfb-ng逻辑WiFi通信接口5. 参考资料6. 补充资料为了更加方便的调试和使用wfb-ng软件,解决由于设备枚举发现时命名可能存…...
Python所有方向的入门和进阶路线,20年老师傅告诉你方法
干了20多年程序员,对于Python研究一直没停过,这几天把我自己对Python的认知和经验,再结合很多招聘网站上的技术要求,整理出了Python所有方向的学习路线图,基本上各个方向应该学什么,都在上面了,…...
RLOAM/RO-LOAM
LOAM框架 LOAM框架包含三个步骤: Scan registration:从原始激光扫描点数据中提取点特征。点特征是角点或者面点。 odometry estimation:在特征提取之后,特征点传递到里程计模块,通过特征匹配和优化步骤计算相对坐标变…...
JUC并发编程之Semaphore-应用与深度源码剖析
目录 JUC并发编程之Semaphore-应用与深度源码剖析 1. Semaphore 是什么? 2.怎么使用Semaphore? 2.1构造方法 2.2 重要方法 2.3 基本使用 需求场景 基础版代码实现 tryAcquire()引入代码实现 acquireUninterruptibly(),acquire()对比代码实现 3.…...
JWT详细介绍使用
一、JWT介绍 JWT是JSON Web Token的缩写,即JSON Web令牌,是一种自包含令牌。 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准。 JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务…...
C/C++开发,无可避免的多线程(篇六).线程池封装类
一、线程池概念 线程池是一种多线程处理方式,它包含一个线程工作队列和一个任务队列。当有任务需要处理时,线程池会从线程工作队列中取出一个空闲线程来处理任务,如果线程工作队列中没有空闲线程,则任务会被放入任务队列中等待处理…...
HIVE中如何实现针对IPv6 CIDR的查询
Hive默认情况下不支持IPv6 CIDR查询,因为IPv6 CIDR查询需要使用一些额外的函数。 但是可以通过使用UDF(用户自定义函数)来实现这一点。 IPv6 CIDR表示为网络地址/前缀长度,其中网络地址是一个IPv6地址,前缀长度是一个介于0和128之间的整数,表示网络地址中前多少位是网络…...
【微信小程序】-- 生命周期(二十八)
💌 所属专栏:【微信小程序开发教程】 😀 作 者:我是夜阑的狗🐶 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询! &…...
Kafka 概述
Kafka 概述Broker消费者Kafka 属于分布式的消息引擎系统,主要功能 :提供一套完备的消息发布与订阅解决方案 生产者和消费者都是客户端(Clients): 生产者(Producer):向主题发布消息…...
详解Java8中如何通过方法引用获取属性名/::的使用
在我们开发过程中常常有一个需求,就是要知道实体类中Getter方法对应的属性名称(Field Name),例如实体类属性到数据库字段的映射,我们常常是硬编码指定 属性名,这种硬编码有两个缺点。 1、编码效率低&#x…...
0106广度优先搜索和最短路径-无向图-数据结构和算法(Java)
1 单点最短路径 单点最短路径。 给定一幅图和一个起点s,回答“从s到给定目的顶点v是否存在一条路径?如果有,找出其中最短的那条(所含边数最少)。“等类似问题。 深度优先搜索在这个问题上没有什么作为,因为…...
僵尸(Zombie)进程
文章目录1.僵尸进程2.产生僵尸进程的原因3.利用 wait 函数销毁僵尸进程4.使用 waitpid 函数销毁僵尸进程1.僵尸进程 进程完成工作后(执行完 main 函数中的程序后)应被销毁,但有时这些进程将变成僵尸进程,占用系统中的重要资源。这…...
揭秘大模型上线即崩真相:SITS 2026首席架构师亲授3类隐性推理延迟根因及实时熔断方案
更多请点击: https://intelliparadigm.com 第一章:AI原生LLMOps:SITS 2026大模型运维专项技术分享 AI原生LLMOps 正在重塑大模型交付生命周期——它不再将模型训练、评估、部署与监控视为线性阶段,而是以模型为一等公民ÿ…...
别再只会用strlen了!CAPL脚本字符串处理实战:从CAN报文解析到日志格式化
CAPL脚本字符串处理实战:从CAN报文解析到日志格式化 在汽车电子测试领域,CAPL脚本是Vector工具链(如CANoe/CANalyzer)中不可或缺的组成部分。字符串处理作为基础却关键的操作,直接影响着测试脚本的效率和可靠性。本文将…...
OBS多路推流插件:突破单一平台限制,实现多平台直播同步的技术方案
OBS多路推流插件:突破单一平台限制,实现多平台直播同步的技术方案 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp 在直播行业快速发展的今天,内容创作…...
将Hermes Agent自定义提供商指向Taotoken的配置指南
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 将Hermes Agent自定义提供商指向Taotoken的配置指南 Hermes Agent 是一款功能强大的 AI 智能体开发框架,它支持通过自定…...
别再只盯着机械雷达了!聊聊MEMS、相控阵这些固态激光雷达到底强在哪
固态激光雷达技术革命:MEMS与相控阵如何重塑自动驾驶感知格局 当Waymo第五代自动驾驶系统将MEMS激光雷达成本压缩至7500美元时,行业终于意识到固态化浪潮已不可逆转。传统机械式激光雷达的旋转部件正如内燃机之于电动车,正在经历一场静默但彻…...
上海AI Lab:真实场景虚拟细胞模型基准评测
摘要 虚拟细胞模型旨在通过计算预测细胞对各类扰动的响应,已成为药物研发与精准医疗的前沿手段。但当前研究存在明显缺口:各类模型在标准基准测试中表现优异,但其预测结果在实际应用中的生物学意义尚不明确。这主要源于现有评估方案的缺陷——评估设置过度简化、流程不统一…...
别再只会用多边形了!Maya NURBS挤出命令的三种玩法,轻松搞定复杂曲面建模
解锁Maya NURBS挤出命令的隐藏潜力:从基础到高阶的曲面建模实战 在三维建模领域,NURBS(非均匀有理B样条)技术一直是创建精确曲面的黄金标准。许多设计师在掌握了多边形建模后,面对NURBS工具时却感到无从下手。实际上&a…...
AI工具搭建自动化视频生成PromptLayer
好的,我们直接切入正题。聊聊PromptLayer。 很多人在用大模型的时候,感觉像是在跟一个天才但记性很差的同事合作。你告诉他一件事,他做得漂亮,但第二天你忘了当初具体是怎么说的,只能重新摸索。PromptLayer就是为了解决…...
基于Python与arXiv API构建自动化论文订阅与管理工作流
1. 项目概述:当学术论文遇上自动化工作流如果你是一名研究生、科研人员,或者像我一样,需要持续跟踪某个领域的最新学术进展,那你一定对arXiv这个预印本服务器不陌生。每天,成千上万篇论文被上传,涵盖了从计…...
llm.energy:为AI智能体精准提取文档的引擎,告别爬虫噪音
1. 项目概述:为AI智能体“供能”的文档提取引擎 如果你正在构建AI智能体、自动化工作流,或者只是想让Claude、Cursor这类AI助手更好地理解和使用某个项目的文档,那你一定遇到过这样的困境:文档散落在各个角落,格式五花…...
