NSGA-II算法解析

NSGA-Ⅱ是一种处理多目标优化问题的算法,通过非支配排序和拥挤距离概念找到帕累托前沿,保持了解的多样性。文章详细介绍了基本原理,包括初始化解、适应度计算、非支配关系的定义以及拥挤距离在选择最优解中的作用。
摘要由CSDN通过智能技术生成

1. NSGA-Ⅱ解决的问题类型

多目标优化是涉及多个目标函数同时优化的数学问题。需要在两个或多个相互冲突的目标之间进行权衡的情况下作出最优决策。 通俗易懂的解释是,假如现在有两个指标(a, b)去衡量事物的优越性,那么此时有

实例指标
实例1 a 1 , b 1 a_1,b_1 a1,b1
实例2 a 2 , b 2 a_2,b_2 a2,b2
实例3 a 3 , b 3 a_3,b_3 a3,b3

当指标 a 1 好于 a 2 好于 a 3 , b 2 好于 b 1 好于 b 3 a_1 好于 a_2 好于 a_3, b_2 好于 b_1好于 b_3 a1好于a2好于a3b2好于b1好于b3
我们很清楚可以知道,实例3是最差的,但实例1和实例2分别有一个指标优于对方。NSGA-Ⅱ的解即是实例1和实例2,最终的解是一个集合,里面的所有解的关系就像实例1和实例2一样,无法确定哪个比哪个更优,即无法互相支配,称为帕累托前沿(Pareto Front)。

2. NSGA-Ⅱ的基本原理

2.1 基本流程

  1. 初始化N个解(个体)
  2. 计算函数值(或者适应度)质
  3. 利用旧解产生新解期,各种策略:GA,PSO,灰狼优化等(本质一样)
  4. 选择得到新一轮的解
    • 单目标: 谁的y值小,谁就好(最小化问题),旧的解50个,新的解50个,直接整体排序,保留50个即可
    • 多目标: 旧的解50个,新的解50怎么排序?如何比较大小?谁更好? 使用非支配排序解决

2.2 非支配排序

2.2.1 支配

根据前面的解释,下图中点P可以支配圈内所有的解,经过对所有解筛选支配关系,最后我们得到的会是帕累托前沿上的所有解。
在这里插入图片描述

2.2.2 拥挤距离

在求得帕累托前沿时,我们总是希望解是均匀分布在帕累托前沿的线/面上的,因为均匀分布的才方便我们去直观感受解的空间,如果分布不均匀,可能很难去了解真实的情况,比如下图,我们很难看出中间部分解的情况,到底哪一条虚线才是真实的情况
在这里插入图片描述
拥挤距离的计算如下图所示,对每个点来说,是离它最近的两个点的距离,推理到三维或多维空间也相同
在这里插入图片描述
可以看到, P 2 的拥挤距离相对于 P 1 的拥挤距离是更大的,我们就认为 P 2 是更优的解 可以看到,P_2的拥挤距离相对于P_1的拥挤距离是更大的,我们就认为P_2是更优的解 可以看到,P2的拥挤距离相对于P1的拥挤距离是更大的,我们就认为P2是更优的解
选择在保留解的时候,更倾向于保留拥挤距离较大的解。
而拥挤距离越大就代表着这里解比较空旷,选择拥挤距离大的解,有利于种群多样性(可能),因此,非支配解之间,也能进行比较大小。 经过比较拥挤距离,我们还可以删除一些次优的解。
此时比较大小的问题,得到了解决。 再经过拥挤距离的筛选,我们就得到了最终的帕累托最优集。

  • 22
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
R-NSGA-II算法是改进的非支配排序遗传算法(NSGA-II)。在R-NSGA-II算法,为了维持群体的均匀分布,引入了指定共享参数的概念。这个参数的定义需要一定的经验,所以确定共享参数成为了一个复杂的问题。 R-NSGA-II算法的具体步骤如下: 1. 对每个进行支配计数和支配集合的计算。支配计数(n_p)表示被p支配的的数量,支配集合(S_p)表示p所支配的的集合。这个过程需要进行O(MN^2)次比较。 2. 所有第一非支配前沿面的支配计数都为零。然后遍历每个p,对其支配集合的成员进行支配计数减一的操作。如果某个成员的支配计数达到了零,那么将其放入一个单独的集合Q,这些成员属于第二非支配前沿面。然后再从集合Q重复以上步骤,直到所有前沿面都被确定。 3. 在R-NSGA-II,将进化群体按支配关系分为多个层次。第一层是进化群体的非支配个体集合,第二层是去掉第一层个体后得到的非支配个体集合,依此类推。选择操作首先从第一层选取个体,然后再从第二层选择,直至满足新进化群体的大小要求。 综上所述,R-NSGA-II算法是一种改进的非支配排序遗传算法,通过指定共享参数来维持群体的分布性,并且根据支配关系将进化群体分为多个层次,从选择个体以形成新的进化群体。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [NSGA-II 算法](https://blog.csdn.net/qq_40491534/article/details/120767436)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值