预防维护下装配线平衡的多目标重启变邻域搜索算法
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第32卷第21期
中国机械工程
V o l .32㊀N o .212021年11月
C H I N A M E C HA N I C A LE N G I N E E R I N G
p p
.2606G2616预防维护下装配线平衡的多目标重启
变邻域搜索算法
赵联鹏1,2
㊀唐秋华1,2㊀张子凯1,2㊀蒙㊀凯1,2
1.武汉科技大学冶金装备及其控制教育部重点实验室,武汉,4300812.武汉科技大学机械传动与制造工程湖北省重点实验室,武汉,430081
摘要:针对预防维护下的装配线平衡问题,提出了一种带有重启策略的多目标变邻域搜索算法,以优化正常工作㊁设备维护情形下的节拍与工序调整.算法结合启发式与随机方法得到较优初始解;设计并筛选出寻优能力较强且具有互补性的四类邻域算子及其搜索策略,以更好地进行全局探索与局部开发.为促进P a r e t o 前沿推进,提出了一种具有自适应能力的重启算子,以便根据问题规模调整重启代数阈值㊁参考寻优进程扩大搜索空间.该算法机制简单且无固定参数,实验结果表明该算法能够获得具有竞争性的非支配解集
.
关键词:装配线平衡;预防维护;变邻域搜索;P a r e t o 优化;自适应重启中图分类号:T H 186;T P 301.6
D O I :10.3969/j .i s s n .1004 132X.2021.21.010开放科学(资源服务)标识码(O S I D )
:M u l t i Go b j e c t i v eR e s t a r tV a r i a b l eN e i g h b o r h o o dS e a r c hA l g
o r i t h mf o r A s s e m b l y L i n eB a l a n c i n g C o n s i d e r i n g P
r e v e n t i v eM a i n t e n a n c e Z H A O L i a n p e n g 1,
2㊀T
A N G Q i u h u a 1,
2㊀Z H A N GZ i k a i 1,
2㊀M E N Gk a i 1,
2
1.K e y L a b o r a t o r y o fM e t a l l u r g i c a l E q u i p m e n t a n dC o n t r o l ,M i n i s t r y o fE d u c a t i o n ,W u h a nU n i v e r s i t y o f S c i e n c e a n dT e c h n o l o g y
,W u h a n ,4300812.H u b e iK e y L a b o r a t o r y o fM e c h a n i c a lT r a n s m i s s i o na n d M a n u f a c t u r i n g E n g i n e e r i n g
,W u h a nU n i v e r s i t y o f S c i e n c e a n dT e c h n o l o g y
,W u h a n ,430081A b s t r a c t :A i m i n g a t t h e a s s e m b l y l i n eb a l a n c i n gp r o b l e m s c o n s i d e r i n gp
r e v e n t i v em a i n t e n a n c e ,a m u l t i Go b j e c t i v e v a r i a b l e n e i g h b o r h o o d s e a r c h a l g o r i t h m w i t h r e s t a r t s t r a t e g y w a s p r o p o s e d t o o p
t i m i z e t a s ka d j u s t m e n t s a n d c y c l e t i m e su n d e r n o r m a lw o r ka n de q u i p m e n tm a i n t e n a n c e s c e n a r i o s .T h e p r o Gp o s e d a l g o r i t h mc o m b i n e dh e u r i s t i c sa n ds t o c h a s t i cm e t h o d s t oo b t a i nab e t t e r i n i t i a l s o l u t i o n .F o u r t y p e s o f n e i g h b o r h o o do p e r a t o r sw i t h s t r o n g o p t i m i z a t i o n a b i l i t y a sw e l l a s c o m p l e m e n t a r i t y a
n d t h e i r s e a r c h s t r a t e g y w e r e d e s i g n e d ,s e l e c t e d a n d e f f e c t i v e l y c o m b i n e d f o r b e t t e r g l o b a l e x p
l o r a t i o n a n d l o c a l e x p l o i t a t i o n .I n o r d e r t o p r o m o t e t h e a d v a n c e m e n t o f P a r e t o f r o n t ,a r e s t a r t o p e r a t o rw i t h a d a p
t i v e c a Gp a b i l i t y w a s p r o p o s e d t oa d j u s t t h e i t e r a t i o nt h r e s h o l da c c o r d i n g t ot h es c a l eo f t h e p r o b l e m sa n dt o e x p a n d t h e s e a r c hs p a c eb a s e do nt h eo p t i m i z a t i o n p r o c e s s e s .T h e p r o p o s e da l g o r i t h mi ss i m p l ea n d h a s n o f i x e d p a r a m e t e r s .E x p e r i m e n t a l r e s u l t s s h o wt h a t t h e a l g o r i t h m m a y o b t a i n a s e t o f n o n Gd o m i Gn a t e d s o l u t i o n sw i t hc o m p e t i n gp
e r
f o r m a n c e .K e y w
o r d s :a s s e m b l y l i n e b a l a n c i n g ;p r e v e n t i v em a i n t e n a n c e (P M );v a r i a b l e n e i g h b o r h o o d s e a r c h (V N S );P a r e t oo p t i m i z a t i o n ;s e l f Ga d a p
t i v e r e s t a r t 收稿日期:20200717
基金项目:国家自然科学基金(51875421
)0㊀引言
装配流水线常用于汽车㊁电器等产品的大批
量生产,是制造型企业最基本的生产单元.装配线的平衡程度直接影响制造系统的效率,关乎产品质量以及生产成本,因此使装配线达到平衡状态至关重要.装配线平衡问题(a s s e m b l y l
i n e b a l a n c i n gp
r o b l e m ,A L B P )就是将所有基本工作单元分派到各个工位,以使每个工位在节拍(相邻两产品通过装配线尾端的间隔时间)内都处于繁忙状态.该问题自被提出以来就受到学者广泛关
注,B O Y S E N 等[1]根据求解目标将其划分为四
类,并衍生出一系列变体问题及相关理论,其求解
方法多样,可分为精确算法[2]㊁启发式算法[3
]以及元启发式算法[
4]
.由于设备损耗㊁不确定性因素的存在,在实际
6062 Copyright©博看网 . All Rights Reserved.
生产时机器会出现故障,又因为装配线生产过程具有连续特征,故障一旦出现便会导致生产过程中断,故需要对机器进行维护.设备维护通常分为纠正性维护(c o r r e c t i v e m a i n t e n a n c e,C M)和预防性维护(p r e v e n t i v e m a i n t e n a n c e,P M).前
者在设备发生故障后进行维修,属于事后维护;后者利用机器诊断㊁定期检查等技术对设备状态进行监测,并有针对性地安排维修,该方法可以将机器故障事先排除,提高设备的可靠性,减少或避免停机损失[5].
预防维护现已成为制造型企业普遍采用的设备维护方式.预防维护与车间调度的相互影响很大,集成预防维护和车间调度的研究近年来也大幅度增加.A L I R E Z A等[6]将预防维护与柔性流水车间调度进行集成优化,提出了融合遗传算法与模拟退火算法的元启发式算法,以最小化最大完工时间.WA N G等[7G8]提出多目标禁忌搜索以及四种启发式算法,分别求解预防维护与两阶段混合流水车间㊁双机流水车间集成调度问题.同样,在已知预防维护计划前提下,也应考虑基于预防维护情形的装配线平衡,以便在设备维护时迅速做出生产调整.面向该问题,蒙凯等[9G10]建立多目标优化模型,并提出了改进多目标灰狼算法与改进鲸群优化算法两种群智能算法.Z H A N G 等[11]针对考虑预防维护的U型装配线平衡问题,提出改进多目标J A Y A算法.总体来说,针对预防维护下的装配线平衡研究相对较少,并且求解方法主要集中在群智能算法的改进.仍然有必要对预防维护下的装配线平衡问题进行深入研究,特别是面向问题独有特征的分析,同时应拓展如局部搜索等求解方法,以结合问题本质特征,快速有效求解问题.
为此,本文提出了一种多目标重启变邻域搜索(m u l t iGo b j e c t i v e r e s t a r t v a r i a b l en e i g h b o r h o o d s e a r c h,MO R V N S)算法,探索面向预防维护下装配线平衡问题属性的邻域结构特征与P a r e t o前沿推进方法,并且将其与基本变邻域搜索算法㊁改进多目标灰狼算法以及另外四种经典算法进行比较,以评估所提算法的有效性和优越性.
1㊀问题描述
1.1㊀预防维护下的装配线平衡
相比正常工作,预防维护会使得工作工位减少㊁生产节拍增加以及工序调整,这时需根据工序间的优先关系确定操作序列,同时将相应工序重新分配到不同的工位,并保证正常工作和预防维护两种情形下的生产效率.如图1所示,某案例具有12道工序和4个工位,已知各工序操作时间及其优先关系.由于工位2需要进行预防维护,则工序[5369]需要进行调整.
(a)各工序优先关系
(b)工序安排
图1㊀工序优先关系及安排
F i g.1㊀P r o c e s s p r i o r i t y r e l a t i o n s h i p a n da r r a n g e m e n t
由此可以看出,正常生产和预防维护情形下的任务分配既具有一定的相同性,同时又具有极强的差异性.其中,相同性体现在:不同情形下的工序分配都必须满足优先关系;各工位时间不能大于当前情形下的生产节拍.差异性主要体现在以下三个方面:
(1)预防维护情形下,至少有一个工位被维护,被维护工位没有生产能力,其他工位能够参与生产.考虑到工位维护会改变生产状态,所以会导致一定时间的生产中断,为缩短该调整时间,每次维护应暂停尽可能少的工位.
(2)预防维护下参与生产的工位减少,意味着该情形下的生产节拍不会小于正常工作时的生产节拍.
(3)预防维护工位的工序需调整到其他工位,而且其他工位上的工序也可能会被调整,以达到负载均衡的目的.因此工序调整数应尽量少,以减少调整时间并更好地保持生产连续性.1.2㊀多目标优化模型
预防维护下的装配线平衡优化正常工作㊁维护情形下的节拍与工序调整三个目标,基于此构建多目标优化模型,并做出以下假设:
(1)已知各个工序的操作时间与优先关系;
(2)各道工序必须并且只能够被加工一次;
(3)在每一个工位上都能够加工所有工序;
(4)装配线是生产单一产品的单边直线型;
(5)不考虑工序准备时间与工件移动时间;
(6)每次计划必须且只能够维护一个工位.
7062
预防维护下装配线平衡的多目标重启变邻域搜索算法 赵联鹏㊀唐秋华㊀张子凯等
Copyright©博看网 . All Rights Reserved.
模型中,n为工序数;m为工位数;I是工序集合,I={1,2, ,n},i,kɪI;J是工位集合,J={1,2, ,m},j,lɪJ,l为需要维护的工位序号;S是工作情形集合,S={0,1, ,m},ωɪS,当ω=0时为正常工作的情形,ω=l时为对第l号工位预防维护的情形;P nˑn为优先关系矩阵,若工序i为工序k的直接前序则P i k=1,否则P i k=0;t i为第i道工序的加工时间;Cω是ω情形下的生产节拍;Aω为正常工作转换到ω情形下的工序调整数量,当ω=0时Aω=0;X i jω是决策变量,表示在ω情形下,若工序i分配到工位j上则X i jω=1,否则X i jω=0.
基于上述定义,该问题多目标优化模型的目标函数可以表示为
z1=m i n Cω=0(1)
z2=m i n Cω=l(2)
z3=m i n Aω=l(3)式(1)与式(2)分别表示最小化正常工作以及预防维护情形下的生产节拍;式(3)表示最小化由正常工作切换到某种预防维护情形时产生的工序调整数量,其计算依据下式:
Aω=l=ðn i=1ðm j=1X i j(ω=l)-X i j(ω=0)
2(4)式(4)通过将预防维护与正常工作情形下每个工位上的工序分配相比较,来计算该预防维护情形下的工序调整总量,以便进行生产准备.
多目标优化模型的约束条件可以表示为
ðm j=1X i jω=1(5)ðm j=1j(X i jω-X k jω)ɤ0㊀㊀P i k=1(6)
ðn i=1X i jωȡ1㊀㊀jʂl(7)
ðn i=1X i l(ω=l)=0(8)
ðn i=1X i jωt iɤCω(9)式(5)为工序分配约束,表示每道工序都必须分配到一个工位并且只能分配一次;式(6)为工序优先关系约束,表示只有当某工序的所有紧前工序全部完成后才能对其进行分配;式(7)与式(8)为工位分配约束,表示工位不被维护时应至少被分配一道工序,进行维护的工位不应该被分配任何一道工序,因此被维护工位上的总操作时间为零;式(9)为节拍约束,表示在ω情形下任何一个工位上的总操作时间都不能大于生产节拍.2㊀多目标重启变邻域搜索算法
变邻域搜索算法(V N S)[12]是一种经典的局部搜索算法,因其结构简单㊁易于实现且参数较少
等优点,自提出以来就被广泛应用于生产调度㊁路
径规划等组合优化问题,它通过对多邻域进行特
定形式的搜索来找到问题的满意解.装配线平衡
问题是典型的N PGh a r d问题,当问题规模较大时需要运用近似算法对其进行求解,在该问题研究
领域,变邻域搜索算法已被应用于优化双边装配
线平衡问题[13G14]中工人数量㊁线长以及生产节拍.
基本变邻域搜索算法通过设计扰动算子来避
免陷入局部最优.本文所提算法设计重启算子以
替代扰动算子作为跳出局部最优的手段,并对多
种邻域结构的选择㊁组合与搜索策略进行研究.2.1㊀初始化与解码
2.1.1㊀初始解的生成
预防维护下装配线平衡问题的可行解包括正
常工作㊁设备维护情形下的工序安排以及工序调
整三部分,解的表达采用满足优先关系的实数编
码[9].在局部搜索算法中,初始解通常由随机或启发式方法获得,从一个性能较优的初始解出发能够更快找到满意解.
考虑多目标和装配线平衡问题的特性,本文
所研究问题的初始解利用启发式规则与随机编码
相结合的方式生成.首先按照最短操作时间(s h o r t e s t p r o c e s s i n g t i m e,S P T)规则[15]㊁最长操作时间(l o n g e s t p r o c e s s i n g t i m e,L P T)规则[16]㊁优先位置权重(r a n k e d p o s i t i o n a lw e i g h t,R P W)规则[17],分别混合最短与最长操作时间和优先位置权重规则随机编码生成6种操作排序方案,由此得到36个不同的待选初始解.然后,利用 擂台赛法则 [18]依据它们的目标函数值进行非支配排序,找出初始非支配解集,并计算解集中各解与其他解之间的距离,最终选出距离之和最大的解作为初始解.
2.1.2㊀固定工位下的动态迭代解码
在求解预防维护下装配线平衡问题中的不同
工作情形下的生产节拍时,其本质是求解第二类
装配线平衡问题,即在给定工位数时最小化生产
节拍.当操作序列确定后需要将各工序分配到各
工位并获得该序列下的最小生产节拍.由于每种
生产情形下工位数目固定,又因同一序列的分配
方案有多种,故不能采用增加工位的方式进行解
码,所以采用固定工位下的动态迭代解码.基于某
一情形下的工序操作序列,具体解码步骤如下.
(1)依据下式计算该操作序列下的理论最小生产节拍:
8062
中国机械工程第32卷第21期2021年11月上半月Copyright©博看网 . All Rights Reserved.
C E=ðn i=1t i
m
(10)
并令当前节拍C=C E.
(2)按照当前节拍C将该序列中的操作依次分配到各工位,直至分配到第(m-1)号工位满足当前节拍要求,然后将剩余操作全部依次分配给第m号工位.
(3)计算此时每个工位上的总操作时间T j 与Tᶄj,后者的计算公式如下:
Tᶄj=T j+t1(j+1)(11)其中,t1(j+1)表示此时第(j+1)个工位上的第一道工序的操作时间.
(4)令Cᶄ=m a x T j,Cᵡ=m i n Tᶄj,若CᶄɤTᵡ,那么Cᵡ就是该操作序列下的最优生产节拍,此时的分配方案也为该操作序列下的最佳分配方案;若Cᶄ>Cᵡ,那么,令当前节拍C=Cᵡ,并重复步骤(2)~步骤(4).
针对每种情形,固定待维护工位和可工作工位,运行上述解码,可获得目标值(C0,A l,C l).其中,C0为正常工作情形下的生产节拍;C l为对l 号工位进行维护的情形下的生产节拍;A l为两种情形切换时的工序调整数量.
2.2㊀接收准则
新解的接收准则是:若该解能支配当前P a r e t o前沿解集中的某些解,或者与其中所有解互不支配,那么就将该解放入前沿解集并删除被其支配的所有解,否则丢弃该解;在新解与当前非支配解集中的所有解互不支配时,则将其保留在前沿解集中,但不认为前沿解集获得实质性推进;只有当前P a r e t o前沿解集中全部或者部分解被新解支配时才认为其发生实质性推进.
2.3㊀变邻域搜索算子
在对多邻域进行搜索时,若邻域结构数量太多则会增加计算的时间成本,反之将会导致对解空间探索不完全,最终遗失满意解.因此,在进行算法设计时必须考虑以下三点内容[12]:
(1)设计恰当数量并且针对问题属性的邻域结构;
(2)确定所采用的多种邻域结构的排列组合形式;
(3)采用面向问题属性寻优能力最好的搜索策略.
在本文所提算法中,对上述内容进行深入研究,并最终使算法展现出相对较好的性能.2.3.1㊀邻域结构的选择
针对装配线平衡问题,现已有发展成熟且性能良好的邻域结构,如互换算子㊁后插算子以及前插算子.在搜索阶段,通常为了追求运行速度而忽略邻域解的可行性,一般采取修复机制使不可行解转换为可行解,这种设计方法不仅降低了产生可行解的概率又增加了计算复杂度.修复机制如同设备管理中的纠正性维护,本文在设计邻域算子时运用预防维护思想,选取互换㊁后插与前插三种邻域结构,并根据工序优先关系设计一次互换与多次互换㊁一次后插与多次后插㊁一次前插与多次前插六个算子以生成可行邻域解,并且避免各算子邻域空间出现重叠现象,消除重复操作带来的时间损失.
同时,本文设计了一种新型邻域结构,称为重排式邻域算子.已知某一操作序列,随机选择其中任意两个位置,分别以近前端㊁近后端为起止点截取子序列,并根据子序列中各操作之间的优先关系形成部分优先关系矩阵,基于此对子序列进行重新排列得到新序列,如图2所示.该例中起点为3㊁终点为9,初始子序列包含操作为[6347859],根据优先关系重新排列之后得到新的子
序列[4593678],对应地,由初始序列[126347859101112]得到新的可行邻域解序列[124593678101112].
图2㊀重排式邻域算子实例
F i g.2㊀E x a m p l e s o f r e a r r a n g e dn e i g h b o r h o o do p e r a t o r s 2.3.2㊀邻域结构的排序
所提算法采用四类七个邻域结构,除重排式邻域结构之外,实现了互换㊁后插与前插算子的邻域解空间完全没有交叉部分.而重排式邻域结构随机性大,其邻域解空间与其他三类算子的解空间有部分重叠,在其余算子探索不到的解空间,该结构起一定的补足作用.
大量实验证明,根据工序优先关系实现的四类邻域结构性能由优到劣依次为重排㊁互换㊁后插和前插,在邻域搜索阶段多种邻域结构按此顺序进行排列,以保证尽快找到满意解.2.3.3㊀搜索策略的选择
多邻域结构的搜索方式通常有三种,分别是每次迭代随机选择一种邻域结构进行探索的随机邻域搜索(s t o c h a s t i c n e i g h b o r h o o d s e a r c h, S N S)策略㊁交替进行的变邻域搜索策略和对多种邻域结构全部探索的全局邻域搜索(g l o b a l
9062
预防维护下装配线平衡的多目标重启变邻域搜索算法 赵联鹏㊀唐秋华㊀张子凯等
Copyright©博看网 . All Rights Reserved.
n e i g h b o r h o o d s e a r c h,G N S)策略.
面向预防维护下装配线平衡问题,邻域搜索策略采用交替搜索.理论上,假设选取K种不同的邻域结构,在每次迭代时随机搜索策略的计算复杂度为1,该策略时间成本最低;全局邻域搜索策略的计算复杂度为K,时间成本最高;而采用交替搜索策略时计算复杂度在区间[1,K]内,时间成本也在其他两种策略之间.采用三种搜索策略展现出的性能也将通过实验算例进行验证说明.
当邻域结构选择㊁组合以及搜索策略确定之后,随即实现重启前的变邻域搜索阶段(v a r i a b l e n e i g h b o r h o o ds e a r c h b e f o r er e s t a r t,V N S B R),使它在算法中承担重启前的探索工作,并依据接收准则对新解进行判断.伪代码如下所示.
算法1㊀V N S B R
1:㊀I n p u t:Ω,N h(h=1,2, ,K),P O S
2:㊀B e g i n:
3:㊀㊀㊀d=0;
4:㊀㊀㊀F o r h=1t o K d o
5:㊀㊀㊀㊀㊀㊀Ωᶄ=N h(Ω);
6:㊀㊀㊀㊀㊀㊀I f∃πɪP O S:Ωᶄ≺πt h e n
7:㊀㊀㊀㊀㊀㊀㊀㊀㊀P O Sѳ∁P O SπɣΩᶄ;
8:㊀㊀㊀㊀㊀㊀㊀㊀㊀ΩѳΩᶄɡd=0;
9:㊀㊀㊀㊀㊀㊀㊀㊀㊀b r e a k
10:㊀㊀㊀㊀㊀E l s e I f∀πɪP O S:π≺Ωᶄt h e n
11:㊀㊀㊀㊀㊀㊀㊀㊀㊀dѳd+1;
12:㊀㊀㊀㊀㊀E l s e
13:㊀㊀㊀㊀㊀㊀㊀㊀P O SѳP O SɣΩᶄ;
14:㊀㊀㊀㊀㊀㊀㊀㊀dѳd+1;
15:㊀㊀㊀㊀㊀E n d I f
16:㊀㊀㊀E n dF o r
17:㊀O u t p u t:Ω,P O S,d
算法1中,Ω为被探索解;Ωᶄ是邻域解;N h表示第h种邻域结构;P O S为当前P a r e t o前沿解集;∁P O Sπ表示解π在P O S中的相对补集,是由P O S中所有不同于π的解组成的集合;d用来记录前沿解集连续未发生实质性推进的代数.2.4㊀重启算子
由于接收准则的本质是贪心策略,所以算法容易陷入局部最优.基本变邻域搜索(b a s i c v a r i a b l e n e i g h b o r h o o d s e a r c h,B V N S)算法采用扰动算子在每次寻优前对被探索解进行扰动得到中间解,从而获得全新的邻域解空间并进行探索,从而达到跳出局部最优的目的,但扰动具有随机性,中间解性能有时会劣于当前解,所以增加了寻优过程的波动性.
为跳出局部最优,实现P a r e t o前沿解集的推进并同时保证算法稳定性,本文设计了一种新型重启算子来替代扰动算子.2.4.1㊀自适应阈值
非支配解集连续未获得实质性推进的代数是判断何时重启的关键,将它作为重启算子的启动阈值,记为g.若阈值取值过小,将导致频繁执行重启算子并错过满意解;若阈值取值过大,则会迟迟不重启从而无法跳出局部最优,浪费C P U时间[19].
在算法运行过程中,解的性能会随着寻优次数的增大逐渐变优,因此在寻优后期相比前期更容易陷入局部最优.针对不同规模的装配线平衡问题,陷入局部最优的可能性与工序数n㊁工位数m㊁操作时间不同的工序个数a以及优先关系约束强度R有关.在确定上述因素与重启阈值的函数关系之后,当前寻优代数自适应重启阈值g依据下式确定:
g=0.3r F⌉(12)
F=9m a n R(13)
R=2b2
n(n-1)(14)其中, ⌉表示向上取整;b为优先关系矩阵中所有紧前约束的个数;r为当前寻优代数.
以基准案例H a h n中53工序4工位㊁A r c u s2中111工序12工位以及S c h o l l中297工序26工位情况为例,重启算子中自适应阈值g随着算法迭代次数r动态变化曲线如图3所示.图3中,g o 为关于迭代次数的实际阈值函数.图3显示,随着迭代次数r的增大,g o曲线的斜率不断减小,并且在寻优前期下降迅速,中后期趋于缓慢,这说明前期非支配解集能够快速向真实前沿推进,中后期逐渐接近真实前沿.因此g o的增长趋势在不断减缓,且向上取整后得到的每个g值持续代数增大.自适应g值曲线动态变化与算法在求解过程中陷入局部最优的趋势吻合.2.4.2㊀自适应邻域结构
当d>g时,执行重启算子,即在当前非支配解集中随机选择一个候选解并记录此时刻的重启时间节点t r,并进入重启后的变邻域搜索(v a r i a b l e n e i g h b o r h o o d s e a r c h a f t e r r e s t a r t,V N S A R)对候选解进行探索.与V N S B R阶段不同的是该阶段的多种邻域结构是自适应的,每一次执行重启更新该阶段的邻域结构规模时依据下式进行:
K M=R o u n d(t r T t K)(15)式中,R o u n d( )表示四舍五入取整.
0162
中国机械工程第32卷第21期2021年11月上半月Copyright©博看网 . All Rights Reserved.
㊀㊀㊀㊀(a)H a h n(53工序4工位)㊀㊀㊀(b)A r c u s2(111工序12工位)㊀㊀㊀(c)S c h o l l(297工序26工位)
图3㊀不同规模案例g,g o,g o值曲线
F i g.3㊀C u r v e s o f t h e v a l u e s o f g,g o a n d g o f o r d i f f e r e n t s c a l e c a s e s
式中,K M随寻优进程动态变化,表示当前时间节点重启执行后的邻域搜索阶段的邻域规模;T t是算法最大寻优总时间;K为全部邻域结构的个数.
随寻优进程的推移,该阶段邻域空间不断扩大,从开始时只有性能最优的重排式邻域空间逐步扩展到全邻域空间.这是因为在寻优前期,重启之后要立即将探索重点放在更容易产生满意解的邻域空间中以快速跳出局部最优,到中后期非支配解集中的解已接近满意解,此时要将探索重点放在更广阔的邻域空间中,防止满意解丢失.2.4.3㊀基于空间距离的选择策略
在执行完毕重启算子与重启后的变邻域搜索后,可以获得最新的P a r e t o前沿解集.此时,为确保进入下一次重启前的变邻域搜索阶段的候选解具有良好的多样性,本文基于空间距离最大策略从当前非支配解集中选择候选解.
每个解的适应度值(C0,P l,C l)都可视为三维空间中的一个点.显然,P a r e t o前沿解集中与所有解距离之和最大的解就是位于最不拥挤区域的解,即为当前解集中多样性最好的解,选此为候选解进入下一次重启之前的变邻域搜索阶段.至此,多目标重启变邻域搜索算法执行完毕,其伪代码如下所示.
算法2㊀MO R V N S
1:㊀I n p u t:n,m,R,P nˑn,t i
2:㊀B e g i n:
3:㊀㊀㊀G e n e r a t e a n i n i t i a l P O S;4:㊀㊀㊀F i n d t h e i n i t i a l s o l u t i o nΩ;
5:㊀㊀㊀d=0;
6:㊀㊀㊀W h i l e t p<T t d o
5:㊀㊀㊀㊀F o r r=1t oβd o
6:㊀㊀㊀㊀㊀㊀g=G(n,m,P nˑn,t i);
7:㊀㊀㊀㊀㊀㊀(Ω,P O S,d)=V N S B R(Ω);8:㊀㊀㊀㊀㊀㊀I f d>g t h e n
9:㊀㊀㊀㊀㊀㊀㊀㊀㊀(Ω,P O S,d)=V N S A R(Ω);10:㊀㊀㊀㊀㊀㊀㊀㊀S=D(P O S);
11:㊀㊀㊀㊀㊀㊀E n d I f
12:㊀㊀㊀㊀E n dF o r
13:㊀㊀㊀E n d W h i l e
14:㊀O u t p u t:P O S
算法2中,t p表示算法当前寻优总时间;β为足够大的正整数;G为阈值g的生成函数;D为基于空间距离的候选解选择函数.
3㊀实验分析
为证明重启算子㊁交替搜索策略以及多目标重启变邻域搜索算法的有效性和优越性,本文采用MA T L A BR2018a编程,电脑配置为:I n t e l(R) C o r e(T M)i5G6200U C P U@2.30G H Z2.40G H Z a n d4.00G BR AM;预防维护情形全部基于装配线平衡问题标杆案例生成,且每次计划随机选择一个工位进行维护,标杆案例数据来自装配线平衡专业网站[20];在进行算法对比时,选取30个案例进行实验,每个案例运行8次,算法运行的终止条件设置为t pȡT t,算法最大寻优总时间T t=
1162
预防维护下装配线平衡的多目标重启变邻域搜索算法 赵联鹏㊀唐秋华㊀张子凯等
Copyright©博看网 . All Rights Reserved.
ρ
n 2/1000,其中ρ=10.3.1㊀案例分析
以案例H a h n 中53工序6工位情况的运行结果来说明预防维护下装配线平衡多目标优化模型
的优势,其甘特图见图4.其中,横轴表示每个工位上的工序操作时间,纵轴表示工位序号;图4a
表示正常工作情形下的工序安排,图4b 表示对工位2进行维护的工序安排.
(a
)正常工作时最佳工序安排(b
)预防维护时最佳工序安排图4㊀案例H a h n (53工序6工位)不同情形下的工序安排
F i g .4㊀T a s k s a r r a n g
e m e n t o fH a h n (53p r o c e s s 6w o r ks t a t i o n )i nd i
f f e r e n t s c e n a r i o s ㊀㊀由图4可知,该方案目标值为(2400,23,2823),说明正常工作的生产节拍为2400个单位时间,工位2维护情形的生产节拍为2823个单位时间,状态切换时对23道工序进行了调整.若不考虑预防维护,当某工位发生故障时需要对其进行纠正性维护,此时整条线处于停工状态.假设对一个工位维护的时间为x 小时,产线的产值为每小时e 万元,则直接损失e x 万元.当考虑预防维护来进行装配线平衡时,维护与生产在相同时刻进行,则损失仅为工序调整所需时间与成本,调整时间远小于工位维护时间,随行夹具以及各装
置调整成本也远远小于工位维护成本,由此可见,与不考虑预防维护的装配线平衡相比,将预防维护提前考虑,能有效保证生产连续性㊁降低维护时的损失.
3.2㊀有效性分析
为全面评价算法的性能,本文选取世代距离
(G D )D G D ㊁逆世代距离(I G D )D I G D 和超体积率
(H V R )R H V R 来判断算法所得P a r e t o 前沿解集的优劣
[21]
.
(1
)收敛性评价指标D G D 用来衡量算法所求得的近似前沿解集S u 与真实P a r e t o 前沿解集之间的逼近程度.D G D (S u )
值越小,说明S u 与真实前沿P T P 逼近程度越高,收敛性越好.计算如下:
D G D (S u )=
ð|S u |
v =1
(
d t v
)2
|S u |
(16)d t v =m
i n |P T P
|q =1ðτ
λ=1
[f λ(x v )-f λ(
x q )f m
a x λ-f m i n λ]
2(17
)式中,d t v 为S u 中第v 个解与所有算法所得近似前沿解集
并集的非支配解集P T P 的最小欧氏距离;τ为问题中目标个数;f m a x λ㊁f m i n
λ分别为真实前沿P T P 中第λ个目标的最大
值和最小值.
(2)逆世代距离D I G D 同时评价解集收敛性与
分布性,通过衡量真实前沿逼近S u 的程度来判断
S u 的优劣.D I G D (
S u )越小,说明解集S u 的综合性能越好.计算如下:
D I G D (
S u )=ð|P T P
|v =1
d
t v
|P T P |
(18)d t v =m
i n |S u |
q =1ðτ
λ=1
[f λ(x v )-f λ(
x q )f m a x λ-f m i n λ]2(19
)式中,d t v 为P T P 中第v 个解与S u 的最小欧氏距离;f m a x
λ㊁
2162 中国机械工程第32卷第21期2021年11月上半月
Copyright©博看网 . All Rights Reserved.。