遗传算法原理,交叉、变异、适应度函数的设置

article/2025/10/16 7:07:30

遗传算法(Genetic Algorithm,GA)由霍兰德教授在20世纪70年代提出,是以自然选择和遗传变异为理论依据的全局性概率搜索优化算法模型。采用遗传算法寻优时需要将问题的候选解进行编码,即一个候选解对应一个编码,编码通常采用二进制,用“0”、“1”表示,为“1”则表示该候选解被选中,所有候选解组合在一起定义为染色体;在迭代进化的过程中,通过构造适应度函数,计算每个个体的适应度,适应度值越大,该个体被保留的可能性越大。

遗传算法主要操作包括选择、交叉、变异。选择是指依据适应度值优胜劣汰的过程;交叉是指两个父代个体的结构按照一定的概率Pc(交叉概率,也称交叉率)相互交换产生新个体的过程;变异是以一个很小的概率Pm(变异概率,也称变异率)随机将个体的基因值从“0”变成“1”或“1”变成“0”的过程. Pc和Pm的大小对于算法的优化效率影响很大,Pc越大表示当前父代的染色体结构复制到下一代的比例较少,与另一个父代染色体结构交换的比例越大,而这样,父代的染色体的结构破坏较大;当Pm较大时,则代表父代染色体的结构在下一次迭代优化时会发生较大概率的突变。因此,为了提高算法的优化效率,在迭代优化的早期,较大的Pc和Pm,在迭代优化后期较小的Pc和Pm有利于算法效率的提高。普通的遗传算法将上述两个概率值设置为固定值,限制了算法的优化效率,而自适应遗传算法(Adaptive Genetic Algorithm)将上述Pc和Pm的值依据适应度值在迭代优化时动态调整,提高了算法的优化效率(下面只列举一种Pc和Pm的自适应算法)。

1:交叉(多点交叉),其他种类的交叉算法详见https://blog.csdn.net/u012750702/article/details/54563515/

2:变异

3:自适应遗传算法的举例(其他的自适应算法读者可搜索文献)

          

             

        式中,fmax代表种群中最佳适应度值;favg代表每代种群的平均适应度值;'代表要交叉的两个个体中较大的适应度值;f代表要变异的个体的适应度值;k1=k2=0.6k3=k4=0.1。                     

     4:适应度函数的设置

适应度函数的设置对于遗传算法的优化系哦啊绿至关重要,而在不同的优化问题中,适应度函数的设置需要根据具体的优化问题而言,就常见的机器学习分类问题而言,fitness=w1×f1+w2×accuracy;其中 w1和w2分别代表权重系数,两者之和为1,f1代表用到的建模变量个数,accuracy代表分类的精度(比如OA,kappa等)。对于机器学习的回归问题,fitness=R^{2}/RMSE.R2表示决定系数,RMSE表示均方根误差(文章 DOI: 10.1080/01431161.2020.1718239.)。对于适应度值得设置,应当尽量放大体间的差异。

5:迭代结束的设置

可以依据适应度值在保持多少代不变或者设定一个阈值,当适应度值相邻两代的差值低于该阈值时,就停止进化迭代,或者设置最大的遗传迭代次数。

6: 遗传算法的具体使用流程

(1).编码、随机产生初始群体;

(2)个体评价、选择、确定是否输出;

(3)随机交叉运算;

(4)随机变异运算;

(5)转向个体评价,开始新循环

 


http://chatgpt.dhexx.cn/article/b5CsSxLm.shtml

相关文章

利用遗传算法GA和粒子群算法PSO优化算法,将BP神经网络训练集的MSE作为适应度函数

利用遗传算法GA和粒子群算法PSO优化算法,将BP神经网络训练集的MSE作为适应度函数,获取最优的权值和阈值在反向输入到BP神经网络里构建回归预测模型,同时能够打印出模型的多个评价指标,具体效果可以看图 ID:3250669194443543Matl…

麻雀算法SSA,优化VMD,适应度函数为最小包络熵,包含MATLAB源代码

针对大家评论区给出的很多问题,作者一直都有关注,因此在这里又写了一篇文章,而且思路与这篇文章有不同之处,至于具体的不同之处放在下一篇文章了,大家感兴趣的可以移步观看,下一篇文章可以说是作者的呕心力…

计算适应度函数(目标函数)(单目标)

适应度函数 function fitness = CacFitNess(Energy,Time,MissError,overSpeed,Jerk) %UNTITLED 计算适应度函数 caculation fitness % 能耗Energy % 时间Time % 舒适度Jerk % 超限速overSpeed % 停车误差MissError global DESINTIME EMAX; y=zeros(1,5);%% 1 能耗 if E…

进化算法——昂贵、有噪声与动态适应度函数

1.昂贵适应度函数 在很多实际问题中,对适应度做一次评价会需要几分钟、几小时、几天甚至更长时间的计算或实验。我们在这里讨论如何减少适应度评价所需的时间以便降低进化算法对计算量的要求。 实际问题涉及的适应度函数常常包含下列的一种或多种特征:…

经典算法研究系列:七、深入浅出遗传算法,透析GA本质

经典算法研究系列:七、遗传算法初探 ---深入浅出、透析GA本质 作者:July 二零一一年一月十二日。 本文参考:维基百科 华南理工大学电子讲义 互联网 ------------------------------------------------------------------------------- 一、初探遗传算法…

适应度函数及遗传操作

本文转载自:http://blog.csdn.net/b2b160/article/details/4680853/ 这篇文章所举的例子非常给力,摘自《遗传算法原理与应用》,至少我是看过之后就明白了很多概念~ 首先,什么是遗传算法? 遗传算法是为那些难以找到传统…

遗传算法(三)——适应度与选择

适应度(fitness) 含义: 个体的适应度(fitness)指的是个体在种群生存的优势程度度量,用于区分个体的“好与坏”。适应度使用适应度函数(fitness function)来进行计算。适应度函数也叫…

遗传算法适应度函数的计算原理

遗传算法: 适应度函数: FitnVranking(ObjV) ranking函数分两步操作: (1)对个体的目标值ObjV进行由小到大的排序 (2)按照排序的值,利用计算公式 其中:Position是第一步…

SQL 分组统计去重有条件的过滤

见字如面,如标题拆分: 分组 GROUP BY field_name统计 COUNT(field_name)去重 DISTINCT field_name条件过滤 CASE WHEN age > 18 THEN age END 示例: 前序: 表结构 CREATE TABLE data_table_name (id int(11) …

mysql sql 分组求和函数_SQL分组函数group by和聚合函数(COUNT、MAX、MIN、AVG、SUM)的几点说明...

1 分组聚合的原因 SQL中分组函数和聚合函数之前的文章已经介绍过,单说这两个函数有可能比较好理解,分组函数就是group by,聚合函数就是COUNT、MAX、MIN、AVG、SUM。 拿上图中的数据进行解释,假设按照product_type这个字段进行分组,分组之后结果如下图。 SELECT product_ty…

SQL分组取最大值的方法

一、业务需求 1.1.数据表展示 1.2.查询要求 要求查询所有字段,并按iceName,orderPath,exceptionType分组,在分组时取systemTime值最大的那条数据 注:本文适用于查询多字段的查询,单纯的 select MAX(字段A) 或select B,MAX(字段…

SQL分组后将不存在的组记为0

说明 最近遇到这么一个需求&#xff1a;统计区间在0-2000,2000-3000,3000-4000,4000-5000,5000工资的人数。 快速开始 数据如下&#xff1a; 开始看到这个问题&#xff0c;想都没想就开始写了下面的代码&#xff1a; SELECT casewhen salary < 2000 then [0, 2000)when …

SQL 分组条件深入剖析

问题 在 stackoverflow 网站上看到这样一个 SQL 分组条件的需求&#xff0c;需求看似挺简单&#xff0c;但能把 SQL 写正确对于新手来说也不容易&#xff0c;我们拿过来深入剖析一下&#xff0c;数据如下&#xff1a; 需求是查找只有Ready 状态的设备。 解答 自然思路&#xff…

SQL分组排序函数(组内分别排序)

建表并插入数据 -- 部门表 create table dept( deptno int primary key auto_increment, -- 部门编号 dname varchar(14) , -- 部门名字 loc varchar(13) -- 地址 ) ; -- 员工表 create table emp( empno int primary key auto_increment,-- 员工编号 …

sql 分组 行列转换

sql 分组 & 行列转换 文章目录 sql 分组 & 行列转换1、groupby&#xff08;配合组合函数使用&#xff09;2、Sql的行列转换 - 纵横表1&#xff09;纵表转横表2&#xff09;横表转纵表 sql语句教程参考W3C School - SQL 教程 就够了 1、groupby&#xff08;配合组合函数…

SQL:分组数据

分组数据&#xff1a; A. SQL Server Group By语句 Group By 从字面意义上理解就是根据“By”指定的规则对数据进行分组&#xff0c;所谓的分组就是将一个“数据集” 划分成若干个“小区域”&#xff0c;然后针对若干个“小区域”进行数据处理。 以下是 GROUP BY 子句的语…

SQL语言中的分组数据

&#xff08;1&#xff09;group by子句 group by 根据by指定的规则对数据进行分组。 分组&#xff1a;即将一个“数据集”划分成若干个“小区域”&#xff0c;再对若干个“小区域”进行数据处理。 语法&#xff1a; group by 子句为列中的每个值组合生成一个组。 group by子…

SQL分组指南

目录 什么是SQL分组&#xff1f; SQL GROUP BY和Sum 排序分组结果 HAVING和GROUP BY 包含多个表的GROUP BY 按SUM()排序 带有表达式的GROUP BY SQL GROUP BY与DISTINCT 结论 什么是SQL分组&#xff1f; 在SQL中&#xff0c;分组是唯一的列值组合。当查询具有GROUP BY…

单例模式的使用和应用场景

1.概念 标题单例模式&#xff1a;单例指的是单实例&#xff0c;一个类中有且仅有创建一个实例 单例模式的应用场景&#xff1a;windows的任务管理器(不可打开两次吧)、回收站等 单例模式应用一般发现在以下条件下&#xff1a; servlet单例、struts2多例、springmvc单例 &…

单例模式实战应用

理论 什么是单例模式 保证整个系统中一个类只有一个对象的实例&#xff0c;实现这种功能的方式就叫单例模式 常用的 service 和 dao 层的对象通常都是单例的&#xff0c;而多例则指每个请求用一个新的对象来处理&#xff0c;比如 action spring 中的 bean 和 spring mvc 中…