当前位置: 首页 > article >正文

别再死记硬背了!用Python+DEAP库5分钟搞定NSGA-II多目标优化(附完整代码)

用PythonDEAP库5分钟实现NSGA-II多目标优化实战当我们需要同时优化多个相互冲突的目标时比如在机器学习中既要模型精度高又要推理速度快传统单目标优化方法就捉襟见肘了。NSGA-II非支配排序遗传算法II作为多目标优化领域的标杆算法能帮我们找到一组最优权衡解帕累托前沿。今天我将分享如何用Python的DEAP库快速实现这一算法让你跳过复杂的数学推导直接应用于实际问题。1. 环境准备与DEAP库安装在开始之前我们需要准备好Python环境和必要的库。推荐使用Python 3.8版本并通过pip安装DEAP库pip install deap numpy matplotlibDEAPDistributed Evolutionary Algorithms in Python是一个强大的进化计算框架它提供了实现遗传算法、遗传编程等进化算法所需的工具和组件。相比自己从头实现NSGA-II使用DEAP可以节省大量时间同时保证算法的正确性和效率。注意如果你在Jupyter Notebook中运行代码建议先安装ipywidgets以获得更好的交互体验pip install ipywidgets2. 定义多目标优化问题让我们以一个经典的双目标优化问题ZDT1为例演示如何用DEAP实现NSGA-II。ZDT1问题的数学表达式如下目标1: f₁(x) x₁目标2: f₂(x) g(x)[1 - √(x₁/g(x))]其中 g(x) 1 9(∑xᵢ)/(n-1), i2,...,n决策变量x的取值范围[0,1]在DEAP中我们需要先定义问题的各个组件from deap import base, creator, tools import random import numpy as np # 定义适应度函数两个目标都需最小化 creator.create(FitnessMulti, base.Fitness, weights(-1.0, -1.0)) creator.create(Individual, list, fitnesscreator.FitnessMulti) # 初始化工具箱 toolbox base.Toolbox() # 定义决策变量30维范围[0,1] NDIM 30 toolbox.register(attr_float, random.random) toolbox.register(individual, tools.initRepeat, creator.Individual, toolbox.attr_float, nNDIM) toolbox.register(population, tools.initRepeat, list, toolbox.individual) # 定义评估函数 def evaluate(individual): f1 individual[0] # 第一个目标 g 1.0 9.0 * sum(individual[1:]) / (len(individual)-1) f2 g * (1.0 - (f1/g)**0.5) # 第二个目标 return f1, f2 toolbox.register(evaluate, evaluate)3. 配置NSGA-II算法参数DEAP已经内置了NSGA-II的实现我们只需配置适当的遗传算子即可# 配置选择、交叉和变异算子 toolbox.register(select, tools.selNSGA2) toolbox.register(mate, tools.cxSimulatedBinaryBounded, low0.0, up1.0, eta20.0) toolbox.register(mutate, tools.mutPolynomialBounded, low0.0, up1.0, eta20.0, indpb1.0/NDIM) # 算法参数设置 POP_SIZE 100 # 种群大小 CXPB 0.9 # 交叉概率 MUTPB 0.1 # 变异概率 NGEN 50 # 迭代次数这里的关键参数说明cxSimulatedBinaryBounded: 模拟二进制交叉适用于实数编码mutPolynomialBounded: 多项式变异保持解在边界内eta: 控制交叉/变异分布的形状参数典型值15-30selNSGA2: DEAP内置的NSGA-II选择算子4. 运行算法与结果可视化现在我们可以运行算法并可视化帕累托前沿了import matplotlib.pyplot as plt def main(): random.seed(42) pop toolbox.population(nPOP_SIZE) # 评估初始种群 fitnesses toolbox.map(toolbox.evaluate, pop) for ind, fit in zip(pop, fitnesses): ind.fitness.values fit # 运行NSGA-II for gen in range(1, NGEN1): offspring tools.selTournamentDCD(pop, len(pop)) offspring [toolbox.clone(ind) for ind in offspring] # 应用交叉和变异 for child1, child2 in zip(offspring[::2], offspring[1::2]): if random.random() CXPB: toolbox.mate(child1, child2) del child1.fitness.values, child2.fitness.values for mutant in offspring: if random.random() MUTPB: toolbox.mutate(mutant) del mutant.fitness.values # 评估新个体 invalid_ind [ind for ind in offspring if not ind.fitness.valid] fitnesses toolbox.map(toolbox.evaluate, invalid_ind) for ind, fit in zip(invalid_ind, fitnesses): ind.fitness.values fit # 选择下一代 pop toolbox.select(pop offspring, POP_SIZE) # 提取帕累托前沿 front tools.sortNondominated(pop, len(pop), first_front_onlyTrue)[0] return front if __name__ __main__: pareto_front main() # 可视化结果 plt.figure(figsize(8,6)) plt.scatter([ind.fitness.values[0] for ind in pareto_front], [ind.fitness.values[1] for ind in pareto_front], cr, s30, edgecolorsk) plt.title(Pareto Front for ZDT1 Problem) plt.xlabel(Objective 1 (f1)) plt.ylabel(Objective 2 (f2)) plt.grid(True) plt.show()运行这段代码后你将看到一个典型的帕累托前沿图展示了在两个目标之间的最优权衡解集。5. 实际应用案例模型超参数优化让我们看一个更实际的例子同时优化神经网络的准确率和推理速度。假设我们有一个简单的MLP模型from sklearn.neural_network import MLPClassifier from sklearn.datasets import load_digits from sklearn.model_selection import cross_val_score import time # 加载数据 digits load_digits() X, y digits.data, digits.target def evaluate_model(individual): 评估模型的两个目标准确率和推理速度 # 个体前三个基因代表超参数 hidden_size int(individual[0] * 100 50) # 50-150 lr 10**(individual[1] * 3 - 4) # 1e-4 to 1e-1 alpha 10**(individual[2] * 4 - 6) # 1e-6 to 1e-2 model MLPClassifier(hidden_layer_sizes(hidden_size,), learning_rate_initlr, alphaalpha, max_iter500) # 评估准确率最大化 start_time time.time() accuracy np.mean(cross_val_score(model, X, y, cv3)) inference_time time.time() - start_time return -accuracy, inference_time # 第一个目标需要最小化 # 更新评估函数 toolbox.unregister(evaluate) toolbox.register(evaluate, evaluate_model) # 运行优化 model_pareto main() # 可视化模型优化结果 plt.figure(figsize(8,6)) plt.scatter([-ind.fitness.values[0] for ind in model_pareto], [ind.fitness.values[1] for ind in model_pareto], cb, s30, edgecolorsk) plt.title(Pareto Front for MLP Hyperparameter Tuning) plt.xlabel(Model Accuracy) plt.ylabel(Inference Time (s)) plt.grid(True) plt.show()这个案例展示了如何将NSGA-II应用于实际的机器学习超参数优化问题帮助我们在模型性能和推理速度之间找到最佳平衡点。6. 进阶技巧与常见问题6.1 提高算法效率的方法并行评估对于计算密集型的评估函数可以使用DEAP的并行评估功能from multiprocessing import Pool pool Pool() toolbox.register(map, pool.map)早期停止如果帕累托前沿在连续几代中没有显著改进可以提前终止# 在每一代后添加这段代码 if gen % 5 0: front tools.sortNondominated(pop, len(pop), first_front_onlyTrue)[0] hv tools.hypervolume(front, ref[11.0, 11.0]) if hv - last_hv 0.01: # 超体积改进小于1% break last_hv hv6.2 常见问题排查问题现象可能原因解决方案种群过早收敛选择压力过大或多样性不足增加种群大小调整交叉/变异概率帕累托前沿不连续决策变量范围设置不当检查变量边界调整变异算子算法运行缓慢评估函数计算量大优化评估函数使用并行计算6.3 决策变量编码技巧对于不同类型的决策变量可以采用不同的编码方式连续变量直接使用实数编码如我们示例中的做法离散变量使用整数编码或特殊交叉/变异算子类别变量使用自定义的编码和遗传算子例如对于整数变量可以这样注册toolbox.register(attr_int, random.randint, 0, 100) toolbox.register(individual, tools.initCycle, creator.Individual, (toolbox.attr_int, toolbox.attr_float), n1)在实际项目中我发现将NSGA-II与网格搜索或随机搜索的结果进行比较很有价值这能验证进化算法确实找到了更好的解集。特别是在处理3个以上目标时传统的多目标优化方法往往难以胜任而NSGA-II仍能表现出色。

相关文章:

别再死记硬背了!用Python+DEAP库5分钟搞定NSGA-II多目标优化(附完整代码)

用PythonDEAP库5分钟实现NSGA-II多目标优化实战 当我们需要同时优化多个相互冲突的目标时,比如在机器学习中既要模型精度高又要推理速度快,传统单目标优化方法就捉襟见肘了。NSGA-II(非支配排序遗传算法II)作为多目标优化领域的标…...

手把手教你用STM32CubeMX配置STM32F103的Modbus从站(FreeMODBUS移植指南)

基于STM32CubeMX与FreeMODBUS的工业通信从站开发实战 在工业自动化领域,Modbus协议因其简单可靠的特点,至今仍是设备间通信的黄金标准。对于STM32开发者而言,传统的外设库直接编程方式需要处理大量底层细节,而CubeMX工具链与成熟开…...

深入GD32F427的ENET外设:如何为你的LAN8720 PHY芯片选择正确的RMII时钟模式(REF_CLK In vs Out)

深入解析GD32F427与LAN8720的RMII时钟架构设计 在嵌入式以太网开发中,时钟信号的稳定性往往决定着整个通信系统的可靠性。当GD32F427微控制器通过RMII接口与LAN8720 PHY芯片协同工作时,REF_CLK时钟模式的选择不仅影响硬件成本,更直接关系到信…...

别再傻傻用IO翻转了!用STM32的SPI+DMA驱动WS2812灯带,实测1920颗灯珠依然稳如老狗

STM32 SPIDMA驱动WS2812灯带:从时序优化到千级灯珠稳定控制实战 1. 为什么GPIO翻转方案在大型项目中频频翻车? 很多嵌入式开发者初次接触WS2812灯带时,都会尝试用GPIO翻转来实现控制——毕竟看起来只需要一根信号线,似乎用普通IO口…...

OpenClaw小龙虾 Windows10一键部署包|小白友好10分钟搞定本地AI智能体

适配系统:Windows10 64 位(纯小白友好版) 核心优势:免命令行、免环境配置、解压即装,内置所有运行依赖,全程可视化操作,新手也能一次成功部署 2026 爆火的开源 AI 智能体! 本文专属&…...

不知道怎么挖漏洞?吐血整理40个网络安全漏洞挖掘姿势,看完不信你还挖不到

各位靓仔,搞网络安全,就像在雷区蹦迪,一不小心就BoomShakalaka!Web漏洞这玩意儿,说白了就是信任危机 验证掉链子。开发者们啊,总是对用户输入、权限边界和系统交互爱的太深,结果翻车了&#xf…...

Hyperf 高并发的庖丁解牛

它的本质是:**Hyperf 的高并发并非来自 PHP 语言本身的计算速度,而是来自对 I/O 等待时间 (I/O Wait Time) 的极致利用。它通过 Swoole/Swow 扩展 将传统的 同步阻塞 (Sync-Blocking) 模式转变为 异步非阻塞 (Async-Non-blocking) 模式,并利用…...

Linux运维:Jenkins部署

Jenkins 完整部署流程 一句话总结:Jenkins 是自动化流水线工具,把"代码提交→编译打包→测试→部署上线"全流程自动化,不用人工一步步操作。一、先搞懂核心逻辑 Jenkins 就像一个自动化机器人,你告诉它"代码提交后…...

STM32F103 平行替代方案全面分析(2026 年最新)

STM32F103 作为全球最经典的 Cortex-M3 MCU,凭借成熟的生态和广泛的应用基础统治了中低端嵌入式市场十余年。但近年来受国际供应链波动影响,其价格持续走高(2026 年 5 月 STM32F103C8T6 批量价约 8-12 元,部分型号甚至超过 20 元&…...

【设计模式 10】抽象工厂:整体换季

这一课讲抽象工厂模式。什么在变:整个产品族要一起换,不能一个一个换。怎么挡:定义完整的体系标准,切换等于整个体系一起换。 凌晨三点四十七分,林衍站在婴儿床边,觉得自己在打一场没有作战方案的仗。 小家…...

RX65N嵌入式开发实战:从硬件设计到外设驱动与调试

1. 项目概述:为什么选择RX65N作为嵌入式开发的起点?在嵌入式开发领域,选择一个合适的微控制器(MCU)作为学习和项目实践的起点至关重要。它既要功能足够强大以覆盖主流应用场景,又要有完善的生态支持&#x…...

初识C语言(一)

C语言的介绍 计算机语言 C语言是通用的计算机编程语言,广泛应用于底层开发(操作系统及以下)。 计算机语言可以分为三大类: 机器语言(二进制,可直接被机器识别)汇编语言(用助记符来…...

嵌入式Linux下MT7601U无线网卡驱动移植与网络配置实战

1. 项目概述最近在做一个基于Linux 3.5内核的嵌入式项目,需要让开发板通过USB接口连接无线网络。手头正好有几个闲置的360随身WiFi,查了一下,它的核心芯片是联发科(MediaTek)的MT7601U,这是一款非常经典的U…...

水质在线监测系统嵌入式工控机选型与实战指南

1. 水质在线监测:从传统抽检到智慧物联的必然之路水,是生命之源,也是城市运行的命脉。过去,我们了解水源地的水质状况,主要依赖人工定期采样、送回实验室分析。这种方式周期长、成本高,面对突发性污染事件&…...

从0到1:企业级AI项目迭代日记 Vol.29|自然语言变工作流:Agent 自动拼装子图的实现路径

把一件复杂的事做简单,有两种方式:降低门槛,或者让别人替你做。团队选择了后者。那个“别人”,是我们自己的 AI。一、工作流太难配,所以让 Agent 来配昨天上线了工作流初版,可视化节点编排,支持…...

5G手机省电的秘密:一文搞懂NR C-DRX中的Inactivity Timer(附工作流程图解)

5G手机续航优化的核心技术:深入解析C-DRX中的Inactivity Timer机制 当你在咖啡厅刷社交媒体时,是否注意到手机屏幕熄灭后仍能即时收到消息?这种"随叫随到"的体验背后,是5G NR中一项精妙的省电技术——C-DRX(…...

告别手动摆放!UE5.2+PCG插件:程序化实现枯木生蘑菇、岩石长苔藓的生态细节

UE5.2程序化生态细节:用PCG插件实现枯木生蘑菇的魔法 当游戏场景中的枯木自动长出蘑菇,岩石表面自然覆盖苔藓时,这种生态细节的呈现往往能让虚拟世界瞬间"活"起来。传统手动摆放的方式不仅耗时耗力,更难以实现自然生长的…...

短剧进军韩国:外卡收单+本地钱包,Antom助你打通“付费最后一公里”

韩国短剧市场正以惊人的速度崛起。2024年,韩国短剧市场规模已达4.9亿美元,全球排名第4,预计未来将突破15亿美元。中国出海平台如DramaBox、ShortMax、ReelShort等早已抢先布局,在下载榜和收入榜上占据大半江山。然而,流…...

地平线6正式上线!UU远程云电脑工作日也能全高画质飙车

《极限竞速:地平线6》5月18日正式全球发售!该作将舞台设在超燃的日本东京,从东京涩谷的霓虹璀璨,到秋名山的晨雾缭绕与漂移快感;从北海道的茫茫雪原越野,到富士山下的樱花赛道浪漫驰骋,每一处场景都细节拉满…...

[260520] x-cmd v0.9.5:x install 支持 skill 安装,新增 git ci 命令让 AI 帮你写 commit

[260520] x-cmd v0.9.5:x install 支持 skill 安装,新增 git ci 命令让 AI 帮你写 commit x install 全面升级:支持 skill 安装、前缀语法、三种自动化模式、AI Agent 友好选项x git ci/commit 支持 AI 自动生成 Conventional Commits 提交信…...

手把手教你用YOLOv5/PyTorch在DOTA V1.5数据集上训练自己的航拍目标检测模型

从零构建航拍目标检测模型:YOLOv5DOTA V1.5实战指南 当无人机镜头掠过城市上空,传回的40004000像素高清图像中,棒球场、港口集装箱、高速公路立交桥等目标如何被精准识别?本文将带您用YOLOv5框架,在包含18.8万实例的DO…...

离线绘图新选择:draw.io桌面版,让敏感数据不再“上网”

离线绘图新选择:draw.io桌面版,让敏感数据不再“上网” 【免费下载链接】drawio-desktop Official electron build of draw.io 项目地址: https://gitcode.com/GitHub_Trending/dr/drawio-desktop 你是否曾因为网络不稳定而无法绘制重要的流程图&…...

背单词为什么不背词典:CANN上FlashAttention的分块逻辑

上个月有个实习生问我,为什么昇腾CANN的ops-transformer仓库里,FlashAttention算子比标准实现快那么多。我说你先想一个问题:背四级单词,你是把整本词典摊开从头背,还是一次看一页?他说当然是看一页。我说对…...

汽车质量管理体系的核心要素与持续改进之道

在当今竞争激烈的汽车制造业中,质量管理体系不仅是确保产品品质的基石,更是引领行业迈向智能制造未来的关键。作为制造业的核心,质量管理体系能够帮助企业在产品研发、生产制造和售后服务等环节发现并解决问题,提升产品质量和用户…...

别再只用labelme了!用ENVI 5.3的ROI工具给遥感影像打深度学习标签,保姆级避坑指南

遥感影像标注革命:ENVI ROI工具在深度学习标签制作中的专业实践 引言 在遥感影像分析与深度学习模型训练的工作流中,数据标注环节往往成为制约效率提升的关键瓶颈。传统标注工具如labelme虽然在小尺寸自然图像处理中表现出色,但当面对动辄数G…...

音乐学者紧急预警:Perplexity搜索结果偏差率高达47%?3步校验法立即挽救你的学术引用

更多请点击: https://intelliparadigm.com 第一章:音乐学者紧急预警:Perplexity搜索结果偏差率高达47%?3步校验法立即挽救你的学术引用 近期,由国际音乐学联合会(IMS)委托开展的交叉验证实验发…...

别再轮询了!Qt QSerialPort高效读取数据的正确姿势:理解缓冲区与readyRead触发机制

别再轮询了!Qt QSerialPort高效读取数据的正确姿势:理解缓冲区与readyRead触发机制 在嵌入式开发和硬件通信领域,串口通信作为最基础的通信方式之一,其稳定性和效率直接影响整个系统的性能表现。许多开发者在使用Qt的QSerialPort模…...

树莓派4B内存分配翻车实录:给GPU 512MB导致libcamera拍照报错‘内存不足’?

树莓派4B内存分配陷阱:GPU设置如何影响libcamera性能 树莓派4B作为一款功能强大的单板计算机,其8GB内存版本尤其受到开发者和创客的青睐。然而,许多用户在尝试使用libcamera进行高性能图像捕获时,会遇到一个令人困惑的问题&#x…...

Seaborn可视化从入门到精通:风格设置、调色板与常用图表详解

Seaborn可视化 Seaborn的介绍 简介 ​  Seaborn 是以 matplotlib为底层,更容易定制化作图的Python库。官网http://seaborn.pydata.org/ ​  Seaborn其实是在matplotlib的基础上进行了更高级的API封装,从而使得作图更加容易。在大多数情况下使用Seabo…...

蓝桥杯嵌入式第十届真题复盘:从CubeMX配置到EEPROM读写,我是如何一步步踩坑又爬出来的

蓝桥杯嵌入式第十届真题实战复盘:从CubeMX配置到EEPROM读写的深度解析 去年参加蓝桥杯嵌入式比赛的经历,至今回想起来仍让我心有余悸。第十届真题中的LED模块和EEPROM读写部分,堪称"嵌入式开发者的噩梦"。记得当时在实验室熬到凌晨…...