CN103927580A - 一种基于改进人工蜂群算法的工程约束参数优化方法 - Google Patents

一种基于改进人工蜂群算法的工程约束参数优化方法 Download PDF

Info

Publication number
CN103927580A
CN103927580A CN201410172296.5A CN201410172296A CN103927580A CN 103927580 A CN103927580 A CN 103927580A CN 201410172296 A CN201410172296 A CN 201410172296A CN 103927580 A CN103927580 A CN 103927580A
Authority
CN
China
Prior art keywords
search
parameter
honeybee
nectar source
bee colony
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201410172296.5A
Other languages
English (en)
Other versions
CN103927580B (zh
Inventor
高伟
赵博
姜鑫
周广涛
郝勤顺
孙艳涛
夏秀玮
刘学敏
于春阳
林萌萌
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Harbin Engineering University
Original Assignee
Harbin Engineering University
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Harbin Engineering University filed Critical Harbin Engineering University
Priority to CN201410172296.5A priority Critical patent/CN103927580B/zh
Publication of CN103927580A publication Critical patent/CN103927580A/zh
Application granted granted Critical
Publication of CN103927580B publication Critical patent/CN103927580B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Medicines Containing Material From Animals Or Micro-Organisms (AREA)

Abstract

本发明公开一种基于改进人工蜂群算法的工程约束参数优化方法。该方法用目标函数和等式(或不等式)约束描述工程约束参数优化问题;根据参数取值范围,初始化人工蜂群;以概率M选取参数向量中部分参数作为调整对象,自适应调节搜索步长,令引领蜂在邻域内随机搜索蜜源;跟随蜂根据各蜜源对应的代价函数值fi,由fi获取适应度函数值fiti,进而得到转移至各蜜源概率Pi,并判断是否进行位置更新;在每次迭代搜索过程中,记录当前的最优解,经过有限次迭代搜索,得到参数的最优估计值。本发明使搜索步长随搜索次数自适应变化,在不影响搜索准确度的前提下,有效地减少搜索时间,提高搜索效率。

Description

一种基于改进人工蜂群算法的工程约束参数优化方法
技术领域
本发明属于智能算法应用技术领域,尤其涉及一种基于改进人工蜂群算法的工程约束参数优化方法。
背景技术
工程参数优化问题广泛地存在于人们的生产生活中,一般来说,工程参数优化问题都是在许多线性或非线性约束的前提下。但是,由于目前我们对工程约束参数优化问题的求解方法认识还不够深入,还不能像非约束问题那样,把所涉及的模型优化全部转化为线性或非线性方程的求解。因此,需要一种不依赖于系统模型的具体表达方式的约束参数优化方法。
为了解决这一问题,之前很多学者将智能算法(例如:神经网络、遗传算法、粒子群算法等)应用到工程约束参数优化问题中。但是,如果搜索空间不可微或参数间为非线性,则往往得不到全局最优解,即陷入局部最优。因此,全局搜索和局部搜索的平衡机制对优化算法的成功是很重要的。此外,像神经网络这种结构复杂、搜索效率低等问题,总之,传统的工程约束参数优化方法存在诸多不令人满意的问题,难以满足工程约束参数优化的需求。但是,随着智能算法的迅速发展及其在工程应用的日渐广泛,工程约束参数优化问题在计算效率和计算精度上还仍有较大的提升空间。
发明内容
本发明的目的在于提供一种解决一般工程约束参数优化方法存在结构复杂难以确定、局部最优、搜索效率低等缺点的基于改进人工蜂群算法的工程约束参数优化方法。
本发明的目的是这样实现的:
基于改进人工蜂群算法的工程约束参数优化方法,包括以下步骤:
步骤一:确定参数向量及其取值范围,用目标函数和等式或不等式进行描述;
步骤二:根据步骤一中确定的参数向量的个数和取值范围,初始化人工蜂群,确定最大限制迭代次数Limit、最大循环次数MaxCycles及搜索目标参数个数D,令引领蜂在初始位置邻域内随机地搜索蜜源;
所涉及的引领蜂初始位置表达式为:
式中,Rij为0到1之间的随机数,N为0到1之间的设定值;i=1...SN,j=1...D,SN为蜜源的个数,为第j个参数的最小取值,为第j个参数的最大取值,rand(0,1)表示0到1范围内的随机数;
所涉及的引领蜂初始位置邻域位置表达式为:
其中,xij为引领蜂初始位置,vij为引领蜂邻域搜索位置,φij为参数搜索步长,取值范围为[-SF,SF],SF为0到1之间的可调参数;
所涉及的SF的表达式为:
SF i ( t ) = SF i - 1 ( t ) * ( 1 + cos φ ) , if cos φ > 0 SF i - 1 ( t ) / ( 2 - cos φ ) , if cos φ ≤ 0
步骤三:以概率M选取步骤一中确定的参数向量中部分参数作为调整对象,引入参数M控制搜索过程中改变参数向量中参数的个数,并自适应调节搜索步长参数SF,令引领蜂在当前蜜源邻域内随机搜索新的蜜源,获取各蜜源的代价函数值fi,由fi计算适应度函数值fiti,如果搜索位置的适应度函数值大于当前蜜源的适应度函数值,则转移至新的蜜源,引领蜂在新的蜜源附近搜索并记录适应度函数值较大的蜜源位置;
所涉及的M表达式为:
M=e-α·c/MaxCycles
其中,c为蜂群循环次数,MaxCycles为最大循环次数,α为控制参数;
所涉及的适应度函数值fiti表达式为:
fit i = 1 / ( 1 + f i ) if f i &GreaterEqual; 0 1 + abs ( f i ) if f i < 0
式中,abs()为取绝对值函数;
步骤四:待所有引领蜂搜索结束,根据各引领蜂所在蜜源的适应度函数值fiti,得到跟随蜂转移至各蜜源概率Pi,依据概率进行位置更新,并记录每次蜂群迭代搜索过程中的适应度函数值最大的蜜源位置xbest
所涉及的转移概率Pi表达式为:
P i = e - &beta; &CenterDot; c / MaxCycles &CenterDot; fit i &Sigma; i = 1 SN fit i + ( 1 - e - &beta; &CenterDot; c / MaxCycles ) &CenterDot; fit i - fit min &Sigma; i = 1 SN ( fit i - fit min )
其中,fitmin为本次循环后适应度函数值最小值,β为调整因子;
步骤五:重复步骤三、步骤四,经过有限次循环搜索,得到参数的最优估计值。
当迭代次数大于最大限制迭代次数Limit时,要放弃所在蜜源,同时由侦察蜂代替引领蜂产生一个新的位置。
根据权利要求1所述的基于改进人工蜂群算法的工程约束参数优化方法,其特征在于,当参数超出其最大取值范围时,将该参数设定为该边界的最大值或最小值。
本发明的有益效果在于:
在标准人工蜂群算法中,蜂群搜索过程只改变某一个参数,即只在一维空间搜索,本发明在搜索过程中对每个参数都以一定概率判断是否进行更新,使搜索范围扩展到多维空间,大大提高蜂群的搜索能力。蜂群搜索步长为定值,但实际中,随着搜索次数增加,搜索范围不断改变,搜索步长也要自适应变化,本发明使搜索步长随搜索次数自适应变化,在不影响搜索准确度的前提下,有效地减少搜索时间,提高搜索效率。跟随蜂根据概率选择食物源是按轮盘赌的方式,但是轮盘赌的选择方式容易导致群体多样性的下降,算法将过早收敛。针对不同阶段需要不同的选择压力,本发明改变跟随蜂选择引领蜂的转移概率,既保证蜂群的多样性,又加快参数估计的收敛速度。
附图说明
图1是本发明的方法流程图;
图2是本发明提供的蜂群变步长搜索示意图;
图3是本发明提供的伸缩绳结构示意图;
图4是本发明提供的标准蜂群算法和改进蜂群算法对工程约束参数优化效果对比图;
具体实施方式
下面结合附图对本发明作进一步的描述。
本发明针对标准人工蜂群算法的搜索策略和选择策略进行改进,充分发挥人工蜂群算法的搜索能力和开发能力,并将改进后的人工蜂群搜索算法应用到工程约束参数优化过程,避免局部最优情况出现,同时,保证一定的收敛速度和收敛精度。
本发明包括以下几个步骤:
步骤一:针对具体工程约束参数优化问题,确定参数向量及其取值范围,用目标函数和等式(或不等式)进行描述;
步骤二:根据参数向量的个数和取值范围,初始化人工蜂群,确定最大限制迭代次数Limit、最大循环次数MaxCycles及搜索目标参数个数D,令引领蜂在初始邻域内随机地搜索蜜源;
步骤三:以概率M选取参数作为调整对象,并自适应调节搜索步长,令引领蜂在当前蜜源邻域内随机搜索新的蜜源,获取各蜜源的代价函数值fi,由fi计算适应度函数值fiti,如果搜索位置的适应度函数值大于当前蜜源的适应度函数值,则转移至新的蜜源;
步骤四:待所有引领蜂搜索结束,根据各引领蜂所在蜜源的适应度函数值fiti,得到跟随蜂转移至各蜜源概率Pi,依据概率进行位置更新;
步骤五:若选择蜜源,则转化为引领蜂搜索新的蜜源,同时在蜜源附近搜索并记录适应度函数值较大的蜜源位置;
步骤六:如果迭代次数大于最大限制迭代次数Limit,得到的最优解仍没有变化,要放弃所在蜜源,同时由侦察蜂代替引领蜂产生一个新的位置;
步骤七:如果某一参数超过其最大取值范围,应将该参数设定为该边界的最大值或最小值;
步骤八:记录每次蜂群迭代搜索过程中的适应度函数值最大的蜜源位置xbest,重复步骤三至步骤七,经过有限次循环搜索,得到参数的最优估计值。
各步骤具体为:
一种基于改进人工蜂群算法的工程约束参数优化方法,实时参数估计方法包括以下步骤:
步骤一:针对具体工程约束参数优化问题,确定参数向量及其取值范围,用目标函数和等式(或不等式)进行描述;
步骤二:根据参数向量的个数和取值范围,初始化人工蜂群,确定最大限制迭代次数Limit、最大循环次数MaxCycles及搜索目标参数个数D,令引领蜂在初始邻域内随机地搜索蜜源;
步骤三:以概率M选取参数作为调整对象,并自适应调节搜索步长,令引领蜂在当前蜜源邻域内随机搜索新的蜜源,获取各蜜源的代价函数值fi,由fi计算适应度函数值fiti,如果搜索位置的适应度函数值大于当前蜜源的适应度函数值,则转移至新的蜜源;
步骤四:待所有引领蜂搜索结束,根据各引领蜂所在蜜源的适应度函数值fiti,得到跟随蜂转移至各蜜源概率Pi,依据概率进行位置更新;
步骤五:若选择蜜源,则转化为引领蜂搜索新的蜜源,同时在蜜源附近搜索并记录适应度函数值较大的蜜源位置;
步骤六:如果迭代次数大于最大限制迭代次数Limit,得到的最优解仍没有变化,要放弃所在蜜源,同时由侦察蜂代替引领蜂产生一个新的位置;
步骤七:如果某一参数超过其最大取值范围,应将该参数设定为该边界的最大值或最小值;
步骤八:记录每次蜂群迭代搜索过程中的适应度函数值最大的蜜源位置xbest,重复步骤三至步骤七,经过有限次循环搜索,得到参数的最优估计值。
在步骤一中,针对具体工程约束问题,确定参数向量及其取值范围,用目标函数和等式(或不等式)进行描述,一般工程上的约束参数指的是零件的机械结构尺寸,例如:长度、直径、齿数等,目标函数一般为面积、体积、重量等,一个工程约束问题可定义如下:
minf(x),x=(x1,x2,...,xn)∈Rn
s.t.gi(x)≤0,i=1,2,...,m
hj(x)=0,j=1,2,...,p
lk≤xk≤uk,k=1,2,...,n
其中,x=(x1,x2,...,xn)是参数向量,xi(i=1,...,n)为参数向量中某一具体参数,n为参数向量中参数的个数,m和p分别表示不等式约束和等式约束条件的个数,f(x)为目标函数,gi(x)≤0和hj(x)=0表示参数向量在n维空间上的边界条件约束,lk和uk分别表示xk的下界和上界。
在步骤二中,初始化人工蜂群,确定蜂群数量,其中一半为引领蜂,另一半为跟随蜂,设定最大限制迭代次数Limit、最大循环次数MaxCycles及搜索目标参数个数D。根据参数向量的取值范围,随机确定各引领蜂的初始位置,即
x ij = x j min + ranf ( 0,1 ) ( x j max - x j min )
其中,i=1...SN,j=1...D,SN为蜜源(引领蜂)的数量,D为参数向量中参数的个数,为第j个参数的最小取值,为第j个参数的最大取值,rand(0,1)表示0到1范围内的随机数。蜂群初始化后,令引领蜂在初始位置邻域内随机地搜索蜜源。
在步骤三中,根据一定概率选取参数向量中部分参数作为调整对象,在标准人工蜂群算法中,只进行一维参数变化,严重制约了搜索性能,考虑引入参数M控制搜索过程中改变参数向量中参数的个数。每个引领蜂进行搜索时,按下式进行参数变化
v ij = x ij + &phi; ij ( x ij - x kj ) if R ij < M x ij otherwise
其中,xij为引领蜂初始位置,vij为引领蜂邻域搜索位置,Rij为0到1之间的随机数,M为0到1之间的设定值,φij为参数搜索步长,取值范围为[-SF,SF],SF为0到1之间的可调参数。
当蜂群循环次数较小时,选取较大的M,保持蜂群的多样性,扩大搜索范围,加快搜索过程;当蜂群循环次数较大时,选取较小的M,缩小搜索范围,提高搜索稳定性,保证搜索的精度。因此,综合考虑蜂群搜索的速度和精度的影响,令M按下面的规律变化:
M=e-α·c/MaxCycles
其中,c为蜂群循环次数,MaxCycles为最大循环次数,α为控制参数。
此外,随迭代次数增加,自适应调整搜索步长调节参数SF,如图1所示,如果本次预想移动的方向与本次迭代最优解的方向基本一致则增大步长,否则减小步长,见图1,其中φ是蜂群移动方向与最优蜜源方向的夹角,xbest(t)是当前蜂群搜索到适应度值最大的位置。为了保证稳定性,限定步长最大不超过SFmax。令SF按下面规律变化
SF i ( t ) = SF i - 1 ( t ) * ( 1 + cos &phi; ) , if cos &phi; > 0 SF i - 1 ( t ) / ( 2 - cos &phi; ) , if cos &phi; &le; 0
跟随蜂根据各蜜源对应的代价函数值fi,由fi获取适应度函数值fiti
fit i = 1 / ( 1 + f i ) if f i &GreaterEqual; 0 1 + abs ( f i ) if f i < 0
式中,abs()为取绝对值函数。
将搜索到蜜源的适应度函数值(蜜量)与当前蜜源位置的适应度函数值进行比较,如果搜索蜜源的适应度函数值大于当前蜜源的适应度函数值,则转移至新的蜜源,否则,继续搜索新的蜜源。
在步骤四中,根据上面得到的适应度函数值fiti,获取转移至各蜜源概率Pi,在标准人工蜂群算法中,通过下式获取转移概率Pi
P i = f i &Sigma; j = 1 N f i
其中,N表示蜜源的个数。
在搜索最优解过程中,不同阶段的选择压力不同,当蜂群循环次数较小时,希望适应度相对较小的引领蜂也有机会招募到跟随蜂,使蜂群保持较高的种群多样性;当蜂群循环次数较大时,希望缩小搜索范围,加快搜索进度。
根据引领蜂的适应度函数值计算转移概率Pi,按下式计算:
P i = e - &beta; &CenterDot; c / MaxCycles &CenterDot; fit i &Sigma; i = 1 SN fit i + ( 1 - e - &beta; &CenterDot; c / MaxCycles ) &CenterDot; fit i - fit min &Sigma; i = 1 SN ( fit i - fit min )
其中,SN为蜜源的个数,fiti为第i个蜜源对应的适应度函数值,蜂群循环次数为c,fitmin为本次循环后适应度函数值最小值,MaxCycles为最大循环次数,β为调整因子。
跟随蜂按照上面的转移至个引领蜂概率Pi,选择其中某个引领蜂进行跟随,从而进行位置更新。
在步骤六中,如果经过一定次数迭代后,得到的最优解没有改进,要放弃所在蜜源,同时由侦察蜂代替引领蜂产生一个新的位置。在标准人工蜂群算法中,按下式确定新的位置
x ij = x j min + ranf ( 0,1 ) ( x j max - x j min )
其中,j为改变参数向量中某一个参数序号,分别表示当前蜂群指示的第j参数的最小值和最大值。
与引领蜂和跟随蜂一样,标准的人工蜂群算法只能进行一维参数搜索,为了提高蜂群的多样性,做出如下改进
v ij = x ij + &phi; ij ( x ij - x kj ) if R ij < M x ij otherwise
式中,Rij为0到1之间的随机数,M为0到1之间的设定值,与引领蜂搜索过程中取值一致,令M按下面的规律变化:
M=e-α·c/MaxCycles
其中,c为蜂群循环次数,MaxCycles为最大循环次数,α为控制参数,取值为5。
在步骤七中,如果参数向量中某一参数超过其最大取值范围,应将该参数设定为该边界的最大值或最小值,即
x ij = x j min if x ij < x j min x j max if x ij > x j max
其中,j为改变参数向量中某一个参数序号,分别表示当前蜂群指示的第j参数的最小值和最大值。
本发明的一种基于改进人工蜂群算法的工程约束参数优化方法,流程图如图2所示,包括以下几个步骤:
步骤一:针对具体工程约束参数优化问题,确定参数向量及其取值范围,用
目标函数和等式(或不等式)进行描述。
具体为,针对具体工程约束问题,确定参数向量及其取值范围,用目标函数
和等式(或不等式)进行描述,一般工程上的约束参数指的是零件的机械结构尺寸,例如:长度、直径、齿数等,目标函数一般为面积、体积、重量等,一个工程约束问题可定义如下:
minf(x),x=(x1,x2,...,xn)∈Rn
s.t.gi(x)≤0,i=1,2,...,m
hj(x)=0,j=1,2,...,p
lk≤xk≤uk,k=1,2,...,n
其中,x=(x1,x2,...,xn)是参数向量,xi(i=1,...,n)为参数向量中某一具体参数,n为参数向量中参数的个数,m和p分别表示不等式约束和等式约束条件的个数,f(x)为目标函数,gi(x)≤0和hj(x)=0表示参数向量在n维空间上的边界条件约束,lk和uk分别表示xk的下界和上界。
步骤二:根据参数向量的个数和取值范围,初始化人工蜂群,确定最大限制迭代次数Limit、最大循环次数MaxCycles及搜索目标参数个数D,令引领蜂在初始邻域内随机地搜索蜜源。
具体为,初始化人工蜂群,确定蜂群数量,其中一半为引领蜂,另一半为跟
随蜂,设定最大限制迭代次数Limit、最大循环次数MaxCycles及搜索目标参数个数D。根据参数向量的取值范围,随机确定各引领蜂的初始位置,即
x ij = x j min + rand ( 0,1 ) ( x j max - x j min )
其中,i=1...SN,j=1...D,SN为蜜源(引领蜂)的数量,D为参数向量中参数的个数,为第j个参数的最小取值,为第j个参数的最大取值,rand(0,1)表示0到1范围内的随机数。
蜂群初始化后,令引领蜂在初始位置邻域内随机地搜索蜜源。
步骤三:以概率M选取参数作为调整对象,并自适应调节搜索步长,令引领蜂在当前蜜源邻域内随机搜索新的蜜源,获取各蜜源的代价函数值fi,由fi计算适应度函数值fiti,如果搜索位置的适应度函数值大于当前蜜源的适应度函数值,则转移至新的蜜源。
具体为,根据一定概率选取参数向量中部分参数作为调整对象,在标准人工
蜂群算法中,只进行一维参数变化,严重制约了搜索性能,考虑引入参数M控制搜索过程中改变参数向量中参数的个数。每个引领蜂进行搜索时,按下式进行参数变化
v ij = x ij + &phi; ij ( x ij - x kj ) if R ij < M x ij otherwise
其中,xij为引领蜂初始位置,vij为引领蜂邻域搜索位置,Rij为0到1之间的随机数,M为0到1之间的设定值,φij为参数搜索步长,取值范围为[-SF,SF],SF为0到1之间的可调参数。
当蜂群循环次数较小时,选取较大的M,保持蜂群的多样性,扩大搜索范围,加快搜索过程;当蜂群循环次数较大时,选取较小的M,缩小搜索范围,提高搜索稳定性,保证搜索的精度。因此,综合考虑蜂群搜索的速度和精度的影响,令M按下面的规律变化:
M=e-α·c/MaxCycles
其中,c为蜂群循环次数,MaxCycles为最大循环次数,α为控制参数。
此外,随迭代次数增加,自适应调整搜索步长调节参数SF,如图1所示,如果本次预想移动的方向与本次迭代最优解的方向基本一致则增大步长,否则减小步长,见图2,其中φ是蜂群移动方向与最优蜜源方向的夹角,xbest(t)是当前蜂群搜索到适应度值最大的位置。为了保证稳定性,限定步长最大不超过SFmax。令SF按下面规律变化
SF i ( t ) = SF i - 1 ( t ) * ( 1 + cos &phi; ) , if cos &phi; > 0 SF i - 1 ( t ) / ( 2 - cos &phi; ) , if cos &phi; &le; 0
跟随蜂根据各蜜源对应的代价函数值fi,由fi获取适应度函数值fiti
fit i = 1 / ( 1 + f i ) if f i &GreaterEqual; 0 1 + abs ( f i ) if f i < 0
式中,abs()为取绝对值函数。
将搜索到蜜源的适应度函数值(蜜量)与当前蜜源位置的适应度函数值进行比较,如果搜索蜜源的适应度函数值大于当前蜜源的适应度函数值,则转移至新的蜜源,否则,继续搜索新的蜜源。
步骤四:待所有引领蜂搜索结束,根据各引领蜂所在蜜源的适应度函数值fiti,得到跟随蜂转移至各蜜源概率Pi,依据概率进行位置更新。
具体为,根据上面得到的适应度函数值fiti,获取转移至各蜜源概率Pi,在标准人工蜂群算法中,通过下式获取转移概率Pi
P i = f i &Sigma; j = 1 N f i
其中,N表示蜜源的个数。
在搜索最优解过程中,不同阶段的选择压力不同,当蜂群循环次数较小时,希望适应度相对较小的引领蜂也有机会招募到跟随蜂,使蜂群保持较高的种群多样性;当蜂群循环次数较大时,希望缩小搜索范围,加快搜索进度。
根据引领蜂的适应度函数值计算转移概率Pi,按下式计算:
P i = e - &beta; &CenterDot; c / MaxCycles &CenterDot; fit i &Sigma; i = 1 SN fit i + ( 1 - e - &beta; &CenterDot; c / MaxCycles ) &CenterDot; fit i - fit min &Sigma; i = 1 SN ( fit i - fit min )
其中,SN为蜜源的个数,fiti为第i个蜜源对应的适应度函数值,蜂群循环次数为c,fitmin为本次循环后适应度函数值最小值,MaxCycles为最大循环次数,β为调整因子。
跟随蜂按照上面的转移至个引领蜂概率Pi,选择其中某个引领蜂进行跟随,从而进行位置更新。
步骤五:若选择蜜源,则转化为引领蜂搜索新的蜜源,同时在蜜源附近搜索并记录适应度函数值较大的蜜源位置。
步骤六:如果迭代次数大于最大限制迭代次数Limit,得到的最优解仍没有变化,要放弃所在蜜源,同时由侦察蜂代替引领蜂产生一个新的位置。
具体为,如果迭代次数大于最大限制迭代次数Limit,得到的最优解仍没有变化,要放弃所在蜜源,同时由侦察蜂代替引领蜂产生一个新的位置。在标准人工蜂群算法中,按下式确定新的位置
x ij = x j min + rand ( 0,1 ) ( x j max - x j min )
其中,j为改变参数向量中某一个参数序号,分别表示当前蜂群指示的第j参数的最小值和最大值。
与引领蜂和跟随蜂一样,标准的人工蜂群算法只能进行一维参数搜索,为了提高蜂群的多样性,做出如下改进
v ij = x ij + &phi; ij ( x ij - x kj ) if R ij < M x ij otherwise
式中,Rij为0到1之间的随机数,M为0到1之间的设定值,与引领蜂搜索过程中取值一致,令M按下面的规律变化:
M=e-α·c/MaxCycles
其中,c为蜂群循环次数,MaxCycles为最大循环次数,α为控制参数,取值为5。
步骤七:如果某一参数超过其最大取值范围,应将该参数设定为该边界的最大值或最小值。
具体为,如果参数向量中某一参数超过其最大取值范围,应将该参数设定为
该边界的最大值或最小值,即
x ij = x j min if x ij < x j min x j max if x ij > x j max
其中,j为改变参数向量中某一个参数序号,分别表示当前蜂群指示的第j参数的最小值和最大值。
步骤八:记录每次蜂群迭代搜索过程中的适应度函数值最大的蜜源位置xbest,重复步骤三至步骤七,经过有限次循环搜索,得到参数的最优估计值。
实施过程:伸缩绳结构如图3所示,优化的目标是寻求满足最小偏差、切应力、湍振频率等一系列约束条件的多个决策变量,即平均卷直径D(x1)、线直径d(x2)和活动卷的数量p(x3),使得伸缩绳的重量最小。
伸缩绳问题的数学模型描述如下:
( x ) = ( x 3 + 2 ) x 2 x 1 2 , x = ( x 1 , x 2 , x 3 ) &Element; R 3
s . t . g 1 ( x ) = 1 - x 2 3 x 3 / ( 71785 x 1 4 ) &le; 0
g 2 ( x ) = ( 4 x 2 2 - x 1 x 2 ) / [ 12566 ( x 2 x 1 3 - x 1 4 ) ] + 1 / ( 5108 x 1 2 ) - 1 &le; 0
g 3 ( x ) = 1 - 140.45 x 1 / ( x 2 3 x 3 ) &le; 0
g4(x)=(x1+x2)/1.5-1≤0
0.05≤x1≤2,0.25≤x1≤1.3,3.2≤x1≤15
初始条件:人工蜂群数量N为100,最大限制次数Limit为50,最大循环次数为1000,目标参数个数为3,分别利用标准人工蜂群算法和改进后蜂群算法,在上述条件下进行对比仿真。
仿真结果见图4,仿真结果表明:在工程约束优化问题求解中,相比标准人工蜂群算法,改进后的蜂群算法的收敛时间明显缩短,即有效提高搜索效率,而且在收敛精度上也有较大提高。
从以上实施例不难看出,针对一般工程约束参数优化方法存在结构复杂难以确定、局部最优、搜索效率低等问题。本发明在标准人工蜂群算法的基础上,改进搜索策略和选择策略,充分发挥人工蜂群算法的搜索能力和开发能力,并将改进后的人工蜂群搜索算法应用到工程约束参数优化过程,避免局部最优情况出现,同时,保证一定的收敛速度和收敛精度。

Claims (2)

1.一种基于改进人工蜂群算法的工程约束参数优化方法,其特征在于,该方法包括以下步骤:
步骤一:确定参数向量及其取值范围,用目标函数和等式或不等式进行描述;
步骤二:根据步骤一中确定的参数向量的个数和取值范围,初始化人工蜂群,确定最大限制迭代次数Limit、最大循环次数MaxCycles及搜索目标参数个数D,令引领蜂在初始位置邻域内随机地搜索蜜源;
所涉及的引领蜂初始位置表达式为:
式中,Rij为0到1之间的随机数,N为0到1之间的设定值;i=1...SN,j=1...D,SN为蜜源的个数,为第j个参数的最小取值,为第j个参数的最大取值,rand(0,1)表示0到1范围内的随机数;
所涉及的引领蜂初始位置邻域位置表达式为:
其中,xij为引领蜂初始位置,vij为引领蜂邻域搜索位置,φij为参数搜索步长,取值范围为[-SF,SF],SF为0到1之间的可调参数;
所涉及的SF的表达式为:
SF i ( t ) = SF i - 1 ( t ) * ( 1 + cos &phi; ) , if cos &phi; > 0 SF i - 1 ( t ) / ( 2 - cos &phi; ) , if cos &phi; &le; 0
步骤三:以概率M选取步骤一中确定的参数向量中部分参数作为调整对象,引入参数M控制搜索过程中改变参数向量中参数的个数,并自适应调节搜索步长参数SF,令引领蜂在当前蜜源邻域内随机搜索新的蜜源,获取各蜜源的代价函数值fi,由fi计算适应度函数值fiti,如果搜索位置的适应度函数值大于当前蜜源的适应度函数值,则转移至新的蜜源,引领蜂在新的蜜源附近搜索并记录适应度函数值较大的蜜源位置;
所涉及的M表达式为:
M=e-α·c/MaxCycles
其中,c为蜂群循环次数,MaxCycles为最大循环次数,α为控制参数;
所涉及的适应度函数值fiti表达式为:
fit i = 1 / ( 1 + f i ) if f i &GreaterEqual; 0 1 + abs ( f i ) if f i < 0
式中,abs()为取绝对值函数;
步骤四:待所有引领蜂搜索结束,根据各引领蜂所在蜜源的适应度函数值fiti,得到跟随蜂转移至各蜜源概率Pi,依据概率进行位置更新,并记录每次蜂群迭代搜索过程中的适应度函数值最大的蜜源位置xbest
所涉及的转移概率Pi表达式为:
P i = e - &beta; &CenterDot; c / MaxCycles &CenterDot; fit i &Sigma; i = 1 SN fit i + ( 1 - e - &beta; &CenterDot; c / MaxCycles ) &CenterDot; fit i - fit min &Sigma; i = 1 SN ( fit i - fit min )
其中,fitmin为本次循环后适应度函数值最小值,β为调整因子;
步骤五:重复步骤三、步骤四,经过有限次循环搜索,得到参数的最优估计值。
2.根据权利要求1所述的基于改进人工蜂群算法的工程约束参数优化方法,其特征在于,当迭代次数大于最大限制迭代次数Limit时,要放弃所在蜜源,同时由侦察蜂代替引领蜂产生一个新的位置。
根据权利要求1所述的基于改进人工蜂群算法的工程约束参数优化方法,其特征在于,当参数超出其最大取值范围时,将该参数设定为该边界的最大值或最小值。
CN201410172296.5A 2014-04-25 2014-04-25 一种基于改进人工蜂群算法的工程约束参数优化方法 Expired - Fee Related CN103927580B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201410172296.5A CN103927580B (zh) 2014-04-25 2014-04-25 一种基于改进人工蜂群算法的工程约束参数优化方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201410172296.5A CN103927580B (zh) 2014-04-25 2014-04-25 一种基于改进人工蜂群算法的工程约束参数优化方法

Publications (2)

Publication Number Publication Date
CN103927580A true CN103927580A (zh) 2014-07-16
CN103927580B CN103927580B (zh) 2017-02-01

Family

ID=51145796

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410172296.5A Expired - Fee Related CN103927580B (zh) 2014-04-25 2014-04-25 一种基于改进人工蜂群算法的工程约束参数优化方法

Country Status (1)

Country Link
CN (1) CN103927580B (zh)

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104616656A (zh) * 2014-12-25 2015-05-13 西安建筑科技大学 一种基于改进abc算法的朱鹮鸣声码书设计方法
CN105785963A (zh) * 2016-05-18 2016-07-20 中南大学 一种基于人工蜂群算法的炼钢连铸调度方法
CN106546953A (zh) * 2016-11-02 2017-03-29 东南大学 一种基于人工蜂群算法的室内水下目标定位方法
CN107065585A (zh) * 2017-05-18 2017-08-18 上海博历机械科技有限公司 一种医疗物品管控系统
CN107103356A (zh) * 2017-04-24 2017-08-29 华北电力大学(保定) 基于动态粒子蜜蜂算法的群机器人搜索方法
CN107465664A (zh) * 2017-07-07 2017-12-12 桂林电子科技大学 基于并行多人工蜂群算法和支持向量机的入侵检测方法
CN108805367A (zh) * 2018-07-17 2018-11-13 广东工业大学 一种基于自适应abc算法的吸波材料最优配比设计方法
CN109543202A (zh) * 2017-09-22 2019-03-29 中国科学院微电子研究所 一种电子设计自动优化的方法及系统
CN109581291A (zh) * 2018-12-11 2019-04-05 哈尔滨工程大学 一种基于人工蜂群的直接定位方法
CN110020710A (zh) * 2019-03-08 2019-07-16 华南理工大学 一种基于人工蜂群算法的射束方向及权重多目标优化方法
CN110110276A (zh) * 2019-03-18 2019-08-09 清华大学 基于变步长递推轨迹的泄漏源定位方法和装置
CN110532651A (zh) * 2019-08-13 2019-12-03 桂林电子科技大学 一种再流焊冷却阶段下应力的焊点结构参数的优化方法
CN112036540A (zh) * 2020-09-07 2020-12-04 哈尔滨工程大学 一种基于双种群混合人工蜂群算法的传感器数目优化方法
CN112530529A (zh) * 2020-12-09 2021-03-19 合肥工业大学 一种气体浓度预测方法、系统、设备及其存储介质
CN113569461A (zh) * 2021-06-08 2021-10-29 西安航天精密机电研究所 一种基于改进人工蜂群算法的谐振子设计方法
CN114936942A (zh) * 2022-07-21 2022-08-23 深圳市绽放工场科技有限公司 一种面向保险用户的计算机网络数据处理分析系统及方法
CN117057492A (zh) * 2023-10-13 2023-11-14 合肥工业大学 基于概率最大覆盖模型的应急船舶救援基地选址优化方法
CN117474486A (zh) * 2023-11-03 2024-01-30 北京交通大学 一种重复性建设工程工期优化方法

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101894273A (zh) * 2010-05-26 2010-11-24 北京航空航天大学 一种基于人工蜂群优化边缘势场函数无人机目标识别方法
EP2159974B1 (en) * 2008-08-27 2013-01-16 Alcatel Lucent Multi-domain routing using an ant colony algorithm
CN103338491A (zh) * 2013-06-09 2013-10-02 南京邮电大学 一种基于蜂群算法的移动信标路径选择方法

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2159974B1 (en) * 2008-08-27 2013-01-16 Alcatel Lucent Multi-domain routing using an ant colony algorithm
CN101894273A (zh) * 2010-05-26 2010-11-24 北京航空航天大学 一种基于人工蜂群优化边缘势场函数无人机目标识别方法
CN103338491A (zh) * 2013-06-09 2013-10-02 南京邮电大学 一种基于蜂群算法的移动信标路径选择方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
刘雷: "一种基于蜂群原理的划分聚类算法", 《计算机应用研究》 *

Cited By (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104616656A (zh) * 2014-12-25 2015-05-13 西安建筑科技大学 一种基于改进abc算法的朱鹮鸣声码书设计方法
CN104616656B (zh) * 2014-12-25 2018-06-12 西安建筑科技大学 一种基于改进abc算法的朱鹮鸣声码书设计方法
CN105785963A (zh) * 2016-05-18 2016-07-20 中南大学 一种基于人工蜂群算法的炼钢连铸调度方法
CN105785963B (zh) * 2016-05-18 2018-08-10 中南大学 一种基于人工蜂群算法的炼钢连铸调度方法
CN106546953A (zh) * 2016-11-02 2017-03-29 东南大学 一种基于人工蜂群算法的室内水下目标定位方法
CN106546953B (zh) * 2016-11-02 2019-03-12 东南大学 一种基于人工蜂群算法的室内水下目标定位方法
CN107103356A (zh) * 2017-04-24 2017-08-29 华北电力大学(保定) 基于动态粒子蜜蜂算法的群机器人搜索方法
CN107103356B (zh) * 2017-04-24 2020-10-09 华北电力大学(保定) 基于动态粒子蜜蜂算法的群机器人搜索方法
CN107065585A (zh) * 2017-05-18 2017-08-18 上海博历机械科技有限公司 一种医疗物品管控系统
CN107465664A (zh) * 2017-07-07 2017-12-12 桂林电子科技大学 基于并行多人工蜂群算法和支持向量机的入侵检测方法
CN107465664B (zh) * 2017-07-07 2020-04-24 桂林电子科技大学 基于并行多人工蜂群算法和支持向量机的入侵检测方法
CN109543202A (zh) * 2017-09-22 2019-03-29 中国科学院微电子研究所 一种电子设计自动优化的方法及系统
CN108805367A (zh) * 2018-07-17 2018-11-13 广东工业大学 一种基于自适应abc算法的吸波材料最优配比设计方法
CN109581291A (zh) * 2018-12-11 2019-04-05 哈尔滨工程大学 一种基于人工蜂群的直接定位方法
CN110020710A (zh) * 2019-03-08 2019-07-16 华南理工大学 一种基于人工蜂群算法的射束方向及权重多目标优化方法
CN110020710B (zh) * 2019-03-08 2023-10-27 华南理工大学 一种基于人工蜂群算法的射束方向及权重多目标优化方法
CN110110276A (zh) * 2019-03-18 2019-08-09 清华大学 基于变步长递推轨迹的泄漏源定位方法和装置
CN110110276B (zh) * 2019-03-18 2021-01-26 清华大学 基于变步长递推轨迹的泄漏源定位方法和装置
CN110532651A (zh) * 2019-08-13 2019-12-03 桂林电子科技大学 一种再流焊冷却阶段下应力的焊点结构参数的优化方法
CN112036540A (zh) * 2020-09-07 2020-12-04 哈尔滨工程大学 一种基于双种群混合人工蜂群算法的传感器数目优化方法
CN112036540B (zh) * 2020-09-07 2023-11-28 哈尔滨工程大学 一种基于双种群混合人工蜂群算法的传感器数目优化方法
CN112530529A (zh) * 2020-12-09 2021-03-19 合肥工业大学 一种气体浓度预测方法、系统、设备及其存储介质
CN112530529B (zh) * 2020-12-09 2024-01-26 合肥工业大学 一种气体浓度预测方法、系统、设备及其存储介质
CN113569461A (zh) * 2021-06-08 2021-10-29 西安航天精密机电研究所 一种基于改进人工蜂群算法的谐振子设计方法
CN113569461B (zh) * 2021-06-08 2023-08-04 西安航天精密机电研究所 一种基于改进人工蜂群算法的谐振子设计方法
CN114936942A (zh) * 2022-07-21 2022-08-23 深圳市绽放工场科技有限公司 一种面向保险用户的计算机网络数据处理分析系统及方法
CN114936942B (zh) * 2022-07-21 2022-11-01 深圳市绽放工场科技有限公司 一种面向保险用户的计算机网络数据处理分析系统及方法
CN117057492A (zh) * 2023-10-13 2023-11-14 合肥工业大学 基于概率最大覆盖模型的应急船舶救援基地选址优化方法
CN117057492B (zh) * 2023-10-13 2024-02-02 合肥工业大学 基于概率最大覆盖模型的应急船舶救援基地选址优化方法
CN117474486A (zh) * 2023-11-03 2024-01-30 北京交通大学 一种重复性建设工程工期优化方法

Also Published As

Publication number Publication date
CN103927580B (zh) 2017-02-01

Similar Documents

Publication Publication Date Title
CN103927580A (zh) 一种基于改进人工蜂群算法的工程约束参数优化方法
CN110084424A (zh) 一种基于lstm与lgbm的电力负荷预测方法
CN111523749B (zh) 一种水电机组模型智能辨识方法
CN106875050A (zh) 一种基于改进混沌蜂群算法的工程约束参数优化方法
CN110888317A (zh) 一种pid控制器参数智能优化方法
CN109038643B (zh) 多机系统调速器pid参数优化方法、装置、设备及介质
CN104050505A (zh) 一种基于带学习因子蜂群算法的多层感知器训练方法
CN110598983A (zh) 一种自适应改进粒子群算法的梯级水库优化调度方法
CN105426955A (zh) 一种基于扰动的精英反向学习粒子群优化的实现方法
CN106162663A (zh) 一种基于改进蜂群算法的传感节点覆盖方法
CN112330487B (zh) 一种光伏发电短期功率预测方法
CN111709511A (zh) 一种基于随机无迹Sigma点变异的哈里斯鹰优化算法
CN116307533B (zh) 水库群防洪调度智能化方法、系统及介质
CN109472397A (zh) 基于粘度变化的聚合工艺参数调节方法
CN106296434A (zh) 一种基于pso‑lssvm算法的粮食产量预测方法
CN111625992B (zh) 一种基于自调优深度学习的机械故障预测方法
Wang et al. Short-term load forecasting of power system based on time convolutional network
CN111353534B (zh) 一种基于自适应分数阶梯度的图数据类别预测方法
CN109344960A (zh) 一种防止数据信息丢失的dgru神经网络及其预测模型建立方法
CN110276478B (zh) 基于分段蚁群算法优化svm的短期风电功率预测方法
CN104598657A (zh) 一种基于memetic算法的基因模体重构技术
CN103268068A (zh) 轴向混合磁轴承免疫蜂群算法pid控制器的构造方法
CN105117616A (zh) 基于粒子群算法的微生物发酵优化方法
CN111488690B (zh) 一种冲击式水轮发电机调速器空载调节参数优化方法
CN112766565B (zh) 梯级水库群防洪优化调度分数阶逐步优化方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20170201