news 2026/5/27 5:36:28

基于NSGA-II的局部寻优算法探索

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于NSGA-II的局部寻优算法探索

根据NSGA-II改编的局部寻优算法。 加入了ZDT和DTLZ系列测试函数,IGD定值退出也加入到里面了。 下面是ZDT1和DTLZ4函数测试的部分图片。

最近在算法研究的道路上,我对NSGA-II算法进行了一番改造,开发出了一个独具特色的局部寻优算法。今天就来和大家唠唠这其中的门道。

NSGA-II的改编思路

NSGA-II(Non - dominated Sorting Genetic Algorithm II)本身就是多目标优化领域的经典算法,它在处理多目标问题时有着高效的非支配排序和拥挤度计算机制。但在实际应用中,有时候我们希望算法能够更聚焦于局部区域进行精细寻优。所以我在NSGA-II的基础上,对其选择、交叉和变异操作进行了调整。让算法在迭代过程中,以一定概率更关注当前种群中较优解周围的局部区域,而不是像原始算法那样较为均匀地在整个搜索空间中探索。

比如在选择操作上,原始NSGA-II是基于非支配排序和拥挤度选择个体进入下一代。而在我的局部寻优算法中,会额外引入一个局部性判断机制。对于当前种群中的每个个体,计算它与种群中最优个体的某种距离度量(比如欧氏距离),如果距离小于某个阈值,那么这些个体在选择时会有更高的优先级进入下一代,以此来促使算法在最优解附近进行局部探索。

# 简单示例代码,展示局部性判断机制在选择操作中的应用 import numpy as np # 假设种群个体的表示形式为二维数组,每一行代表一个个体,每一列代表一个维度 population = np.array([[1.2, 3.5], [2.1, 4.7], [0.8, 2.9], [1.9, 3.1]]) optimal_individual = np.array([1.0, 3.0]) threshold = 0.5 # 计算每个个体与最优个体的欧氏距离 distances = np.sqrt(np.sum((population - optimal_individual) ** 2, axis = 1)) # 根据距离筛选个体 local_individuals = population[distances < threshold] print(local_individuals)

在这段代码中,我们首先定义了一个简单的种群population,以及假设的最优个体optimalindividual和距离阈值threshold。通过计算每个个体与最优个体的欧氏距离distances,我们筛选出了距离小于阈值的局部个体localindividuals,这部分个体在后续的选择操作中就会有更高的机会进入下一代,实现局部寻优的倾向。

引入ZDT和DTLZ系列测试函数

为了更好地评估这个改编后的局部寻优算法的性能,我加入了ZDT和DTLZ系列测试函数。这些函数在多目标优化领域是非常经典的测试基准。

以ZDT1函数为例,它的定义如下:

\[

\begin{align*}

f1(x) &= x1\\

f2(x) &= g(x) \cdot (1 - \sqrt{\frac{f1(x)}{g(x)}})\\

g(x) &= 1 + 9 \cdot \frac{\sum{i = 2}^{n}xi}{n - 1}

\end{align*}

\]

其中 \(x \in [0, 1]^n\), \(n\) 是决策变量的维度。

下面是用Python实现ZDT1函数的简单代码:

import numpy as np def zdt1(x): n = len(x) f1 = x[0] g = 1 + 9 * np.sum(x[1:]) / (n - 1) f2 = g * (1 - np.sqrt(f1 / g)) return np.array([f1, f2])

这个函数接受一个一维数组x作为输入,代表决策变量的值。通过计算f1f2,返回两个目标函数的值。

DTLZ4函数相对来说稍微复杂一些,它的形式如下(以双目标,三维决策变量为例):

\[

\begin{align*}

f1(x) &= \prod{i = 1}^{m - 1}xi \cdot g(x) \cdot \cos(\frac{x{m - 1}\pi}{2})\\

f2(x) &= g(x) \cdot \sin(\frac{x{m - 1}\pi}{2})\\

g(x) &= 1 + 10(m - 1) + \sum{i = m - 1}^{n}(xi^2 - 10 \cos(4 \pi x_i))

\end{align*}

\]

import numpy as np def dtlz4(x): n = len(x) m = 2 # 目标数 g = 1 + 10 * (m - 1) for i in range(m - 1, n): g += x[i] ** 2 - 10 * np.cos(4 * np.pi * x[i]) f1 = np.prod(x[:m - 1]) * g * np.cos(x[m - 1] * np.pi / 2) f2 = g * np.sin(x[m - 1] * np.pi / 2) return np.array([f1, f2])

通过使用这些测试函数,我们可以直观地观察到算法在不同复杂程度的多目标问题上的表现,比如算法是否能够找到均匀分布且逼近真实Pareto前沿的解集。

IGD定值退出机制

在算法运行过程中,我还加入了IGD(Inverted Generational Distance)定值退出机制。IGD是一种用于衡量多目标优化算法得到的解集与真实Pareto前沿之间距离的指标。简单来说,它计算得到的解集中每个点到真实Pareto前沿的最小距离的平均值。

当算法运行到一定阶段,如果IGD的值小于我们预先设定的某个定值,这意味着算法得到的解集已经足够接近真实Pareto前沿,继续运行下去可能不会带来显著的提升,此时就可以终止算法,节省计算资源。

以下是一个简单的IGD计算的概念性代码(假设已知真实Pareto前沿trueparetofront和算法得到的解集solution_set):

import numpy as np def calculate_igd(solution_set, true_pareto_front): igd_sum = 0 for point in solution_set: min_dist = np.min(np.sqrt(np.sum((true_pareto_front - point) ** 2, axis = 1))) igd_sum += min_dist igd = igd_sum / len(solution_set) return igd # 假设已经有了真实Pareto前沿和算法得到的解集 true_pareto_front = np.array([[0.1, 0.9], [0.2, 0.8], [0.3, 0.7]]) solution_set = np.array([[0.15, 0.85], [0.25, 0.75]]) igd_value = calculate_igd(solution_set, true_pareto_front) print(igd_value)

在实际应用中,我们会在算法的每次迭代后计算IGD值,并与预设的定值进行比较。如果igd_value小于定值,就终止算法。

最后附上ZDT1和DTLZ4函数测试的部分图片(这里由于无法直接展示图片,大家可以想象一下,在ZDT1函数测试图片中,Pareto前沿呈现出一条平滑的曲线,算法得到的解集点在曲线上分布,越靠近真实前沿,说明算法性能越好;而DTLZ4函数测试图片中,由于其函数特性,Pareto前沿可能更为复杂,算法解集点的分布情况则反映了算法在处理复杂多目标问题时的能力)。

通过对NSGA-II的改编,引入经典测试函数以及IGD定值退出机制,这个局部寻优算法在多目标优化问题上展现出了独特的优势和潜力。希望今天的分享能给大家在算法研究和优化方面带来一些启发。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/24 3:27:52

医疗边缘用PyTorch Mobile部署稳住推理

&#x1f4dd; 博客主页&#xff1a;jaxzheng的CSDN主页 医疗边缘计算的革新&#xff1a;PyTorch Mobile如何稳住推理性能目录医疗边缘计算的革新&#xff1a;PyTorch Mobile如何稳住推理性能 引言&#xff1a;医疗边缘计算的紧迫需求 一、技术应用场景与应用价值&#xff1a;从…

作者头像 李华
网站建设 2026/5/20 17:07:50

数据科学家实战:当Jupyter Notebook报错Conda不可用时

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个数据科学工作环境修复工具&#xff0c;专门针对Conda不是内部命令错误设计以下功能&#xff1a;1.提供紧急解决方案&#xff08;使用pip临时替代&#xff09;2.生成Docker…

作者头像 李华
网站建设 2026/5/20 11:52:07

CRNN OCR在财务报表处理的效率提升

CRNN OCR在财务报表处理的效率提升 &#x1f4d6; 项目简介&#xff1a;为何选择CRNN进行OCR识别&#xff1f; 在财务数字化转型过程中&#xff0c;非结构化数据的自动化提取是核心挑战之一。传统人工录入方式不仅耗时耗力&#xff0c;还容易出错。而通用OCR技术虽然已广泛应…

作者头像 李华
网站建设 2026/5/21 12:12:51

成本优化指南:如何在Llama Factory训练中选择最经济的GPU配置

成本优化指南&#xff1a;如何在Llama Factory训练中选择最经济的GPU配置 作为一名预算有限的开发者&#xff0c;你可能经常面临这样的困境&#xff1a;既想充分利用Llama Factory的强大功能进行大模型微调&#xff0c;又希望尽可能节省GPU资源开销。本文将为你提供一套实用的G…

作者头像 李华
网站建设 2026/5/20 21:19:54

Llama Factory黑科技:免配置实现大模型微调与API部署一站式方案

Llama Factory黑科技&#xff1a;免配置实现大模型微调与API部署一站式方案 作为一名技术团队的负责人&#xff0c;你是否遇到过这样的困境&#xff1a;产品急需接入大语言模型能力&#xff0c;但团队缺乏专业的AI部署经验&#xff0c;从环境配置到API封装每一步都举步维艰&…

作者头像 李华
网站建设 2026/5/21 0:22:47

从零到英雄:学生党如何用Llama Factory快速完成机器学习课设

从零到英雄&#xff1a;学生党如何用Llama Factory快速完成机器学习课设 作为一名计算机专业的学生&#xff0c;期末项目总是让人又爱又恨。特别是当项目涉及大模型微调时&#xff0c;光是搭建环境就足以让人头疼。最近我也遇到了同样的问题&#xff0c;学校的GPU资源需要排队&…

作者头像 李华