【遗传算法】【机器学习】【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

相关文章

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.