" f1 m a" r$ p5 r一、遗传算法概述 ( x% E5 b4 e" ~% J; e8 J0 ?' c! G . p+ s6 A5 M, T! {) h8 M 0 G v$ `' J3 O二、遗传算法的特点和应用 % r. j. ?" u3 P+ W, p' Y% T, ?/ m% g; V
' r: ~ x. }% [5 o- \; u
三、遗传算法的基本流程及实现技术5 ?( Y7 c: L7 Z7 i
0 }$ i) C U. W6 O& T% Q& z, y
' ?2 o. g( S. v" t5 v
3.1 遗传算法的基本流程8 R v$ t, O9 ?3 K
% z7 h" z% M [+ h7 K: {# z$ f2 R
! F( `, {/ |5 ^. o3.2 遗传算法的实现技术 ) i: k/ [! o+ w' C 1 P' x! V$ f q1 ]7 R* ?* B5 Z- s6 }$ o
1.编码 7 d9 b+ [8 I5 o! ~* c * Q1 z3 y |3 P- X 3 G8 Q8 }* C ^* [" k$ ?3 _5 d2.适应度函数 4 r) F9 }$ k j' w1 A8 l/ B " p3 F1 v$ _ [9 \$ h' S . H& i( J1 o2 K0 g0 }# h3.选择算子" H4 }9 z/ h* f( h
% Q0 t' G$ ]. l$ `' g. M4 M5 J# N6 l% G( Q- f
4.交叉算子 , \8 k2 ?% T- K, ]: {. [1 L, Z7 @$ L# I2 T# W* Q' a% {9 w
; _; ^5 o" q- x0 ]# B
5.变异算子 ; ~' m* H. N8 \1 f, ~- v. f $ S; A$ Y- n9 v+ B* {( L4 f" o- K( y1 V0 z
6.运行参数4 ]/ }* U3 e9 v6 h6 r
7 q* v% R9 b, @ `5 J! A8 j. F% s8 l2 M四、遗传算法的基本原理 ( n5 `0 V( f$ t. n * x# N t9 u( H( u6 F' S: @7 i8 U( n) b; k) a
4.1 模式定理 " ?) N& R) l! B3 p" ]& U ) a( @- M ?9 Y' w1 ? 4 h8 ?3 Z+ ~5 R7 O' C4.2 积木块假设 2 }/ i! v8 m1 G8 K% \, W8 h/ {" w - B# i B. q6 c p( e7 F* c+ d2 u + z" E/ X$ i! k' [1 B2 c3 S五、遗传算法编程实例(MATLAB)5 n$ X! z6 Q1 k
0 F3 x( e, e* z% W; h3 z
! O" b$ O5 U, A3 m. ~6 f/ l* @: J一、遗传算法概述 / E+ e" s7 m3 u+ {- @, |; h H0 y 遗传算法(Genetic Algorithm,GA)是进化计算的一部分,是模拟达尔文的遗传选择和自然淘汰的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法。该算法简单、通用,鲁棒性强,适于并行处理。$ g6 L* Y0 D7 M5 h
) t. ]# l1 Z1 P; d5 t) `4 I# j7 z7 M
二、遗传算法的特点和应用9 [$ i+ F" Q E; T* |% _
遗传算法是一类可用于复杂系统优化的具有鲁棒性的搜索算法,与传统的优化算法相比,具有以下特点:' `5 y" }4 ?% ?7 J. C* Z
& _, R: Q: p% k
2 c: T5 e5 \4 l
1. 以决策变量的编码作为运算对象。 + J+ x) [0 c7 D5 L; j0 B& M : R& F, z- p) c - Y$ v( c- U* A( r4 l 传统的优化算法往往直接利用决策变量的实际值本身来进行优化计算,但遗传算法是使用决策变量的某种形式的编码作为运算对象。这种对决策变量的编码处理方式,使得我们在优化计算中可借鉴生物学中染色体和基因等概念,可以模仿自然界中生物的遗传和进化激励,也可以很方便地应用遗传操作算子。9 W* y% ?8 s3 V4 ]
# z6 ~ j+ N, r' Z, u) {5 `0 n 8 n. ^& g( J) m( }2. 直接以适应度作为搜索信息。- F/ a, v( Y. z7 T- m
$ m' D' e8 v( h* b6 }9 ~+ u! j7 J
9 B) u q) t7 D% a |6 ]8 S
传统的优化算法不仅需要利用目标函数值,而且搜索过程往往受目标函数的连续性约束,有可能还需要满足“目标函数的导数必须存在”的要求以确定搜索方向。 ! ]# X& B% }8 i) j" N) T . \: y K7 K' F: V0 \" ` 0 a" C7 o5 j6 |6 f5 V8 d0 M# {# K 遗传算法仅使用由目标函数值变换来的适应度函数值就可确定进一步的搜索范围,无需目标函数的导数值等其他辅助信息。直接利用目标函数值或个体适应度值也可以将搜索范围集中到适应度较高部分的搜索空间中,从而提高搜索效率。* e. f- H1 I% q5 f( K! l: i9 g/ `
! y8 ~5 K! Y' ?
# o f3 L9 V. h8 V. K z% @
3. 使用多个点的搜索信息,具有隐含并行性。 5 {8 j5 Y: I, y% t6 ^1 T/ w7 P+ E2 r5 M3 I% V
& V$ M& @2 k' l. v, g5 [* ?
传统的优化算法往往是从解空间的一个初始点开始最优解的迭代搜索过程。单个点所提供的搜索信息不多,所以搜索效率不高,还有可能陷入局部最优解而停滞;0 x- ]2 t# r$ A1 L* q4 [
9 u$ G, a) f+ Q3 N 1 Z; R6 m( L' u6 P4 ] 遗传算法从由很多个体组成的初始种群开始最优解的搜索过程,而不是从单个个体开始搜索。对初始群体进行的、选择、交叉、变异等运算,产生出新一代群体,其中包括了许多群体信息。这些信息可以避免搜索一些不必要的点,从而避免陷入局部最优,逐步逼近全局最优解。 3 I2 y2 K0 ~7 H6 Q" Y" h% f; } h- J7 F. h4 V; v$ v