多目标优化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

相关文章

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B