pymoo包NSGA2算法实现多目标遗传算法调参详细说明

news2025/1/23 4:45:45

pymoo包NSGA2算法实现多目标遗传算法调参详细说明

    • 1.定义待求解问题
      • 1.0定义问题的参数说明
        • 1.0.0 求解问题必须设置在```def _evaluate(self, x, out, *args, **kwargs)```函数中
        • 1.0.1 问题必须用 out["F"] = [f1, f2] 包裹起来
        • 1.0.2 约束条件也必须用 out["G"] = [g3] 包裹起来
        • 1.0.3 ```def __init__(self):```里需要定义以下参数
        • 1.0.4 约束条件的g以不等式形式写明 会按照小于等于0 进行选择
      • 2.调用NSGA2的算法包设置参数
        • 2.1 NSGA2函数的参数设置
      • 3.定义迭代次数90次
      • 4.求解最帕累托最优解集的参数x向量
          • 4.2 查看输出的X的解
      • 5.帕累托最优解集的X向量参数最优解集分布
      • 6.画出帕累托前沿

1.定义待求解问题

1.0定义问题的参数说明

import numpy as np
from pymoo.core.problem import ElementwiseProblem

class MyProblem(ElementwiseProblem):

    def __init__(self):
        super().__init__(n_var=2, # X 变量数量
                         n_obj=2, # f 问题数
                         n_ieq_constr=1,# g 约束条件数量
                         xl=np.array([-2,-2]), # X 自变量下限
                         xu=np.array([2,2])# X 自变量上限
                         ) 

    def _evaluate(self, x, out, *args, **kwargs):
        # 待求解函数 
        f1 = np.cos(x[0]+x[1]) #100 * (x[0]**2 + x[1]**2) 
        f2 = np.sin(x[0]+x[1]) #(x[0]-1)**2 + x[1]**2
        # f3 = (abs(x[0])<0.3)+(abs(x[1])<0.5)

        # 约束条件会选择 <= 0 的选择
        # g1 = 2*(x[0]-0.1) * (x[0]-0.9) / 0.18
        # g2 = - 20*(x[0]-0.4) * (x[0]-0.6) / 4.8
        # g3 = ((x[0]**2)<0.5)+((x[1]**2)>0.3)
        g3 = x[0]-0.7 #+(abs(x[1])<0.3)

        out["F"] = [f1, f2] #待求解问题
        #out["G"] = [g1, g2,g3] #约束条件
        out["G"] = [g3] #约束条件


problem = MyProblem()

2.调用NSGA2的算法包设置参数

2.1 NSGA2函数的参数设置
  • pop_sizez种群数量
  • n_offsprings每代的数量
  • sampling#抽样设置
  • crossove()交叉配对设置
    • prob交叉配对的概率设置
    • eta
  • mutation()变异译概率
    • prob是变异的概率设置
    • eta
  • eliminate_duplicates我们启用重复检查(“eliminate_duplicates=True”),确保交配产生的后代在设计空间值方面与自身和现有种群不同。
from pymoo.algorithms.moo.nsga2 import NSGA2
from pymoo.operators.crossover.sbx import SBX
from pymoo.operators.mutation.pm import PM
from pymoo.operators.sampling.rnd import FloatRandomSampling,IntegerRandomSampling,BinaryRandomSampling

algorithm = NSGA2(
   pop_size=90, # z种群数量
   n_offsprings=100, # 每代的数量
   sampling= FloatRandomSampling(), #抽样设置
    #交叉配对
   crossover=SBX(prob=0.9 #交叉配对概率
                 , eta=15), #配对效率
   #变异
   mutation=PM(prob=0.8 #编译概率
               ,eta=20),# 配对效率
   eliminate_duplicates=True
)

3.定义迭代次数90次

from pymoo.termination import get_termination

termination = get_termination("n_gen", 90)

4.求解最帕累托最优解集的参数x向量

from pymoo.optimize import minimize

res = minimize(problem,
               algorithm,
               termination,
               seed=1,
               save_history=True,
               verbose=True)

X = res.X # 求解出来的参数
F = res.F # 帕累托最优解集
4.2 查看输出的X的解
array([[-1.22983903, -0.3408983 ],
       [-1.17312926, -1.9683635 ],
       [-1.62815244, -1.25867184],
       [-1.59459202, -1.24720921],
       [-0.85812605, -0.86104326],
       [ 0.14217774, -1.79408273],
       [-1.16038493, -0.45298884],
       [-1.30857014, -0.53215836],
       [-0.99480251, -1.0484723 ],
       [-1.17506923, -0.83512127],
       [-1.12330204, -1.13340585],
       [-1.02395611, -1.33764674],
       [-0.99658648, -0.88776711],
       [-0.87963539, -0.86581268],
       [-1.59330301, -0.09593218],
       [-1.89860429, -1.07240541],
       [-0.92025241, -0.88515559],
       [-1.89221588, -1.02590525],
       [-1.15977198, -0.61984559],
       [-1.23391136, -1.89214062],
       [-1.08575639, -1.1960931 ],
       [-1.8422881 , -1.17730121],
       [-1.97907088, -0.67847822],
       [-1.19339619, -1.30837703],
       [-1.81657534, -0.6468284 ],
       [-1.34872892, -1.1691978 ],
       [-1.70461135, -1.08101794],
       [-1.28766298, -0.92085304],
       [-1.10488217, -1.16702018],
       [-1.45199598, -0.92807938],
       [-1.83785271, -0.26933177],
       [-1.10292853, -1.0760453 ],
       [-1.97460715, -1.02344251],
       [-1.92346673, -1.17730121],
       [-1.35716933, -0.9513154 ],
       [-1.07370789, -1.16339584],
       [-1.61844778, -0.54832033],
       [-1.69262569, -1.29666833],
       [-1.1205858 , -1.9683635 ],
       [-1.32886108, -1.09105746],
       [-0.87963539, -0.85896725],
       [-1.17319829, -1.50153054],
       [-1.63954555, -1.28599005],
       [-0.92662448, -0.93538073],
       [-1.29072744, -0.82715754],
       [-1.72496415, -1.22313643],
       [-1.70410919, -1.36171497],
       [-1.57300848, -1.04123091],
       [-1.81522276, -0.66364657],
       [-1.28643454, -1.14856238],
       [-1.13870379, -0.8286136 ],
       [-1.60254074, -1.21320856],
       [-1.3972806 , -0.68146238],
       [-1.37242908, -0.92807938],
       [-1.29950364, -0.37689045],
       [-1.32237812, -1.09105746],
       [-1.59549137, -1.35399596],
       [-0.86920703, -1.22313643],
       [-1.38180886, -1.34157915],
       [-1.46024398, -1.24232167],
       [-1.12485534, -1.47579521],
       [-1.24917941, -1.2408934 ],
       [-1.6174287 , -1.02798238],
       [-1.46214609, -0.68146238],
       [-0.89315598, -0.95504252],
       [-1.2693953 , -1.07649403],
       [-1.31640451, -1.32237493],
       [-1.2414329 , -1.15952844],
       [-1.10828403, -0.80474544],
       [-1.06864911, -0.83165391],
       [-1.83785271, -1.1960931 ],
       [-1.03382957, -1.50125804],
       [-1.81678927, -0.71106355],
       [-1.12485534, -1.50226124],
       [-1.14170746, -1.05251568],
       [-0.37583973, -1.94856256],
       [-1.19888652, -0.86892885],
       [-1.44462396, -0.94172587],
       [-1.57293402, -1.19861388],
       [-1.7873066 , -1.04123091],
       [-1.19339619, -0.74337764],
       [-1.41439116, -0.77744839],
       [-1.03394747, -1.65557748],
       [-1.29621172, -0.30606688],
       [-0.85812605, -1.09549174],
       [-1.31640451, -1.39906326],
       [-1.36337969, -1.03256822],
       [-1.59459202, -1.20585082],
       [-1.10292853, -1.02523266],
       [-1.85491578, -0.88327578]])

5.帕累托最优解集的X向量参数最优解集分布

import matplotlib.pyplot as plt 
plt.figure(figsize=(16,16))
plt.scatter(X[:,0],X[:,-1])

请添加图片描述

6.画出帕累托前沿

import matplotlib.pyplot as plt 
plt.figure(figsize=(16,9))
plt.scatter(F[:,0],F[:,-1])
plt.savefig("NSGA2demo帕累托前沿.png")

请添加图片描述

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

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

相关文章

Oracle 简介与 Docker Compose部署

最近&#xff0c;我翻阅了在之前公司工作时的笔记&#xff0c;偶然发现了一些有关数据库的记录。当初&#xff0c;我们的项目一开始采用的是 Oracle 数据库&#xff0c;但随着项目需求的变化&#xff0c;我们不得不转向使用 SQL Server。值得一提的是&#xff0c;公司之前采用的…

Windows保姆级安装Docker教程

1.官网下载 2.安装 3.启动Hyper-V 4.检查是否安装成功 1.下载 1.1.打开官网&#xff0c;然后点击下载 官网链接&#xff1a;https://hub.docker.com/ 2.安装 下载好之后会得到一个exe程序&#xff0c;然后启动它&#xff0c;进行安装。 去掉 WSL 不使用Hyper-V&#xff0…

KdMapper扩展实现之REALiX(hwinfo64a.sys)

1.背景 KdMapper是一个利用intel的驱动漏洞可以无痕的加载未经签名的驱动&#xff0c;本文是利用其它漏洞&#xff08;参考《【转载】利用签名驱动漏洞加载未签名驱动》&#xff09;做相应的修改以实现类似功能。需要大家对KdMapper的代码有一定了解。 2.驱动信息 驱动名称hwin…

使用testMe自动生成单元测试用例

文章目录 1、testMe简介2、插件对比2.1 testMe2.2 Squaretest2.3 Diffblue 3、IDEA插件安装4、单测用例4.1 maven依赖4.2 生成用例 5、自定义模板6、使用自定义模板生成用例7、调试用例 1、testMe简介 公司对于系统单元测试覆盖率有要求&#xff0c;需要达到50%或80%以上才可以…

RV1126-RV1109-进入uboot的按键和名字显示-HOSTNAME

今天添加一个小功能,就是uboot是按CTRLC进入的 今日我做了一个定制,让按L或者l让也进入uboot指令模式,并且修改主板名字显示 默认是CTRLC:键码值是0x03(ASCII对照表) 于是代码中跟踪: //rv1126_rv1109/u-boot/common/console.c int ctrlc(void) { #ifndef CONFIG_SANDBOXif (…

Python大数据之Python进阶(五)线程

文章目录 线程1. 线程的介绍2. 线程的概念3. 线程的作用4. 小结 线程 学习目标 能够知道线程的作用 1. 线程的介绍 在Python中&#xff0c;想要实现多任务除了使用进程&#xff0c;还可以使用线程来完成&#xff0c;线程是实现多任务的另外一种方式。 2. 线程的概念 线程是进程…

【chrome基础】Chrome、Chromium、libcef、electron版本关系大揭秘!

文章目录 概述chrome、Chromium、cef、electron 版本管理chrome的各种概念和学习资料V8 bindings 设计谷歌V8引擎探秘&#xff1a;基础概念Chrome 的插件&#xff08;Plugin&#xff09;与扩展&#xff08;Extension&#xff09;Chrome插件开发 概述 Chrome、Chromium、libcef、…

电荷泵CP原理及在PLL/DLL中的使用

参考【模拟集成电路】电荷泵&#xff08;CP&#xff09;设计_pll 电荷泵-CSDN博客 PLL-CP | Fitzs Blog 1.PLL/DLL中电荷泵概念及原理 电荷泵CP(charge pump)是锁相环中重要的一个模块&#xff0c;其主要功能是将鉴频鉴相器 (PFD) 输出的时钟相位差值转化为电荷&#xff0c;将…

UE5如何实现语言本地化管理(中英文切换)

一。实现蓝图的本地化控制 1.打开本地化控制面版 2.设置收集文本的路径 3.添加自己需要使用的语言&#xff0c;一般是中文 4.收集文本并进行转换语言的翻译 5.进入面板之后开始翻译 6.翻译完成之后计算字数并编译 7。一整套流程下来就是这样了 8.编译完成之后会在文件中生成…

一文汇总 Linux 内核调试的方法

内核开发比用户空间开发更难的一个因素就是内核调试艰难。内核错误往往会导致系统宕机&#xff0c;很难保留出错时的现场。调试内核的关键在于你的对内核的深刻理解。 在调试一个bug之前&#xff0c;我们所要做的准备工作有&#xff1a; 有一个被确认的bug&#xff0c;包含这…

10.10泊松、指数、伽马分布的理解

泊松定理、泊松分布 泊松定理就是描述在T段时间内每时每刻一直进行一个实验&#xff0c;这个实验成功的概率由t段时间总的成功期望次数决定&#xff0c;就是给二项分布加了个时间 泊松分布可用来描述某段时间来电次数的分布&#xff0c;电话台收到的呼叫数&#xff0c;商城的…

2023年【陕西省安全员B证】最新解析及陕西省安全员B证操作证考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2023年陕西省安全员B证最新解析为正在备考陕西省安全员B证操作证的学员准备的理论考试专题&#xff0c;每个月更新的陕西省安全员B证操作证考试祝您顺利通过陕西省安全员B证考试。 1、【多选题】《陕西省建设工程质量…

导入导出Excel

一、Springboot Easyexcel读取写入数据&#xff0c;多头行数&#xff0c;多sheet&#xff0c;复杂表头简单实现 1. 导入依赖&#xff0c;阿里的easyexcel插件 <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId>…

uniapp上echarts地图钻取

1: 预期效果 通过切换地图 , 实现地图的钻取效果 2: 实现原理以及核心方法/参数 一开始是想利用更换地图数据的形式进行地图钻取 , 这就意味着我们需要准备全国30多个省份的地图数据 , 由于一开始考虑需要适配小程序端 , 如此多的地图文件增加了程序的体积 , 如果使用接口调…

element el-table表格表头某一列表头字段修改颜色

需求&#xff1a; 1 使用 :header-cell-class-name"addClass" 属性 2 根据显示条件 在redText&#xff0c;whiteText 中设置你想要添加的必填表头index 3.根据条件修改文字样式 完整代码 <el-table ref"tableRef" :cell-style"{ color: #FFF,…

拥抱产业发展机遇 兑现5G商业价值

[阿联酋&#xff0c;迪拜&#xff0c;2023年10月10日] 今天&#xff0c;以“将5G-A带入现实”为主题的2023全球移动宽带论坛在迪拜举行。本次大会上&#xff0c;华为轮值董事长胡厚崑与GSMA总干事Mats Granryd围绕“5G产业进程与发展”连线对话。胡厚崑指出&#xff0c;“技术发…

redis 哨兵 sentinel

sentinel巡查监控后台master主机是否故障&#xff0c;如果故障根据投票数自动将某一个从库转换为新主库&#xff0c;继续对外服务 sentinel 哨兵的功能 监控 监控主从redis库运行是否正常消息通知 哨兵可以将故障转移的结果发送给客户端故障转移 如果master异常&#xff0c;则…

openEuler 系统搭建高可用 Kubernetes 集群

k8s 高可用集群部署 在生产环境中&#xff0c;k8s 高可用集群部署能够确保应用程序稳态运行不出现服务中断情况。 此处我们基于 openEuler 系统环境&#xff0c;配置 Keepalived 和 HAproxy 使负载均衡&#xff08;LB/Load Balancer&#xff09;、实现高可用。 步骤如下&…

NZ系列工具NZ04:VBA网络连接测试

我的教程一共九套及VBA汉英手册一部&#xff0c;分为初级、中级、高级三大部分。是对VBA的系统讲解&#xff0c;从简单的入门&#xff0c;到数据库&#xff0c;到字典&#xff0c;到高级的网抓及类的应用。大家在学习的过程中可能会存在困惑&#xff0c;这么多知识点该如何组织…

UOS通过GPG对文件签名验签

本人用的版本&#xff1a;gpg (GnuPG) 2.2.12 生成密钥 生成公钥/私钥对 gpg --full-generate-key设置密钥的长度 默认回车3072&#xff0c;越长越安全。 设定密钥的有效期限 默认回车“0” 构建用户标识 输入姓名、邮件、注释后&#xff0c;输入“o”确认 在弹出框内…