iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python遗传算法之geatpy的怎么安装使用
  • 221
分享到

python遗传算法之geatpy的怎么安装使用

2023-06-30 04:06:20 221人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

这篇“python遗传算法之geatpy的怎么安装使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python遗传算法之g

这篇“python遗传算法之geatpy的怎么安装使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python遗传算法之geatpy的怎么安装使用”文章吧。

    1. geatpy的安装

    首先是安装geatpy,使用pip3命令进行安装即可:

    pip3 install geatpy

    出现如下提示即安装成功:

    python遗传算法之geatpy的怎么安装使用

    2. geatpy的基础数据结构

    geatpy中的大部分数据都是都是使用numpy的数组进行存储和计算的,下面我将介绍遗传算法中的概念是如何用numpy数据表示,以及行和列的含义。

    2.1 种群染色体

    遗传算法中最重要的就是个体的染色体表示,在geatpy中种群染色体用Chrom表示,这是一个二维数组,其中每一行对应一个个体的染色体编码,Chrom的结构如下:其中lind表示编码的长度,Nind表示的是种群的规模(个体数量)。

    python遗传算法之geatpy的怎么安装使用

    2.2 种群表现型

    种群表现型是是指种群染色体矩阵Chrom经过解码后得到的基因表现型矩阵Phen,每一行对应一个个体,每一列对应一个决策变量,Phen的结构如下:其中Nvar表示变量的个数

    python遗传算法之geatpy的怎么安装使用

    Phen的值与采用的解码方式有关。Geatpy提供二进制/格雷码编码转十进制整数或实数的解码方式。另外,在Geatpy也可以使用不需要解码的“实值编码”种群,这种种群的染色体的每一位就对应着决策变量的实际值,即这种编码方式下Phen等价Chrom。

    2.3 目标函数值

    Geatpy采用numpy的array类型矩阵来存储种群的目标函数值。一般命名为ObjV,每一行对应每一个个体,因此它拥有与Chrom相同的行数;每一列对应一个目标函数,因此对于单目标函数,ObjV会只有1列;而对于多目标函数,ObjV会有多列, ObjV的表示形式如下:

    python遗传算法之geatpy的怎么安装使用

    2.4 个体适应度

    Geatpy采用列向量来存储种群个体适应度(适应度函数计算而来)。一般命名为FitnV,它同样是numpy的array类型,每一行对应种群矩阵的每一个个体。因此它拥有与Chrom相同的行数,FitnV的格式如下:

    python遗传算法之geatpy的怎么安装使用

    注意:Geatpy中的适应度遵循“最小适应度为0”的约定。

    2.5 违反约束程度矩阵

    Geatpy采用numpy的array类型的矩阵CV(Constraint Violation Value)来存储种群个体违反各个约束条件的程度。命名为CV,它的每一行对应种群的每一个个体,因此它拥有与Chrom相同的行数;每一列对应一个约束条件,因此若有一个约束条件,那么CV矩阵就会只有一列,如有多个约束条件,CV矩阵就会有多列。如果设有num个约束,则CV矩阵的结构如下图所示:

    python遗传算法之geatpy的怎么安装使用

    CV矩阵的某个元素若小于或等于0,则表示该元素对应的个体满足对应的约束条件。若大于0,则表示违反约束条件,在大于0的条件下值越大,该个体违反该约束的程度就越高。Geatpy提供两种处理约束条件的方法,一种是罚函数法,另一种是可行性法则。在使用可行性法则处理约束条件时,需要用到CV矩阵。

    2.6 译码矩阵

    所谓的译码矩阵,只是用来描述种群染色体特征的矩阵,如染色体中的每一位元素所表达的决策变量的范围、是否包含范围的边界、采用二进制还是格雷码、是否使用对数刻度、染色体解码后所代表的决策变量的是连续型变量还是离散型变量等等。

    在只使用工具箱的库函数而不使用Geatpy提供的面向对象的进化算法框架时,译码矩阵可以单独使用。若采用Geatpy提供的面向对象的进化算法框架时,译码矩阵可以与一个存储着种群染色体编码方式的字符串Encoding来配合使用。

    目前Geatpy中有三种Encoding,分别为:

    • BG:(二进制/格雷码)

    • RI:((实整数编码,即实数和整数的混合编码)

    • P:(排列编码,即染色体每一位的元素都是互异)

    注:’RI’和’P’编码的染色体都不需要解码,染色体上的每一位本身就代表着决策变量的真实值,因此“实整数编码”和“排列编码”可统称为“实值编码”

    以BG编码为例,我们展示一下编译矩阵FieldD。FieldD的结构如下:

    python遗传算法之geatpy的怎么安装使用

    其中,lens,lb,ub,codes,scales,lbin,ubin,varTypes都是行向量,其长度等于决策变量的个数。

    • lens:代表以条染色体中,每个子染色体的长度。

    • lb:代表每个变量的上界

    • ub:代表每个变量的下界

    • codes:代表染色体字串用的编码方式,[1,0,1]代表第一个变量用的格雷编码,第二个变量用的二进制编码,第3个变量用的格雷编码。

    • scales:指明每个子串用的是算术刻度还是对数刻度。scales[i] = 0为算术刻度,scales[i] = 1为对数刻度(对数刻度很少用,可以忽略。)

    • lbin:代表变量上界是否包含其范围边界。0代表不包含,1代表包含。‘[ ’和 ‘(’ 的区别

    • ubin:代表变量下界是否包含其范围边界。0代表不包含,1代表包含。

    • varTypes:代表决策变量的类型,元素为0表示对应位置的决策变量是连续型变量;1表示对应的是离散型变量。

    例如:有以下一个译码矩阵

    python遗传算法之geatpy的怎么安装使用

    它表示待解码的种群染色体矩阵Chrom解码后可以表示成3个决策变量,每个决策变量的取值范围分别是[1,10], [2,9], [3,15]。其中第一第二个变量采用的是二进制编码,第三个变量采用的是格雷编码,且第一、第三个决策变量为连续型变量;第二个为离散型变量。

    #通过种群染色体chrom和译码矩阵FieldD,可解码成种群表现型矩阵。import geatpy as eaPhen = ea.bs2ri(Chrom, FieldD)

    2.7 进化追踪器

    在使用Geatpy进行进化算法编程时,常常建立一个进化追踪器(如pop_trace)来记录种群在进化的过程中各代的最优个体,尤其是采用无精英保留机制时,进化追踪器帮助我们记录种群在进化过程中的最优个体。待进化完成后,再从进化追踪器中挑选出“历史最优”的个体。这种进化记录器有多种,其中一种是numpy的array类型的,结构如下:其中MAXGEN是种群进化的代数(迭代次数)。

    python遗传算法之geatpy的怎么安装使用

    trace的每一列代表不同的指标,比如第一列记录各代种群的最佳目标函数值,第二列记录各代种群的平均目标函数值…trace的每一行对应每一代,如第一行代表第一代,第二行代表第二代…另外一种进化记录器是一个列表,列表中的每一个元素都是一个拥有相同数据类型的数据。比如在Geatpy的面向对象进化算法框架中的pop_trace,它是一个列表,列表中的每一个元素都是历代的种群对象。

    3. geatpy的种群结构

    3.1 Population类

    在Geatpy提供的面向对象进化算法框架中,种群类(Population)是一个存储着与种群个体相关信息的类。它有以下基本属性:

    • sizes : int -种群规模,即种群的个体数目。

    • ChromNum : int -染色体的数目,即每个个体有多少条染色体。

    • Encoding : str -染色体编码方式。

    • Field : array -译码矩阵,可以是FieldD或FieldDR。

    • Chrom : array -种群染色体矩阵,每一行对应一个个体的一条染色体。

    • Lind : int -种群染色体长度。

    • ObjV : array -种群目标函数值矩阵。

    • FitnV : array -种群个体适应度列向量。

    • CV : array -种群个体违反约束条件程度的矩阵。

    • Phen : array -种群表现型矩阵。

    可以直接对种群对象进行提取个体、个体合并等操作,比如pop1和pop2是两个种群对象,则通过语句“pop3 = pop1 + pop2”,即可把两个种群的个体合并,得到一个新的种群。在合并的过程中,实际上是把种群的各个属性进行合并,然后用合并的数据来生成一个新的种群(详见Population.py)。又比如执行语句“pop3 = pop1[[0]]”,可以把种群的第0号个体抽取出来,得到一个新的只有一个个体的种群对象pop3。值得注意的是,种群的这种个体抽取操作要求下标必须为列表或是Numpy array类型的行向量,不能是标量(详见Population.py)

    3.2 PsyPopulation类

    PsyPopulation类是Population的子类,它提供Population类所不支持的多染色体混合编码。它有以下基本属性:

    • sizes : int -种群规模,即种群的个体数目。

    • ChromNum : int -染色体的数目,即每个个体有多少条染色体。

    • Encodings : list -存储各染色体编码方式的列表。

    • Fields : list -存储各染色体对应的译码矩阵的列表。

    • Chroms : list -存储种群各染色体矩阵的列表。

    • Linds : list -存储种群各染色体长度的列表。

    • ObjV : array -种群目标函数值矩阵。

    • FitnV : array -种群个体适应度列向量。

    • CV : array -种群个体违反约束条件程度的矩阵。

    • Phen : array -种群表现型矩阵。

    可见PsyPopulation类基本与Population类一样,不同之处是采用Linds、Encodings、Fields和Chroms分别存储多个Lind、Encoding、Field和Chrom。

    PsyPopulation类的对象往往与带“psy”字样的进化算法模板配合使用,以实现多染色体混合编码的进化优化

    4. 求解标准测试函数——McCORMick函数

    遗传算法求解以下函数的最小值: 

    python遗传算法之geatpy的怎么安装使用

    代码实现:

    #-*-coding:utf-8-*-import numpy as npimport geatpy as ea#导入geatpy库import time"""============================目标函数============================"""def aim(Phen):#传入种群染色体矩阵解码后的基因表现型矩阵    x1 = Phen[:, [0]]#取出第一列,得到所有个体的第一个自变量    x2 = Phen[:, [1]]#取出第二列,得到所有个体的第二个自变量    return np.sin(x1 + x2) + (x1 - x2) ** 2 - 1.5 * x1 + 2.5 * x2+1"""============================变量设置============================"""x1 = [-1.5, 4]#第一个决策变量范围x2 = [-3, 4]#第二个决策变量范围b1 = [1, 1]#第一个决策变量边界,1表示包含范围的边界,0表示不包含b2 = [1, 1]#第二个决策变量边界,1表示包含范围的边界,0表示不包含#生成自变量的范围矩阵,使得第一行为所有决策变量的下界,第二行为上界ranges=np.vstack([x1, x2]).T#生成自变量的边界矩阵borders=np.vstack([b1, b2]).TvarTypes = np.array([0, 0])#决策变量的类型,0表示连续,1表示离散"""==========================染色体编码设置========================="""Encoding ='BG'#'BG'表示采用二进制/格雷编码codes = [1, 1]#决策变量的编码方式,两个1表示变量均使用格雷编码precisions =[6, 6]#决策变量的编码精度,表示解码后能表示的决策变量的精度可达到小数点后6位scales = [0, 0]#0表示采用算术刻度,1表示采用对数刻度#调用函数创建译码矩阵FieldD =ea.crtfld(Encoding,varTypes,ranges,borders,precisions,codes,scales)"""=========================遗传算法参数设置========================"""NIND     = 20#种群个体数目MAXGEN   = 100#最大遗传代数maxormins = np.array([1])#表示目标函数是最小化,元素为-1则表示对应的目标函数是最大化selectStyle ='sus'#采用随机抽样选择recStyle ='xovdp'#采用两点交叉mutStyle ='mutbin'#采用二进制染色体的变异算子Lind =int(np.sum(FieldD[0, :]))#计算染色体长度pc= 0.9#交叉概率pm= 1/Lind#变异概率obj_trace = np.zeros((MAXGEN, 2))#定义目标函数值记录器var_trace = np.zeros((MAXGEN, Lind))#染色体记录器,记录历代最优个体的染色体"""=========================开始遗传算法进化========================"""start_time = time.time()#开始计时Chrom = ea.crtpc(Encoding,NIND, FieldD)#生成种群染色体矩阵variable = ea.bs2ri(Chrom, FieldD)#对初始种群进行解码ObjV = aim(variable)#计算初始种群个体的目标函数值best_ind = np.argmin(ObjV)#计算当代最优个体的序号#开始进化for gen in range(MAXGEN):    FitnV = ea.ranking(maxormins * ObjV)#根据目标函数大小分配适应度值    SelCh = Chrom[ea.selecting(selectStyle,FitnV,NIND-1),:]#选择    SelCh = ea.recombin(recStyle, SelCh, pc)#重组    SelCh = ea.mutate(mutStyle, Encoding, SelCh, pm)#变异    # #把父代精英个体与子代的染色体进行合并,得到新一代种群    Chrom = np.vstack([Chrom[best_ind, :], SelCh])    Phen = ea.bs2ri(Chrom, FieldD)#对种群进行解码(二进制转十进制)    ObjV = aim(Phen)#求种群个体的目标函数值    #记录    best_ind = np.argmin(ObjV)#计算当代最优个体的序号    obj_trace[gen,0]=np.sum(ObjV)/ObjV.shape[0]#记录当代种群的目标函数均值    obj_trace[gen,1]=ObjV[best_ind]#记录当代种群最优个体目标函数值    var_trace[gen,:]=Chrom[best_ind,:]#记录当代种群最优个体的染色体    # 进化完成    end_time = time.time()#结束计时    ea.trcplot(obj_trace, [['种群个体平均目标函数值','种群最优个体目标函数值']])#绘制图像"""============================输出结果============================"""best_gen = np.argmin(obj_trace[:, [1]])print('最优解的目标函数值:', obj_trace[best_gen, 1])variable = ea.bs2ri(var_trace[[best_gen], :], FieldD)#解码得到表现型(即对应的决策变量值)print('最优解的决策变量值为:')for i in range(variable.shape[1]):    print('x'+str(i)+'=',variable[0, i])    print('用时:', end_time - start_time,'秒')

    效果图:

    python遗传算法之geatpy的怎么安装使用

    结果如下:

    python遗传算法之geatpy的怎么安装使用

    以上就是关于“python遗传算法之geatpy的怎么安装使用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网Python频道。

    --结束END--

    本文标题: python遗传算法之geatpy的怎么安装使用

    本文链接: https://www.lsjlt.com/news/327363.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • python遗传算法之geatpy的怎么安装使用
      这篇“python遗传算法之geatpy的怎么安装使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python遗传算法之g...
      99+
      2023-06-30
    • python遗传算法之geatpy如何安装使用
      这篇文章主要介绍了python遗传算法之geatpy如何安装使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python遗传算法之geatpy如何安装使用文章都会有所收获,下面我们一起来看看吧。1. geat...
      99+
      2023-07-06
    • python遗传算法之geatpy的深入理解
      目录1. geatpy的安装2. geatpy的基础数据结构2.1 种群染色体2.2 种群表现型2.3 目标函数值2.4 个体适应度2.5 违反约束程度矩阵2.6 译码矩阵2.7 进...
      99+
      2024-04-02
    • Python遗传算法Geatpy工具箱使用介绍
      目录一、 什么是遗传算法?二、 遗传算法库Geatpy2.1 遗传算法工具箱Geatpy参数介绍三、最佳实践3.1 代码示例 | 参数模板3.2 最佳实践一、 什么是遗传算法? 遗传...
      99+
      2024-04-02
    • Python怎么实现遗传算法
      这篇文章给大家分享的是有关Python怎么实现遗传算法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。(一)问题遗传算法求解正方形拼图游戏(二)代码#!/usr/bin/env python# ...
      99+
      2023-06-21
    • 如何使用Python实现遗传算法
      本篇内容介绍了“如何使用Python实现遗传算法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!遗传算法是模仿自然界生物进化机制发展起来的随机...
      99+
      2023-07-05
    • 怎么用python代码实现遗传算法
      要使用Python代码实现遗传算法,可以按照以下步骤进行操作:1. 定义问题:首先,需要明确要解决的问题是什么,例如优化问题、寻找最...
      99+
      2023-10-10
      python
    • 怎么用Python遗传算法处理TSP问题
      本文小编为大家详细介绍“怎么用Python遗传算法处理TSP问题”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Python遗传算法处理TSP问题”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。TSP问题那么...
      99+
      2023-07-04
    • 使用Python实现遗传算法的完整代码
      目录遗传算法具体步骤:1.2 实验代码1.3 实验结果1.4 实验总结1、如何在算法中实现“优胜劣汰”?2 、如何保证进化一直是在正向进行?3、交叉如何实现?...
      99+
      2023-03-23
      Python 遗传算法 python算法
    • 使用Python实现的遗传算法 附完整代码
      遗传算法是模仿自然界生物进化机制发展起来的随机全局搜索和优化方法,它借鉴了达尔文的进化论和孟德尔的遗传学说。其本质是一种高效、并行、全局搜索的方法,它能在搜索过程中自动获取和积累有关搜索空间的知识,并自适应的控制搜索过程以求得最优解。遗传算...
      99+
      2023-09-26
      Python 遗传算法 flask Powered by 金山文档
    • Python中怎么实现一个遗传算法框架
      本篇文章给大家分享的是有关Python中怎么实现一个遗传算法框架,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。算法特点以决策变量的编码作为运算对象,使得优化过程借鉴生物学中的概...
      99+
      2023-06-17
    • python遗传算法之单/多目标规划问题怎么解决
      这篇“python遗传算法之单/多目标规划问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python遗传算法之单...
      99+
      2023-06-30
    • python实现使用遗传算法进行图片拟合
      目录引言预备知识及准备工作打开图片随机生成生物族群按照生物性状画图对比生物个体和目标图片的相似度保存图片算法主体交叉互换基因突变基因片段易位增加基因片段减少基因片段变异繁殖淘汰拟合示...
      99+
      2024-04-02
    • Python中怎么实现一个简单遗传算法
      今天就跟大家聊聊有关Python中怎么实现一个简单遗传算法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。遗传算法遗传算法是模仿自然选择过程的优化算法。 他们没有使用"数学技...
      99+
      2023-06-16
    • 如何使用Python地图四色原理的遗传算法着色
      小编给大家分享一下如何使用Python地图四色原理的遗传算法着色,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 任务需求  ...
      99+
      2023-06-29
    • python如何实现使用遗传算法进行图片拟合
      小编给大家分享一下python如何实现使用遗传算法进行图片拟合,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!引言算法思路假设我们有这样一个生物族群,他们的每个基因片段都是一个个三角形(即只含三个点和颜色信息),他们每个个体...
      99+
      2023-06-29
    • Python之requests怎么安装使用
      1.准备工作首先呢,我们要确保我们已经之前安装requests库,如果没有安装,按照下面步骤按照库。pip 安装无论是 Windows、Linux 还是 Mac,都可以通过 pip 这个包管理工具来安装。在命令行下运行如下命令即可完成 re...
      99+
      2023-05-18
      Python Requests
    • Python遗传算法中适值函数的标定方法是什么
      这篇“Python遗传算法中适值函数的标定方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python遗传算法中适值...
      99+
      2023-06-03
    • Vue3兄弟组件传值之mitt怎么安装使用
      本篇内容介绍了“Vue3兄弟组件传值之mitt怎么安装使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!比起 Vue 实例上的 EventB...
      99+
      2023-07-02
    • Python之zhon库的简介、安装、使用方法
      zhon是一个Python库,用于处理中文文本。它提供了一些有用的工具和数据,例如中文标点符号、简体和繁体中文字符集等。安装zhon...
      99+
      2023-09-08
      Python
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作