【算法基础】NSGA-II:非支配排序遗传算法

2023-10-31 17:20

本文主要是介绍【算法基础】NSGA-II:非支配排序遗传算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

NSGA-II

    • 1. 背景:
    • 2. 快速非支配排序
    • 3. 多样性保护 NSGA-II拥挤度比较
      • 1) 密度估计
      • 2)拥挤度比较算子
    • 4. 主循环
    • 5. 其它概念:

NSGA原文: Muiltiobjective Optimization Using Nondominated Sorting in Genetic Algorithms | MIT Press Journals & Magazine | IEEE Xplore

NSGA-II原文: A fast and elitist multiobjective genetic algorithm: NSGA-II

NSGA-II作者实验室:Kalyanmoy Deb, Koenig Endowed Chair Professor

pymoo库:实验室创建的python第三方库,实现了各种多目标优化算法pymoo: Multi-objective Optimization in Python

geatpy2库:Geatpy是一个高性能实用型进化算法工具箱,提供许多已实现的进化算法中各项重要操作的库函数​​​​​​​,利用“定义问题类 + 调用算法模板”的模式来进行进化优化,可用于求解单目标优化、多目标优化、复杂约束优化、组合优化、混合编码进化优化等 Geatpy


1. 背景:

1) NSGA有以下问题

  • 非支配排序时间复杂度太高,为O(MN3),其中M为多目标数,N为种群数
  • 缺少精英保留策略(elitism),研究表明精英策略能提高GA的性能
  • 需要指定共享参数(share parameter)来确保种群多样性

NSGA-II是对NSGA的优化:

  • 复杂度变为O(MN2)
  • 有精英保留策略
  • 拥挤度替代共享参数

2. 快速非支配排序

对解集进行pareto前沿分级,成Rank1、Rank2…
在这里插入图片描述
快速非支配排序将总时间复杂度降到了O(MN2)
空间复杂度O(N2)。

np:支配数,支配解p的解数量
SP:被支配集合,解p支配的解集合
Fi:第i层Pareto前沿

在这里插入图片描述

3. 多样性保护 NSGA-II拥挤度比较

1) 密度估计

在这里插入图片描述
以下图片描述不太理解:
在这里插入图片描述

几何角度理解拥挤距离:
以两个目标函数为例,下图中黑点和白点分别为两个非支配前沿
对于解i,从与i在同一非支配前沿中选择与解i最相近的两个点i-1和i+1为顶点组成一个长方形(cuboid)
拥挤距离即为长方形周长

2)拥挤度比较算子

在计算完每个解的拥挤距离后,从一定程度上来说,某个解的拥挤距离越小,这个解被其他解拥挤的程度越高。

  • 通过拥挤度比较算子,来选择解实现更广的帕累托最优解分布。
    种群中的每个个体都有两个属性:
    (1)非支配等级irank:1是最高等级
    (2)拥挤距离idistance
    比较顺序:不同非支配等级的两个解,倾向于选择rank值更低的解
    如果两个解的等级相同,倾向于选择拥挤距离更大或者说拥挤区域更小的解。(防止陷入局补最优?)

在这里插入图片描述

4. 主循环

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5. 其它概念:

elitism 精英保留策略:核心思想是把群体在进化过程中迄今出现的最好个体不进行遗传操作而直接复制到下一代中,理论上证明了具有精英保留的标准遗传算法是全局收敛的
tournament selection 联赛选择算法:每次从种群中取一定数量(n)的个体(放回抽样),选择其中适应度较好的进入子代种群

https://blog.csdn.net/weixin_45526117/article/details/128507020

这篇关于【算法基础】NSGA-II:非支配排序遗传算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python中lambda排序的六种方法

《Python中lambda排序的六种方法》本文主要介绍了Python中使用lambda函数进行排序的六种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1.对单个变量进行排序2. 对多个变量进行排序3. 降序排列4. 单独降序1.对单个变量进行排序

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系