当前位置:首页 > 科技  > 软件

Python用户宝典:了解并实现遗传算法

来源: 责编: 时间:2024-07-03 10:12:10 242观看
导读译者 | 布加迪审校 | 重楼遗传算法是一种基于自然选择的技术,用于解决复杂问题。由于问题很复杂,遗传算法(而不是其他方法)被用来得出解决问题的合理方案。本文介绍遗传算法的基础知识以及如何用Python来实现。遗传算法的

译者 | 布加迪7nQ28资讯网——每日最新资讯28at.com

审校 | 重楼7nQ28资讯网——每日最新资讯28at.com

7nQ28资讯网——每日最新资讯28at.com

遗传算法是一种基于自然选择的技术,用于解决复杂问题。由于问题复杂,遗传算法(而不是其他方法)被用来得出解决问题的合理方案。本文介绍遗传算法的基础知识以及如何Python实现。7nQ28资讯网——每日最新资讯28at.com

遗传算法的要

适应度函数

适应度函数衡量所考虑的解决方案与问题的最佳解决方案的接近程度。它为人中的每个人提供了适应度水平,描述了当前一代的质量或效率。这个分定义了选择,更高的适应度值是经过优化的解决方案。7nQ28资讯网——每日最新资讯28at.com

比如说,假设我们在处理一个实际的函数f(x)其中x是一组参数。要找到的最优值是x,这样f(x)就取最大值。7nQ28资讯网——每日最新资讯28at.com

选择

过程决定了当前一代中哪些个体受到青睐,从而繁殖为下一代做出贡献。可以确定许多选择方法,每种方法都有自己的特点和适合的上下文。7nQ28资讯网——每日最新资讯28at.com

  • 盘选择

根据个体的适应度水平,选择个体的概率也是最大的。7nQ28资讯网——每日最新资讯28at.com

  • 锦标赛选择

随机抽取一组,选其中最好的。7nQ28资讯网——每日最新资讯28at.com

  • 基于排序的选择

根据适合度对人进行排序,选择机会根据适合度分数按比例分配。7nQ28资讯网——每日最新资讯28at.com

交叉

交叉是遗传算法的一个基本概念,其目的是交换两个亲本的遗传信息,形成一个或多个后代。这个过程非常类似自然界中发生的生物的交叉和重组。运用遗传的基本原理,交叉试图产生具有双亲理想特征的后代,从而在下一代中有更好的适应性。交叉是一个比较宽泛的概念,可以分为几种类型,每种类型都有其特点和可以有效运用的领域。7nQ28资讯网——每日最新资讯28at.com

  • 单点交叉在亲本染色体上选择一个交叉点,实际上只发生一次交叉。这个位置之前的所有基因都取自第一个亲本,而这个位置之后的所有基因都取自第二个亲本。
  • 两点交叉选择两个断点,它们之间的部分在两个亲本染色体之间交换。它也有利于遗传信息的交换,这与单点交叉不一样。

突变

在遗传算法中,突变之所以至关重要,是由于它提供了多样性,多样性是避免直接向最优解区收敛的关键因素。因此,获得单个突变基因随机变化,算法可以进入仅通过交叉操作无法企及最优空间的其他区域。这随机过程保证了无论怎样群都会进化,或者在遗传算法确定的搜索空间区域内移动其位置。7nQ28资讯网——每日最新资讯28at.com

实现遗传算法的步骤

不妨用Python实现遗传算法。7nQ28资讯网——每日最新资讯28at.com

问题定义

问题对具体函数进行计算;f (x) = x^2f(x) = x^2x取整7nQ28资讯网——每日最新资讯28at.com

适应度函数对于染色体二进制为x的情况,适应度函数的一个例子可f(x)= x^27nQ28资讯网——每日最新资讯28at.com

7nQ28资讯网——每日最新资讯28at.com

def fitness(chromosome):  x = int(''.join(map(str, chromosome)), 2) return x ** 2

群初始化

生成一个给定长度的随机染色体。7nQ28资讯网——每日最新资讯28at.com

def generate_chromosome(length): return [random.randint(0, 1) for _ in range(length)]def generate_population(size, chromosome_length): return [generate_chromosome(chromosome_length) for _ in range(size)]population_size = 10chromosome_length = 5population = generate_population(population_size, chromosome_length)

适应度评估

评估人群中每染色体的适应度。7nQ28资讯网——每日最新资讯28at.com

fitnesses = [fitness(chromosome) for chromosome in population]

选择

使用轮盘选择根据适合度选择亲本染色体。7nQ28资讯网——每日最新资讯28at.com

7nQ28资讯网——每日最新资讯28at.com

def select_pair(population, fitnesses):   total_fitness = sum(fitnesses) selection_probs = [f / total_fitness for f in fitnesses]   parent1 = population[random.choices(range(len(population)), selection_probs)[0]] parent2 = population[random.choices(range(len(population)), selection_probs)[0]] return parent1, parent2

交叉

使用单点交叉,在父本基因串中选择一个随机的交叉位置,并在两个基因串之间交换这个位置之后的所有基因值。7nQ28资讯网——每日最新资讯28at.com

def crossover(parent1, parent2): point = random.randint(1, len(parent1) - 1) offspring1 = parent1[:point] + parent2[point:] offspring2 = parent2[:point] + parent1[point:] return offspring1, offspring2

突变

通过以一定的概率翻转比特来实现突变。7nQ28资讯网——每日最新资讯28at.com

def mutate(chromosome, mutation_rate): return [gene if random.random() > mutation_rate else 1 - gene for gene in chromosome]mutation_rate = 0.01

总之由于模拟物种进化遗传算法对于解决无法直接解决的优化问题具有一致性和有效性。因此,一旦掌握了遗传算法的基本要素了解了如何Python实现遗传算法,解决复杂任务就会容易得多。选择、交叉和突变使您能够对解决方案进行修改,并不断获得最佳或接近最佳的答案。但愿您已准备好将遗传算法运用到自己的任务中,从而在不同的任务和问题解决中得到改进。7nQ28资讯网——每日最新资讯28at.com

原文标题:Understanding and Implementing Genetic Algorithms in Python,作者:Jayita Gulati7nQ28资讯网——每日最新资讯28at.com


7nQ28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-98420-0.htmlPython用户宝典:了解并实现遗传算法

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: .NET Core MVC 页面传值方式详解

下一篇: 高可用架构下 B 站、小红书崩了?对于阿里回应,网友认为裁员裁到大动脉

标签:
  • 热门焦点
  • 对标苹果的灵动岛 华为带来实况窗功能

    继苹果的灵动岛之后,华为也在今天正式推出了“实况窗”功能。据今天鸿蒙OS 4.0的现场演示显示,华为的实况窗可以更高效的展现出实时通知,比如锁屏上就能看到外卖、打车、银行
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 之家push系统迭代之路

    前言在这个信息爆炸的互联网时代,能够及时准确获取信息是当今社会要解决的关键问题之一。随着之家用户体量和内容规模的不断增大,传统的靠"主动拉"获取信息的方式已不能满足用
  • 微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 慕岩炮轰抖音,百合网今何在?

    来源:价值研究所 作者:Hernanderz“难道就因为自己的一个产品牛逼了,从客服到总裁,都不愿意正视自己产品和运营上的问题,选择逃避了吗?”这一番话,出自百合网联合创
  • 华为发布HarmonyOS 4:更好玩、更流畅、更安全

    在8月4日的华为开发者大会2023(HDC.Together)大会上,HarmonyOS 4正式发布。自2019年发布以来,HarmonyOS一直以用户为中心,经历四年多的发展HarmonyOS已
  • iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • OPPO K11搭载高性能石墨散热系统:旗舰同款 性能凉爽释放

    日前OPPO官方宣布,将于7月25日14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖点就是将配备索尼
  • “买真退假” 这种“羊毛”不能薅

    □ 法治日报 记者 王春   □ 本报通讯员 胡佳丽  2020年初,还在上大学的小东加入了一个大学生兼职QQ群。群主“七王”在群里介绍一些刷单赚
Top