数学建模社区-数学中国

标题: 组合优化算法-现代优化算法(四):改进的遗传算法 [打印本页]

作者: 浅夏110    时间: 2020-5-22 15:31
标题: 组合优化算法-现代优化算法(四):改进的遗传算法
无人机航路规划问题实际上是一个组合优化问题,是优化理论中的 NP—hard 问题。 因为其解空间不连续,解邻域表达困难,所以难以用通常的算法求解。遗传算法作为现代优化算法之一[1],其主要特点是对非线性极值问题能以概率 1 跳出局部最优解,找 到全局最优解。而遗传算法这种跳出局部最优寻找全局最优特性都基于算法中的交叉和 变异。在传统遗传算法的结构中,变异操作在交叉操作基础上进行,强调的是交叉作用, 认为变异只是一个生物学背景机制[2]。在具体交叉操作中,人们通常采用断点交叉法 (段交叉)多点交叉与均匀交叉,其中断点交叉是指随机地在基因序列中选择一个断点, 然后交换双亲上断点右端的所有染色体。在变异操作中,变异算子一般是用 Guassian 分 布的随机变异来实现[3,4]。近年来,也有学者尝试用 Cauchy 分布的随机序列来实现变异[5], 希望通过 Cauchy 分布宽大的两翼特性实现更大范围的变异,以利于找到全局最 优解。[6]从理论上分析了采用 Cauchy 分布随机变异进化算法的局部收敛性。[7]进一 步把二者结合起来, 采用两种分布的线性叠加,但仿真结果显示,算法改进效果并不十 分明显。文献[8]将生物进化看成是随机性加上反馈,并指出其中的随机性主要是由系 统的内在因素所引起,而不是由外部环境的随机扰动所造成。而混沌系统在其混沌域中 表现为随机性,它是确定系统内部随机性的反映,不同于外在的随机特性。
) B! r$ T8 l' F) G5 L
* h0 _: z/ F4 [/ Y4 P3 _% M本文根据以 上特点对基于求解航路规划的遗传算法进行改进,首先将变异操作从交叉操作中分离出 来,使其成为独立的并列于交叉的寻优操作,在具体遗传操作中,混沌与遗传操作联系 在一起,在交叉操作中,以“门当户对”原则进行个体的配对,利用混沌序列确定交叉 点,实行强度最弱的单点交叉,以确保算法收敛精度,削弱和避免寻优抖振问题;在变异操作中,利用混沌序列对染色体中多个基因进行变异,以避免算法早熟。
) N: {! w5 A9 y; {' f- ]7 G; y9 n1 P/ W) |7 T: k7 c
下面我们研究 1.2 中同样的问题。! _$ v* r! n: U, z" N# S' }

- e0 e2 A9 _) w: ^$ O# g+ x- U6 f3 ^$ s: v5 r

' q; m( M4 {1 V
6 H) X6 l. C% {$ Y( t. h3 S  O3 M
/ z. H( W4 m/ f# i* u7 R1 R5 j: I5 j; E我方有一个基地,经度和纬度为(70,40)。假设我方飞机的速度为 1000 公里/小时。 我方派一架飞机从基地出发,侦察完敌方所有目标,再返回原来的基地。在敌方每一目 标点的侦察时间不计,求该架飞机所花费的时间(假设我方飞机巡航时间可以充分长)。; t4 o$ O3 D" J% k4 h* ?

  M% v3 I3 `* B4 {
  k  b5 T! P; n" Y6 A( o
5 g5 W+ O+ _- o" \$ A, v2)我方有三个基地,经度、纬度分别为(70,40),(72,45),(68,48)。假设我方 所有无人侦察机的速度都为 1000 公里/小时。三个基地各派出一架飞机侦察敌方目标, 怎样划分任务,才能使时间最短,且任务比较均衡。
( t# s3 Y+ a0 Q# A# I. v4 \- R" `6 `' t
2 模型及算法0 C9 D0 [, r0 z  Z! t# _
与标准的遗传算法相比,我们做了如下的两点改进。( k# o7 O; u* x+ d- M  O8 f

) v1 M4 I% _- [  a$ \7 j+ v(1)交叉操作
+ J& h- L) W1 x/ u2 a: F+ ~6 G1 M( @

8 B+ J' p1 y6 g* z: z: j( ~7 ]+ D; K3 Z9 e# s' h$ U" v7 Z! S
9 @9 q" i! L  `5 |1 ~' y
% A+ p  j  K! {
很明显这种单点交叉对原来的解改动很小,这可以削弱避免遗传算法在组合优化应用中 产生的寻优抖振问题,可以提高算法收敛精度。" F- d% W4 }) F1 E, g9 |5 M3 `: M

5 T6 U" c- V- Q9 J(2)变异操作
6 H* v( s/ H" ~1 l变异也是实现群体多样性的一种手段,是跳出局部最优,全局寻优的重要保证。在 本文具体变异算子设计如下,首先根据给定的变异率(本文选为 0.02),随机地取两个在 2 到 101 之间的整数,对这两个数对应位置的基因进行变异,具体变异以当前的基因值 为初值利用混沌序列 x(n +1) = 4x(n)(1− x(n)) 进行适当次数的迭代,得到变异后新的基因 值,从而得到新的染色体。
/ ^8 b# x: ]' n
2 u: u- |  d6 x. C3 仿真结果对比及算法性能分析' d" \% x8 Z. ?; ]$ O
计算的 MATLAB 程序如下:
* V: R( ?! y0 {/ j- X5 g" F, \# o* E, ^- m& @  ]# H
tic* E% S& Z: E) A) n) l
clc,clear
# |. V2 F! S4 s1 t8 Aload sj.txt %加载敌方 100 个目标的数据
5 D. E3 [0 J/ [7 A) ix=sj(:,1:2:8);x=x(;
1 X' F" L- r2 `y=sj(:,2:2:8);y=y(;
: k( A7 B+ @# Y  r; D: isj=[x y];
4 E. v( S0 Y7 d+ y/ Y: i9 {/ kd1=[70,40];
& \1 y5 P0 N; Y; psj=[d1;sj;d1];
+ W0 {' ^$ I8 Z2 h+ ]  l) D! F%距离矩阵 d
7 N  ^: h- K9 wsj=sj*pi/180;3 J" v9 ~) y% T8 d5 s: x
d=zeros(102);" Z& K& l7 J- y0 A% w
for i=1:1014 a( u1 G: l# V4 M; b" X9 y
    for j=i+1:102
" D0 d) N5 b0 K3 m        temp=cos(sj(i,1)-sj(j,1))*cos(sj(i,2))*cos(sj(j,2))+sin(sj(i,2))*sin(sj(j,2));$ u; W+ T/ H7 Y
        d(i,j)=6370*acos(temp);
  p' @; x( d8 o" @$ J    end
! p; c2 Q0 D! Iend6 I# \* P# E8 G* ]$ q4 S
d=d+d';L=102;w=50;dai=100;
3 @4 w4 ^) Y+ p# J. T6 _%通过改良圈算法选取优良父代 A3 q3 `) |  t# f6 U
for k=1:w
2 V0 P7 c4 c4 _  w* V, c2 o1 R    c=randperm(100);
( y" X0 Z- s" x% \1 u    c1=[1,c+1,102];
: m  I$ x5 X8 y9 U& [# p) `+ a    flag=1;* u3 ?: }2 m- F6 I, E
    while flag>0' t! H& U5 F/ {. E+ l9 G: s! Y
        flag=0;, j7 o& {1 ?% v" |$ t0 D" C4 P
        for m=1-3
$ j& E. [( `0 E  L) u9 h) d- T            for n=m+2-1
3 B& [. C: i/ Y! b- c7 x                if d(c1(m),c1(n))+d(c1(m+1),c1(n+1))<d(c1(m),c1(m+1))+d(c1(n),c1(n+1))
# |; W% }1 w( }, |3 x, ~* w                    flag=1;  m, y% O% B5 m9 }. i6 p& o
                    c1(m+1:n)=c1(n:-1:m+1);
- n9 |! @/ E4 F2 }7 A" V8 p                end
% [& u% p) i- }8 P( a5 T( S! f            end, I$ S: `  `! \6 d$ n) y
        end
/ m- ?7 d! A: v5 n' ?     end9 n" S9 m$ y; s) C* n+ K
    J(k,c1)=1:102;
- Y" M3 s& w9 w* p7 Kend
% B! w' I  Y+ ]$ ~/ F5 m' J: \& E* wJ=J/102;2 J7 q! W0 j8 r% s- {
J(:,1)=0;J(:,102)=1;
& M( ^) c/ z, Q1 Wrand('state',sum(clock));: h; F, j1 {/ @7 {+ V3 w8 S
%遗传算法实现过程
1 |" s( A4 u; o+ C+ RA=J;
6 ^; _, t2 k6 c5 X; ^for k=1:dai %产生 0~1 间随机数列进行编码
* Z* S" q0 M. w$ H; }" W: Q    B=A;; y2 o% i9 {# G3 H( X
%交配产生子代 B
8 q0 _+ k' ~3 H) K( @    for i=1:2:w, v' k1 `4 C1 {5 A3 k
        ch0=rand;ch(1)=4*ch0*(1-ch0);1 }1 \8 L9 g$ B! y4 T
        for j=2:50
+ h. u$ B( B5 A$ F            ch(j)=4*ch(j-1)*(1-ch(j-1));" t* g; E8 o$ d
        end
1 L3 z$ z- s  _5 R" @* z$ a        ch=2+floor(100*ch);  z* B5 g* u+ v, Q$ S" q6 p
        temp=B(i,ch);
. C' v. c8 n  _* j$ C) C        B(i,ch)=B(i+1,ch);, W& |* N3 G+ _2 o  F% [
        B(i+1,ch)=temp;
( O  M; A  D/ `$ D9 I    end
6 o" I; s3 W8 r2 L# g# F0 ]%变异产生子代 C
! y- ^2 g- P/ `+ V0 O  J7 ]    by=find(rand(1,w)<0.1);- I. ]- k9 {# |
    if length(by)==0, o6 A7 J) w1 r6 A0 ?/ N
        by=floor(w*rand(1))+1;    $ P. n2 w. n! M& f2 h+ w1 C
    end! w5 n! z# X* j5 |
    C=A(by,;
( q) v6 B) \# u' A% y8 N  U    L3=length(by);
: m8 j8 F' F4 o    for j=13; R7 s/ W; n1 t; e) J! ~
     bw=2+floor(100*rand(1,3));
( ^: _# X% e5 T+ ?     bw=sort(bw);- q! V9 O  [, b9 d
     C(j,=C(j,[1:bw(1)-1,bw(2)+1:bw(3),bw(1):bw(2),bw(3)+1:102]); , G! Y6 s5 B0 y! ~2 O
end7 I( F! x: v- c
    G=[A;B;C];- f- z& \4 y, a. j3 ]+ E
    TL=size(G,1);, [1 T5 j3 p) e
%在父代和子代中选择优良品种作为新的父代/ C7 D  Z8 C# Z8 Y: k# b
    [dd,IX]=sort(G,2);temp(1:TL)=0;4 O! _# r8 O/ {6 q: U& S7 G
    for j=1:TL
& ?7 A  U# ~4 t3 b; R2 v2 g        for i=1:101
  z+ S% B( @3 O1 X0 ]- V            temp(j)=temp(j)+d(IX(j,i),IX(j,i+1));7 j* S% ~8 l) I/ j& S4 u  M3 E% a
        end' E7 ?/ H  Q! E: ?
    end% C! G! C! Y: z0 ?8 Y& \  P* `4 P* s
    [DZ,IZ]=sort(temp);1 z$ ^/ M* G$ h5 [' [( l# i; W
    A=G(IZ(1:w),;
4 y. c3 a7 {/ x( L9 f' X1 a: _6 v8 Bend+ v  o5 h0 Q: Y& I; p; `& {- X2 D7 l
path=IX(IZ(1),
5 @+ S: L3 j- @' V$ E8 X. vlong=DZ(1)2 J/ ^8 _4 J2 q
toc 3 {, C. p0 J0 d6 _
" p* }8 L: r- G, A& m9 G  s/ _
' @/ u+ A4 T" U. o
在仿真试验中,我们对文中航路规划问题分别利用断点交叉和换位变异结合的遗传 算法,多点交叉和移位变异结合的遗传算法[10]和文中提出的改进算法进行求解比较。 表 1 是各种算法种群规模( M = 50)和迭代次数(G = 100 )都相同时连续 20 次求 解的平均值(公里),算法平均运算时间(秒)。0 j! B* r4 H, b9 G0 @/ O

+ b: Z4 A( H( M; s0 g4 l" y; X$ B+ C$ f* p3 x
' m4 l+ F& T. S- f; n& x
, h( s$ `+ N3 T" U% @- y  o* c
本文从算法结构到具体的遗传操作都进行了改进,其中变异操作从交叉操作中分离 出来,使得遗传算法也可以通过并行计算实现,提高算法实现效率。其次改进后的算法, 分别采用变化强度不同的交叉操作和变异操作,其中交叉操作采用强度最弱的单点交 叉,保证了算法收敛精度,削弱和避免算法因交叉强度大而产生的寻优抖振问题。当然 单一的单点交叉很容易使算法早熟,文中采用较大强度的多个基因变异正好解决早熟问 题。从仿真结果可以看到改进后的算法效果较为明显。7 I0 `" D. Q- @0 u, F- J& Z

4 \0 L7 o; S% n. q/ V) g9 ]4 X3 c7 T& [( C# r4 x) Z

* ~1 a3 R0 O- j% b————————————————
7 l4 L1 p* V4 @; G, t版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
. x5 n' i  h7 ], M+ q原文链接:https://blog.csdn.net/qq_29831163/article/details/89672986; l, b" c" [% E; w" }& t* h
2 u; j, }+ r& m( k  c
1 H8 \8 V  _; B- I





欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5