多目标优化NSGA-II(快速精英非支配排序遗传算法)及python实现

本文主要是介绍多目标优化NSGA-II(快速精英非支配排序遗传算法)及python实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、什么是NSGA-II?
  • 二、学习NSGA-II
    • 1.快速非支配排序算法
    • 2.密度估计
    • 3.拥挤比较算子
    • 4.主循环
    • 5.代码
    • 6.总结


前言

NSGA-II适用于复杂的多目标优化问题,是K-Deb教授在2000年在一篇paper《MOEAs — A fast and elitist multi-objective genetic algorithm: nsga2》提出。

Keywords: optimization; multi-objective evolutionary algorithm; non-dominated sorting genetic algorithm II (NSGA-II); genetic algorithm(GA);crowding-distance

原文链接: http://repository.ias.ac.in/83498/1/2-a.pdf.


一、什么是NSGA-II?

在过去的十年里,许多多目标进化算法被提出。主要原因是他们能够在一次运行中找到多个帕累托最优解。由于问题具有多目标公式的主要原因是不可能有一个同时优化所有目标的单一解,因此给出大量位于帕累托最优前沿或其附近的备选解的算法具有很大的实用价值。

The Non-dominated Sorting Genetic Algorithm (NSGA) 是此多目标进化算法之一。

但是NSGA有一些问题:

  • 非支配排序高的计算复杂度: 复杂度为 O ( m N 3 ) O\left(m N^{3}\right) O(mN3)
  • 缺乏elitism: 精英主义可以显著加快遗传算法的性能。
  • 需要制定共享参数: 严重依赖于共享的概念。

NSGA-II的出现解决了这些问题。

二、学习NSGA-II

1.快速非支配排序算法

为了根据非支配水平大小为N的种群进行排序,必须将每个解与种群中的每个其他的解进行比较,以发现它是否被支配。

什么是支配?

​ 比如一个女生和另外一个女生比较身高和体重,如果1号女生既比2号女生高又比2号女生瘦,此时1号女生支配2号女生。如果1号女生只比2号女生高,但是比2号女生瘦,这说明两个女生身材不分伯仲,此时谁都不支配谁。

首先,我们对于每个解,计算两个实体:

  • n i n_{i} ni支配解的数量。

  • S i S_{i} Si支配解 i i i的一组解

    这两个实体的计算复杂度为 O ( m N 2 ) O\left(m N^{2}\right) O(mN2)

    我们要找到所有 n i = 0 n_{i}=0 ni=0的点,并把它放入一个 F 1 F_{1} F1列表中。现在,对于 F 1 F_{1} F1证监会中每一个解决方案,我们访问其 S i S_{i} Si集合中的每一个成员j,并将n计数减少1。如果对于任何一个成员j的计数变为0,就将它放入单独的列表h中。当 F 1 F_{1} F1中所有成员被检查过,将 F 1 F_{1} F1作为一级非支配层。然后,继续循环,使用h作为下一次循环的 F 1 F_{1} F1。以此类推,直到整个种群被分层。

2.密度估计

为了估计人口中特定点周围解的密度,我们沿着每个目标取该点两侧两点的平均距离。这个数值作为以最近邻居作为顶点的长方体周长的估计。
在这里插入图片描述

3.拥挤比较算子

经过快速非支配排序以及计算拥挤度之后,种群中每个人口有两个属性:

  • 非支配等级

  • 局部拥挤距离

    也就是说,在具有不同非支配等级的两个解之间,我们具有较低等级的点更好。如果两个点都属于一个等级,那么位于点数较少的区域的点(包含它的长方体的大小较大)更好。

4.主循环

最初,创建随机的父群体 P 0 P_{0} P0,对种群进行非支配排序。每个解被分配一个与其非支配等级级别相等的适应度。Binary tournament、重组、变异操作符用于创建大小为n的子种群 Q 0 Q_{0} Q0。精英策略伪代码如下所示:

在这里插入图片描述

首先,将t代产生的新种群 Q t Q_{t} Qt与父代种群 P t P_{t} Pt合并。群体大小为2N。然后,进行非支配排序。新的父群体 P t + 1 P_{t+1} Pt+1是累加的,直到填满N。这个n个大小的种群现在用于选择、交叉和变异,以创建新种群 Q t + 1 Q_{t+1} Qt+1

精英策略:
img

5.代码

使用geatpy遗传算法工具库可以实现NSGA-II算法。后期会介绍,敬请期待!

6.总结

以上就是今天要讲的内容,本文仅仅简单介绍了NSGA-II以及代码,NSGA-II是一个非常强大的多目标优化算法。

这篇关于多目标优化NSGA-II(快速精英非支配排序遗传算法)及python实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time