轮盘赌选择法

news2025/1/18 3:19:38

轮盘赌选择原理

轮盘赌选择法(roulette wheel selection)是最简单也是最常用的选择方法,在该方法中,各个个体的选择概率和其适应度值成比例,适应度越大,选中概率也越大。
轮盘赌选择法
从图中可以看出一等奖、二等奖、三等奖和四等奖的概率分别为10%、20%、30%、40%,和为100%。

个体0123
概率0.10.20.30.4

python代码实现如下:

import numpy as np

# 轮盘赌选择,list1为 list []
def roulette1(list1):
    # 产生 [0, 1) 的随机数
    r = np.random.rand()
    s = 0
    for i, v in enumerate(list1):
        s += v
        if s > r:
        	# 返回个体索引{0,1,2,3}
            return i
    return len(list1) - 1

我们测试一下roulette1,测试代码如下:

from unittest import TestCase

class Test(TestCase):
    def test_roulette1(self):
        l1 = [0.1, 0.2, 0.3, 0.4]
        result1 = [0, 0, 0, 0]
        # 执行1000次,记录每个个体的选择结果
        for i in range(1000):
            index = roulette1(l1)
            result1[index] += 1
        print('result1 =', result1)
result1 = [109, 198, 304, 389]

可以看出比例接近{0.1,0.2,0.3,0.4}。

但是对于和不为100%的情况该怎么办呢?可以将每个个体的概率进行归一化处理,即每个个体的概率除以概率之和。这样做其实比较麻烦。

也可以采用另一种方法。即在取随机数的时候不取 [0,1)的随机数,而是取 [0, s) 的随机数,s为所有个体概率之和,比如每个个体概率如下表所示:

个体0123
概率0.050.010.150.2

所有个体概率之和为0.5,在计算时只需要取[0,0.5)的随机数即可。
python代码如下:

import numpy as np

def roulette2(list1):
    # 产生 [0, sum(list1)) 的随机数
    r = np.random.uniform(0, np.sum(list1))
    s = 0
    for i, v in enumerate(list1):
        s += v
        if s > r:
            return i
    return len(list1) - 1

同样的,测试一下:

from unittest import TestCase

class Test(TestCase):
	def test_roulette2(self):
        l2 = [0.05, 0.1, 0.15, 0.2]
        result2 = [0, 0, 0, 0]
        # 执行1000次,记录每个个体的选择结果
        for i in range(1000):
            index = roulette2(l2)
            result2[index] += 1
        print('result2 =', result2)
result2 = [105, 201, 296, 398]

可以看出比例接近{0.1,0.2,0.3,0.4}。

那么个体的排列顺序对概率是否有影响呢?没有影响。我们可以测试一下。

from unittest import TestCase

class Test(TestCase):
    def test_roulette3(self):
    	# 将个体顺序调换
        l3 = [0.15, 0.2, 0.05, 0.1]
        result3 = [0, 0, 0, 0]
        for i in range(1000):
            index = roulette2(l3)
            result3[index] += 1
        print('result3 =', result3)
result3 = [300, 406, 101, 193]

可以看出结果接近{0.3,0.4,0.1,0.2}。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/387179.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Rust学习总结之数组,元组,结构体用法

学过数据结构的都知道有这么一个公式,程序数据结构算法,好的数据结构能大大降低算法设计的复杂度,也能更好的为算法服务。了解一门新的计算机编程语言其数据结构是必须首先要学的,这有利于对该语言的理解和快速上手。本文将对Rust…

vue引入cdn Vue 优化Vue引入 cdn vue cdn Vue优化引入CDN vue 项目 CDN优化

vue引入cdn Vue 优化Vue引入 cdn vue cdn Vue优化引入CDN vue 项目 CDN优化未引入 CDN前 main.js更改CDN方式引入在 vue.config 中引入 CDNindex.html 加载 cdn资源使用CDN引入资源后的main.js如果引入CDN后 组件不生效CDN 服务商推荐未引入 CDN前 main.js // 依赖使用 npm 方…

Windows server 2003怎么安装iis?Windows server 2003安装IIS教程

Windows 2008系统服务器安装IIS之前已经分享过了,和Windows 2003完全不同,今天飞飞将详细地和你分享Windows server 2003卸载和安装IIS的步骤方法,希望可以帮助到你~ 1、首先进入服务器,确定下服务器是否有安装IIS,有…

漫谈数据库表设计及索引设计

一.数据库表设计 在数据库表设计上有个很重要的设计准则,称为范式设计。 什么是范式设计? 范式来自英文Normal Form,简称NF。MySQL是关系型数据库,但是要想设计—个好的关系,必须使关系满足一定的约束条件&#xff0c…

论如何用C语言的数组手撕一棵特殊的完全二叉树----堆

目录 0.前言 1. 用数组表示存储一棵完全二叉树 2. 数组表示的完全二叉树的性质 3. 堆的基本概念 3.1 堆的核心性质 3.2 堆顶的性质 3.3 堆的单支性质 3.4 堆的左右支关系 4. 用代码实现堆 4.1 堆类的实现 4.2 堆的初始化 4.3 堆的销毁 4.4 获取堆顶的数据 4.5 …

这款 Python 工具进行数据分析及数据可视化真的很棒啊

前言 大家好,今天我们以全国各地区衣食住行消费数据为例,来分析2022年中国统计年鉴数据,统计全国各地人民的消费地图,看看: 哪个省份的人最能花钱 哪个省份的人最舍得花钱 哪个省份的人最抠门 全国各地区人民在吃、穿…

一文读懂SpringBoot整合Elasticsearch(一)

(本篇文章主要介绍Spring Boot如何整合Elasticsearch,包括基本配置、数据操作、搜索功能等方面。) 一、前言 Elasticsearch是一款全文搜索引擎,可用于快速、准确地存储、搜索和分析大量数据。而Spring Boot是一款快速开发框架&a…

JUC【Callable、ReentrantLock、Semaphore、CountDownLatch】

JUC > java.util.concurrent JUC标准库提供的多线程安全相关的包 Callable 接口声明带返回值的任务 类似于Runnable,都是用来描述这个线程的工作的。 Callable描述的任务带返回值,Runnable描述的任务不带返回值 区别:线程封装了一个 “返回值”&#…

【项目精选】基于网络爬虫技术的网络新闻分析(视频+论文+源码)

点击下载源码 基于网络爬虫技术的网络新闻分析主要用于网络数据爬取。本系统结构如下: (1)网络爬虫模块。 (2)中文分词模块。 (3)中3文相似度判定模块。 (4)数据结构化存…

【Python - Matplotlib】P2 plot 折线图

Matplotlib绘制折线图折线图完整代码与效果基础折线图设定横纵坐标设置中文显示添加网格添加描述信息再添加一个城市设置两个折线图前言 上一节内容主要围绕介绍 Matplotlib 的画板结构。 链接:https://blog.csdn.net/weixin_43098506/article/details/129331576 本…

云HIS系统 云his系统源码 基于电子病历的医院信息平台标准建设

云HIS系统 云his系统源码 基于电子病历的医院信息平台标准进行建设 云HIS系统采用SaaS软件应用服务模式,提供软件应用服务多租户机制,实现一中心部署多机构使用。相对传统HIS单机构应用模式,它可灵活应对区域医疗、医疗集团、医联体、连锁诊…

GB28181国标平台LiveGBS视频统一汇聚后如何获取固定的播放地址,实现监控视频Web页面无插件播放、拉流分析、上大屏等目的...

目前汇聚各种厂家监控设备的视频汇聚平台,基本都是通过GB28181标准协议实现的。下面介绍下LiveGBS Web无插件直播的GB28181视频平台将各厂家(包括海康、大华、华为、宇视、天地伟业等)监控汇聚到同一个服务器上后,如何或者直播链接可以直播浏览器播放&am…

flstudio21水果language选项中文设置方法教程

编曲是通过DAW(数字音频工作站软件)完成的,也就是我们常说的宿主软件。现在有很多优秀的宿主软件,例如Cubase、Studio One、FL Studio等。 FL Studio是一款功能强大的音乐制作软件,也被称为FruityLoops。目前已经推出…

Android上传手机图片到服务器(这篇你要是看不懂,全网没你可以看懂的了!!!)

Android上传手机图片到服务器1、整体流程2、页面布局3、选择图片流程实现演示结果完整代码4、路径转换路径转换Utils工具类权限申请完整代码5、创建文件6、服务器端7、传输8、演示9、完整代码目录结构AndroidManifest.xml布局文件activity_main.xml传输文件工具类HttpUtil路径转…

蓝桥杯-质因数个数

蓝桥杯-质因数个数1、问题描述2、解题思路2.1 质数判断2.2 求取因子3、完整代码实现1、问题描述 给定正整数 n, 请问有多少个质数是 n 的约数。 输入格式 输入的第一行包含一个整数 n。 输出格式 输出一个整数, 表示 n 的质数约数个数。 样例输入 396样例输出 3样例说明 3…

【教学典型案例】13.学情页面逻辑问题

目录一:背景介绍二:LocalStorage缓存①localStorage是什么?②如何使用localStorage缓存三:学情页面逻辑分析过程四:总结五:升华一:背景介绍 使用的前端技术是Vue2,前端逻辑&#xf…

SpringCloud:Eureka

目录 一、eureka的作用 二、搭建Eureka服务端 三、添加客户端 四、服务发现 提供者与消费者 服务提供者:一次业务中,被其它微服务调用的服务。(提供接口给其它微服务) 服务消费者:一次业务中,调用其它微服务的服…

[1.1_2]计算机系统概述——操作系统的四个特征

文章目录第一章 计算机系统概述操作系统的特征(一)并发(二)共享并发和共享的关系(三)虚拟(四)异步小结第一章 计算机系统概述 操作系统的特征 操作系统的四个特征 并发共享 并发和共…

Linux学习第七节-SUID、SGID、SBIT特殊权限

1.SetUID特殊权限 setUID (SUID): 对于一个可执行的文件使用SUID权限后,普通用户在执行改文件后,临时拥有文件所有者的身份,该权限只在程序执行过程中有效,程序执行完毕后用户恢复原有身份。 SetUID权限会附加在所有者的x权限位上…

每日分享(2023最新文件快递柜系统网站源码 匿名口令分享临时文件分享)

​demo软件园每日更新资源,请看到最后就能获取你想要的: 1.UML参考手册(第二版) 中文 中文名: UML参考手册(第二版)原名: The Unified Modeling Language Reference Manual(2nd Edition) 作者: James Rumbaugh Ivar Jacobson Grady Booch译者: UML Ch…