【遗传算法】【机器学习】【Python】常见交叉方法(一)、单点交叉和两点交叉

2024-06-05 13:28

本文主要是介绍【遗传算法】【机器学习】【Python】常见交叉方法(一)、单点交叉和两点交叉,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、遗传算法流程图

在这里插入图片描述

交叉过程即存在于上图的”交叉“(crossover)步骤中。

二、单点交叉

随机地选择1个交叉位点进行交叉,如下图所示:

在这里插入图片描述用random库实现随机性:

import random# 简单的单点交叉方式
def sing_muta(list1, list2):# 假设len(list1) == len(list2)# 随机选择交叉点cross_pt = random.randint(0, len(list1) - 2)list1_cut = list1[cross_pt + 1: len(list1)]list2_cut = list2[cross_pt + 1: len(list2)]new_list1 = list1[0: cross_pt + 1]new_list1.append(list2_cut)new_list2 = list2[0: cross_pt + 1]new_list2.append(list1_cut)return new_list1, new_list2list1 = [1, 2, 3, 4, 5, 6, 7, 8]
list2 = [10, 20, 30, 40, 50, 60, 70, 80]
for i in range(5):print(sing_muta(list1, list2))

程序输出(5次交换结果):
在这里插入图片描述

三、两点交叉

随机地选择一个交叉起点和一个交叉终点,交换父代两个基因的中间部分,如下图所示:

在这里插入图片描述

Python代码:

import random# 简单的两点交叉方式
def doub_muta(list1, list2):# 假设len(list1) == len(list2)# 随机选择起点和终点new_list1 = list1new_list2 = list2cross_begin = random.randint(0, len(list1) - 1)cross_end = random.randint(0, len(list1) - 1)if cross_begin == cross_end:cross_end += 1  # 至少产生1个位点的交换elif cross_begin > cross_end:cross_begin, cross_end = cross_end, cross_begin  # 结束位点不能在开始位点之前print(cross_begin, cross_end)  # 检查位点# 切出片段list1_cut = new_list1[cross_begin: cross_end]list2_cut = new_list2[cross_begin: cross_end]new_list1[cross_begin: cross_end] = list2_cutnew_list2[cross_begin: cross_end] = list1_cutreturn new_list1, new_list2for i in range(5):list1 = [1, 2, 3, 4, 5, 6, 7, 8]list2 = [10, 20, 30, 40, 50, 60, 70, 80]print(doub_muta(list1, list2))

程序输出(5次交换结果):
在这里插入图片描述

这篇关于【遗传算法】【机器学习】【Python】常见交叉方法(一)、单点交叉和两点交叉的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1033177

相关文章

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

MySQL底层文件的查看和修改方法

《MySQL底层文件的查看和修改方法》MySQL底层文件分为文本类(可安全查看/修改)和二进制类(禁止手动操作),以下按「查看方法、修改方法、风险管控三部分详细说明,所有操作均以Linux环境为例,需... 目录引言一、mysql 底层文件的查看方法1. 先定位核心文件路径(基础前提)2. 文本类文件(可直

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python列表的创建与删除的操作指南

《Python列表的创建与删除的操作指南》列表(list)是Python中最常用、最灵活的内置数据结构之一,它支持动态扩容、混合类型、嵌套结构,几乎无处不在,但你真的会创建和删除列表吗,本文给大家介绍... 目录一、前言二、列表的创建方式1. 字面量语法(最常用)2. 使用list()构造器3. 列表推导式

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

检查 Nginx 是否启动的几种方法

《检查Nginx是否启动的几种方法》本文主要介绍了检查Nginx是否启动的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1. 使用 systemctl 命令(推荐)2. 使用 service 命令3. 检查进程是否存在4

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处