首页 > 编程语言 >SDC可伸缩的高维约束基准和算法

SDC可伸缩的高维约束基准和算法

时间:2024-03-28 09:12:34浏览次数:36  
标签:伸缩 变量 约束 算法 SDC 维度 优化 高维 函数

可伸缩的高维约束基准和算法

​ 在过去二十年里,进化约束多目标优化受到了广泛的关注和研究,并且已经提出了一些基准测试约束多目标进化算法(CMOEAs)。特别地,约束函数与目标函数值有紧密的联系,这使得约束特征太单调并且与真实世界的问题不同。因此,之前的CMOEAs不能特别好的解决现实问题,这些问题涉及多态或者非线性特征的决策空间约束。因此,我将介绍一个新的基准框架和设计一个合适的可伸缩的高维决策空间约束的新测试函数。具体来说,不同的高维约束函数和变量之间的复杂联系与现实特征都有紧密联系。在这个框架里,提供了许多的参数接口,以便用户可以比较容易地调整参数获得不同的函数,并且可以测试算法的性能。现已存在不同类型的CMOEAs被用来测试已经提出的测试函数,但是结果很容易陷入局部可行区域。因此我也会介绍一个基于多任务CMOEA去更好的处理这些问题,这个算法有一个新的搜索算法去提高种群的搜索能力。

SDC基准

​ SDC(Scalable High-Dimensional Constraint)有以下特征:

  1. 在决策空间中构造约束,以便建立单峰或多峰约束;
  2. 可伸缩变量与距离函数相关,这可以使约束困难可调节;
  3. 可伸缩变量与距离函数相关,这可以使收敛性困难得到调节;
  4. 设置CPF(Constraint Pareto Front)和UPF(unconstraint Pareto Front)之间的重叠度来测试算法局部调整种群分布的能力

SDC框架

如图所示,SDC框架可以定义不同的层次和把变量分成不同的组。

Objective level:在这个层次里,变量被分为两部分,形状函数变量和距离函数变量。形状函数变量用于形状函数,这可以控制UPS(unconstraint Pareto Solution)与UPF(unconstraint Pareto Front)的形状和位置。距离函数变量用于距离函数,以便增加收敛难度。

Variable linkage level:为了强制变量联动使距离函数的最优解旋转,距离函数变量通常与形状函数变量中的第一个变量相关联。因此,我们把距离函数变量分为两部分,并且只有后一部分是强制变量联动。

Constraint level:在这个层里,变量 x1s,…,xa1s 被改写为 x1lc,…,xa1lc,因为它们被用来构造低维度约束变量(LCV)。LCV是用在低维度约束函数中,它可以控制CPS的位置和形状。除此之外,为了提高约束的复杂性,引入了高维度约束,并且与高维度约束相关的变量 x1hc,…,xa2hc(HCV(high-dimension constraint variable))。可伸缩HCV x1sc,…,xa3,1sc(SHCV(Scalable HCV))可通过转化操作变为THCV(transformed HCV)。

​ 基于以上定义,可以生成以下测试函数公式:

d1是CEC2006的约束问题,d2是距离函数,g1和g2分别代表低维度约束和高维度约束。

​ SDC框架里的一些重要观点:

  1. 统一的搜索空间:可以看出 xsc 与 xthc 和 xud 都有关系,因此,最优解 xsc,* 应当同时满足 d2== 0 和 g2 == 0。然而,d2 和 g2 可能有不同的搜索范围。为了使不同范围的形状函数、约束函数和距离函数能在SDC 框架中使用,需要定义一个统一的搜索空间。每一个变量有一个固定的范围 [0 , 1]。当计算任何形状、约束和距离函数,首先将变量从统一搜索空间映射到真正的搜索范围。除此之外,变量联动和转化操作都在统一搜索空间实现。
  2. 高维约束函数和距离函数的难度分离控制:现已存在的形状函数和高维度约束函数,它们都有一个固定的维度,例如,a1 和 a2 是固定的。因此对一个D维向量, a3是固定的。当 a3,1 增加,a3是固定的,g2 的难度将会增加,而 d2 将不会改变。同样的,当a3,1 固定,a3 增加时,g2 的难度将不会改变,而d2 的难度将会增加。因此,高维度约束函数和距离函数的难度可以控制。
  3. 高维度约束的可伸缩难度:因为CEC2006 函数不可伸缩,它的难度直接调整。为了使它可伸缩,我们使用SHCV 和HCV 获得 THCV,如下图所示。

形状函数(shape functions)

​ 形状函数( h(xs)) 的作用是控制UPF的位置和形状。除此之外,当约束 g1(xlc) 增加时,可以控制CPF的位置和形状。因此,我们可以控制CPF 和 UPF 的关系来检验算法局部调整种群分布的能力。这里有两种调整函数,其中一个的公式如下:

参数 b 可以控制可行区域的位置,不同的值可以使得可行域旋转。另一个调整函数的公式如下:

参数b 可以控制UPF 和 CPF 之间的重叠度,不同的值可以改变可行区域。

高维度约束函数

​ 选择高维度约束函数一会重要的问题是接近现实问题的实质。CEC2006 函数集可以满足真实的约束多目标优化问题,除此之外,CEC2006 函数提高了优化可行目标值。

转换函数

​ 为了保证优化解得到存在,xthc 的范围应该在[0 , 1]。上图中的xt 代表参与转换操作的变量集,这里设计了两种转换函数:

距离函数

​ 如图所示,提供了五个距离函数。

​ 除此之外,变量的联系函数在决策空间不同位置中被用来改变最优解,这里也有两种函数:

在公式中,这里设置了一个参数(DTC)来控制 [DCT * xd,2]中的xd,2变量参与变量的联系。

IMCMO算法

  1. 动态辅助任务分配
    • 算法中引入了辅助任务,为每个主任务分配一个动态变化的辅助任务。
    • 辅助任务的目的是帮助共享和传递有价值的信息,以提高整体优化性能。
  2. 多目标优化
    • 该算法专注于同时处理多个目标函数,以便获得一组帕累托最优解。
    • 通过维护帕累托最优解集合来实现多目标优化的目标。
  3. 演化多任务学习
    • 算法利用演化多任务学习的方法,通过任务间的知识共享来提高收敛速度和全局搜索能力。
    • 任务之间的交叉和突变促进信息传递,有助于优化过程中各任务之间的协作。
  4. 约束处理
    • 对于受约束的多目标优化问题,算法设计了有效的约束处理策略。
    • 这可能涉及罚函数、约束处理技术等方法,以确保生成的解满足所有的约束条件。
  5. 动态性与自适应性
    • 该算法具有一定的动态性和自适应性,可以根据优化过程中的需求和变化来调整任务分配和资源分配策略。
    • 动态地适应不同的优化场景,并根据需要灵活调整算法参数。

通过结合多目标优化、动态任务分配和演化多任务学习等技术,这种算法能够有效解决受约束的多目标优化问题,并在复杂的优化环境中取得良好的性能表现。

以下是算法伪代码:


标签:伸缩,变量,约束,算法,SDC,维度,优化,高维,函数
From: https://www.cnblogs.com/cxj666/p/18100734

相关文章

  • 高维前缀和/SOS DP 学习笔记
    JOISC2023D2T2Council注意到,钦定一个人为主席后,对于此时得票数大于\(\lfloor\frac{n}{2}\rfloor\)的议案,不管怎么选副主席,均能通过;对于此时得票数小于\(\lfloor\frac{n}{2}\rfloor\)的议案,不管怎么选副主席,均不能通过。所以需要考虑的只有此时得票数恰好等于\(\lfloo......
  • 浅记高维前缀和
    考虑如下问题:记\(y\subsetx\leftrightarrowx\&y=y\)。若\(x\subsety\),称\(x\)为\(y\)的一个子集,\(y\)为\(x\)的一个超集。给定数组\(f\),求数组\(g\)。其中\(g_x=\sum_{y\subsetx}{f_y}\)。设\(f\)中最大的数二进制下共有\(n\)位。如果直接枚举子集的话,时......
  • 高维前缀和(SOS DP)
    引入方法在讨论高维前缀和前,不妨先回顾以下二维前缀和,一种写法是:for(inti=1;i<=w;i++) for(intj=1;j<=w;j++)sum[i][j]+=sum[i][j-1]for(inti=1;i<=w;i++) for(intj=1;j<=w;j++)sum[i][j]+=sum[i-1][j]推广......
  • 如何基于容器网络流量指标进行弹性伸缩
    本文分享自华为云社区《【自定义指标HPA】基于容器网络流量指标进行弹性伸缩》,作者:可以交个朋友。一、背景业务程序非CPU、memeory敏感类业务,希望可以基于流量指标进行HPA弹性伸缩,但是大部分程序并没有集成PrometheusSDK相关代码进行插桩。此时可以通过cAdvisor提供的容器网......
  • RDS for MySQL Serverless公测上线:弹性伸缩,最高可降成本超80%
    本文分享自华为云社区《RDSforMySQLServerless公测上线:弹性伸缩,最高可降成本超80%》,作者:GaussDB数据库。随着科技的快速发展,我们正在迅速步入一个全新的数字化时代。数字化时代,数据是最宝贵的资源。数据库作为存储数据的仓库,重要性更是不言而喻。一、业务背景及痛点为了确......
  • 传统套路只能处理低维问题,机器学习数学理论的关键是高维函数
    与传统方法相比,机器学习解决的最基本的问题就是函数的表达和逼近。数学上有分片多项式、傅利叶级数、小波……这都是传统的表达函数的套路。但传统套路只能处理低维问题,难以处理高维问题。而机器学习,尤其是深度学习,解决的许多问题都是非常高维的,所以机器学习数学理论的关键是高维......
  • 在K8S中,当Pod业务量比较大时候,如何实现水平伸缩和扩容?
    在Kubernetes中,当Pod的业务量比较大时,可以通过水平伸缩(HorizontalPodAutoscaling,HPA)和扩容(Scaling)来实现动态的资源管理。以下是实现水平伸缩和扩容的一些步骤和方法:1.水平伸缩(HorizontalPodAutoscaling,HPA)水平伸缩允许你根据一些指标(如CPU使用率、内存使用率、自定义......
  • Go语言精进之路读书笔记第36条——使用atomic包实现伸缩性更好的并发读取
    atomic包提供了两大类原子操作接口:一类是针对整型变量的,包括有符号整型、无符号整型以及对应的指针类型;另一个类是针对自定义类型的。atomic包十分适合一些对性能十分敏感、并发量较大且读多写少的场合。如果要对一个复杂的临界区数据进行同步,那么首选依旧是sync包中的原语。36.......
  • P9562 [SDCPC2023] G-Matching 题解
    题目描述给定长度为\(n\)的整数序列\(a_1,a_2,\cdots,a_n\),我们将从该序列中构造出一张无向图\(G\)。具体来说,对于所有\(1\lei<j\len\),若\(i-j=a_i-a_j\),则\(G\)中将存在一条连接节点\(i\)与\(j\)的无向边,其边权为\((a_i+a_j)\)。求\(G\)的一个......
  • 高维前缀和(SOS DP)
    高维前缀和(SOSDP)通常求二维前缀和,用容斥来求但其实,完全可以先做一遍行的前缀和,再做一遍列的前缀和拓展到\(k\)维也是如此,可以在\(O(nk)\)的复杂度求前缀和但怎么和DP扯上关系?可以把第\(i\)维当作阶段,每一维的具体信息是状态先枚举阶段,表示当前固定其它维,只统计这一......