遗传算法的python实现(手撕python遗传算法)

article/2025/10/2 0:06:03

遗传算法简介

假设有无约束优化问题:
z = f ( x , y ) z=f(x,y) z=f(x,y)
如何通过遗传算法求解?
在这里需要将该优化问题与遗传算法中的概念进行对比。

  • f f f 对应遗传算法的适应度函数。
  • 自变量 x , y x,y x,y 对应遗传算法的个体,注意,这里的个体实际上就是染色体/基因,也就是说,我们的遗传算法与生物学中的遗传还是有一定区别的,即在我们的算法中,我们不区分个体、染色体、基因,而将此三者认为是同一个概念。
  • 那么如何将自变量 x , y x,y x,y 转换成我们所需要的基因?这就来到了我要介绍的第一个概念——解码和编码。

解码与编码

先来说说编码。
编码实际上就是将自变量编码为基因,以方便后续的遗传模拟过程。本文以二进制编码为例进行讲解。
为了方便模拟染色体,我们将行向量 [ x , y ] [x,y] [x,y]分开进行编码,如对 x , y = [ 13 , 27 ] x,y=[13,27] x,y=[13,27]有:

  • 13的二进制编码为1101
  • 27的二进制编码为11011

可以发现其长度并不相等,但是不要着急,我们可以在其之前补上若干个0,使得二者最终的长度 n n n相等。

那么问题来了, n n n取多少呢?8,16还是32?再或者其他的值?
当然不是随便取,因为:

  1. n n n取得过大,会使得精度表示过高,增加无谓的计算量,导致算法效率低下等问题。
  2. n n n 取得过小,会导致此时所能表示的精度不够,甚至不能覆盖自变量的所有取值范围。这和32位浮点数、64位浮点数之间的区别是一样的。

所以, n n n的取值取决于我们自变量的范围与精度。
举个例子:
对于一个自变量 x ∈ [ − 2 , 2 ] x \in [-2,2] x[2,2],需要精确到小数点后5位,那么该二进制编码的总长度应为多少?
显然,问题转化为:需要一个多长的二进制编码才能表示该区间内所有具有小数点后5的数字?
很显然,该区间内所有具有小数点后5的数字共有 4 × 1 0 5 4 \times10^5 4×105个。
所以,需要找到一个最小的正整数 n n n,使得 2 n ≥ 4 × 1 0 5 2^n\ge 4 \times10^5 2n4×105

for i in range(40):if 2**i>=4e5:print(i)break

解得n=19.


解码就是编码的逆过程,在二进制编码中,实际上就是由二进制转换为十进制的问题,但同时需要注意不能使得解码后的值超出我们规定的自变量的区间:

def decode(x,a,b):"""解码针对染色体的某个变量"""xt=0for i in range(len(x)):xt+=x[i]*np.power(2,i)return a+xt*(b-a)/(np.power(2,len(x))-1)  # a,b是自变量的取值范围

注意,通过上面的函数,我们只对某一条基因进行了解码,实际上我们在算法中,所有个体以及每个个体的基因都是在一个大的矩阵中,取 n = 20 n=20 n=20,自变量 x , y ∈ [ − 5 , 5 ] x,y \in [-5,5] x,y[5,5]为例,对于基因种群解码:

def decode_X(X:np.ndarray):"""对整个种群的基因解码"""X2=np.zeros((X.shape[0],2))for i in range(X.shape[0]):xi=decode(X[i,:20],-5,5)yi=decode(X[i,20:],-5,5)X2[i]=np.array([xi,yi])return X2

选择

物竞天择,适者生存。
不像之前介绍的粒子群算法,在遗传算法中,不合适的个体会被淘汰掉。因此我们要进行模拟选择的过程,我们选择当然要选择适应能力好的个体。(在最小化问题中适应度越小越好)

def select(X,fitness):"""根据轮盘赌法选择优秀个体"""fitness=1/fitness  # fitness越小的个体越优秀,其对应的概率越大,因此需要取一下倒数fitness=fitness/fitness.sum()    # 归一化idx=np.arange(X.shape[0])    # 每个个体的索引X2_idx=np.random.choice(idx,size=X.shape[0],p=fitness)X2=X[X2_idx,:]return X2

注意我们这里还是比较仁慈的,没有淘汰辣鸡个体,这是为了后面的程序好编写。

交叉

显然,这个是模拟自然界中个体与个体之间的交 配操作。

def mutation(X,m):for i in range(0,X.shape[0],2):xa=X[i,:]xb=X[i+1,:]for j in range(X.shape[1]):if np.random.rand()<m:xa[j],xb[j]=xb[j],xa[j]  # 交叉X[i,:]=xaX[i+1,:]=xbreturn X

代码也很简单。

变异

同样,模拟自然界中的变异,这通常会带来意想不到的结果:

def mutation(X,m):for i in range(X.shape[0]):for j in range(X.shape[1]):if np.random.rand()<m:X[i,j]=(X[i,j]+1)%2return X

代码也很简单。

主函数

来到主函数,只需在每次迭代中进行解码,选择,交叉,变异等操作即可,而这些操作我们上面已经定义完毕,所以主函数代码非常简单明了:

def ga(target_func,size,gene_num,p_cross=0.3,p_muta=0.05,iter_num=100):"""遗传算法主函数params:p_cross:交叉操作的概率阈值p_muta:变异操作的概率阈值iter_num:最大迭代次数size:种群中个体的个数gene_num:表示所有自变量所需要的基因位 数量"""c=p_cross  # 交叉概率m=p_muta  # 变异概率best_fitness=[]  # 记录每次迭代的效果best_xy=[]iter_num=100X0=np.random.randint(0,2,(size,gene_num))  # 初始化种群for i in range(iter_num):X1=decode_X(X0)fitness=target_func(X1)  # 初始化适应度X2=select(X0,fitness)  # 选择操作X3=crossover(X2,c)  # 交叉操作X4=mutation(X3,m)  # 变异X5=decode_X(X4)  # 解码fitness=target_func(X5)best_fitness.append(fitness.min())x,y=X5[fitness.argmin()]best_xy.append((x,y))X0=X4  # 最后别忘了更新种群# 多次迭代后的最新效果print("最优val是: ",best_fitness[-1])print("最优解是:\n x=%.5f, y=%.5f"%best_xy[-1])return best_fitness

最后来看一下迭代的过程:

import matplotlib.pyplot as pltfitnessList=ga(fitness_func,50,40)
plt.plot(fitnessList)

在这里插入图片描述
by——神采的二舅


http://chatgpt.dhexx.cn/article/0IWLvdjh.shtml

相关文章

Python 遗传算法 Genetic Algorithm

粒子群算法常常用于在连续解空间内搜索&#xff0c;而在不连续、离散的空间内常常会出现搜索越界的问题 例如旅行商问题&#xff0c;寻找可以遍历 15 个地点的最短路径&#xff08;当然可以用二进制状态压缩 动态规划解决&#xff09;&#xff0c;以 {0, 1, ..., 14} 表示这些…

python遗传算法之geatpy学习

&#x1f63b;今天我们来学习python中的遗传算法的使用&#xff0c;我们这里使用的是geatpy的包进行学习&#xff0c;本博客主要从geatpy中的各种数据结构一步一步进行学习&#xff0c;请大家耐心看完。 &#x1f424;其实以前也学习过遗传算法&#xff0c;但是主要使用matlab…

遗传算法详解 附python代码实现

遗传算法 遗传算法是用于解决最优化问题的一种搜索算法。从名字来看&#xff0c;遗传算法借用了生物学里达尔文的进化理论&#xff1a;”适者生存&#xff0c;不适者淘汰“&#xff0c;将该理论以算法的形式表现出来就是遗传算法的过程。 问题引入 上面提到遗传算法是用来解…

遗传算法【Python】

遗传算法概念 基本思想&#xff1a; 遗传算法(GA)是一种全局寻优搜索算法&#xff0c;它依据的是大自然生物进化过程中“适者生存”的规律。它首先对问题的可行解进行编码&#xff0c;组成染色体&#xff0c;然后通过模拟自然界的进化过程&#xff0c;对初始种群中的染色体进…

遗传算法python实现

遗传算法python实现 一、问题引入二、遗传算法的步骤1.初始化2.个体评价3.选择运算4.交叉运算5.变异运算6.终止条件判断 三、实现思路1.编码的设计2.适应度函数3.选择函数4.交叉函数5.变异函数6.迭代 四、具体实现1.编码解码函数2.适应度函数3.选择函数4.交叉函数5.变异函数6.选…

遗传算法(Python)

一、遗传算法 1、遗传算法的定义 遗传算法是一种现代优化算法。根据自然界适者生存的法则&#xff0c;种群中优秀个体的基因进行遗传。每个个体的染色体通过选择、交叉和变异等过程产生新的适应度更大的染色体&#xff0c;其中适应度越大的个体越优秀&#xff0c;种群得到优化…

python遗传算法(详解)

学习代码来源于&#xff1a;遗传算法python 一.主要思想 遗传算法是根据达尔文的“适者生存&#xff0c;优胜劣汰”的思想来找到最优解的额&#xff0c;其特点是所找到的解是全局最优解&#xff0c;相对于蚁群算法可能出现的局部最优解还是有优势的。 二.主要名词 个体&…

DH算法、DHE算法、ECDHE算法演进

ECDHE 算法解决了 RSA 算法不具备前向安全的性质 和 DH 算法效率低下的问题。 ECDHE 算法具有前向安全。所以被广泛使用。 由什么演变而来 DH 算法 -- > DHE 算法 -- > ECDHE 算法 DH 算法是非对称加密算法&#xff0c;该算法的核心数学思想是离散对数。 核心数学思…

DH 算法思想 SSH解决内容篡改问题

DH算法用于交换密钥 交换密钥的目的是生成仅双方共享的密钥 交换密钥的基本过程&#xff1a; 双方确定公开的内容用各自的私钥分别对公共内容加密&#xff08;加密本质就是数学运算&#xff09;并发送给对方这时双方使用自己的密钥对收到的内容加密&#xff08;要设计运算保证…

ECDH算法详解

ECDH算法详解 ECDH算法详解DH密钥交换原理结合ECC椭圆曲线算法ECDSA签名算法 参考资料 ECDH算法详解 DH密钥交换原理 进一步解释&#xff1a; 两端&#xff08;Alice 和 Bob&#xff09;想要安全的交换信息并且第三方不能获取到该信息。当然这也是TLS协议中的目的之一&#xf…

DH算法(密钥交换算法)

一 对称加密缺点 密钥传递过程复杂&#xff0c;这是对称加密带来的困扰。 二 DH密钥交换算法特点 构建本地密钥 双方密钥一致 三 DH相关参数 四 DH算法实现过程 1、初始化发送方的密钥&#xff08;KeyPairGenerator、KeyPair、PublicKey&#xff09; 2、初始化接受方的密钥&…

SSL/TLS中的DH算法、DHE算法、 ECDHE算法介绍

❤️SSL/TLS专栏导航页❤️ 文章目录 1. DH算法简介2. DH算法协商流程3. DH算法证明4. SSL/TLS中的DH算法 1. DH算法简介 Diffie-Hellman密钥交换算法是在1976年由这两个人发明的算法。它可以在不安全的网络中&#xff0c;通过交换一些公开的信息协商出共享密钥&#xff0c;使…

一文读懂DH密钥交换算法

DH 算法是 Diffie和Hellman于1976年提出了一种的密钥交换协议。这种加密算法主要用于密钥的交换&#xff0c;可以在非安全信道下为双方创建通信密钥&#xff0c;通讯双方可以使用这个密钥进行消息的加密、解密&#xff0c;并且能够保证通讯的安全。 换而言之&#xff0c;算法希…

密钥协商算法的演变 —— RSA算法 - DH算法 - DHE算法 - ECDHE算法

文章目录 1. RSA算法RSA握手过程RSA秘钥协商算法最大的缺陷 2. DH算法3. DHE算法4. ECDHE算法ECDHE秘钥协商算法的TSL握手&#xff1a; 1. RSA算法 传统的 TLS 握⼿基本都是使⽤ RSA 算法来实现密钥交换的。在 RSA 密钥协商算法中&#xff0c;客户端会⽣成随机密钥&#xff0c…

openswan中DH算法说明

Author :Email : vip_13031075266163.comDate : 2021.01.11Copyright : 未经同意不得转载&#xff01;&#xff01;&#xff01;Version &#xff1a; openswan-2.6.51.5Reference&#xff1a;https://download.openswan.org/openswan/ 目录 1. ope…

DH法理解

旋转关节机器人 四个参数&#xff1a;a&#xff0c;α&#xff0c;d&#xff0c;θ 四个参数实际上是两组&#xff0c;先有a&#xff0c;α&#xff0c;再有d&#xff0c;θ。 a是两个转轴之间的距离&#xff08;Z轴&#xff09;&#xff0c;异面直线公垂线的长度&#xff0c;也…

DH算法及源码解读

【主流的密钥交换方式】 敏感数据信息安全传输需要对敏感信息加密&#xff0c;加密的密钥涉及到传输两端的密钥协商和交换&#xff0c;目前主要两种密钥交换的机制有&#xff1a; 1. 基于非对称密钥的实现&#xff1a;请求方用接收方的公钥加密自己的密钥&#xff0c;接收方用…

DH 加密算法的使用

DH 算法的介绍 上面介绍的 DES,3DES,AES 算法都是对称密码算法&#xff0c;所谓对称&#xff0c;在上面也解释了&#xff0c;就是加密和解密的过程中使用相同的密钥 。而现在将要介绍的是 DH 算法&#xff0c;属于非对称密码算法&#xff0c;根据对称密码的概念&#xff0c;很…

非对称加密 DH算法

DH算法简介 迪菲-赫尔曼密钥交换&#xff08;Diffie–Hellman key exchange&#xff0c;缩写为D-H&#xff09; 是一种安全协议。 它可以让双方在完全没有对方任何预先信息的条件下通过不安全信道创建起一个密钥。 这个密钥可以在后续的通讯中作为对称密钥来加密通讯内容。 迪…

DH算法 | Diffie-Hellman 密钥交换

概述&#xff1a; DH 算法又称“Diffie–Hellman 算法”&#xff0c;像往常的算法名字一样&#xff0c;这是用俩个数学牛人的名字来命名的算法&#xff0c;实现安全的密钥交换&#xff0c;通讯双方在完全没有对方任何预先信息的条件下通过不安全信道创建起一个密钥。 优点&am…