QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 12640|回复: 43
打印 上一主题 下一主题

[建模教程] 不看会后悔系列——国赛加分算法之遗传算法(上)

[复制链接]
字体大小: 正常 放大

52

主题

12

听众

676

积分

  • TA的每日心情
    奋斗
    2021-6-27 15:42
  • 签到天数: 27 天

    [LV.4]偶尔看看III

    版主

    国际赛参赛者

  • TA的关系
  • 群组冬令营普通班

    群组Latex研学群

    群组2018美赛护航培训课程

    群组2018美赛冲刺培训

    群组2017科技论文写作

    跳转到指定楼层
    1#
    发表于 2018-8-8 16:48 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
           建模的国赛里面,纵观12-17年国赛一等奖以及特等奖论文,100%的概率论文里面有高级算法的存在,而70%的概率遗传算法都会出现,之所以它这么受欢迎,一方面是因为它求解复杂方程的实用性,另一方面也因为它作为一种智能优化算法,其求解的正确性随着迭代次数增加而增加,虽然同样求解极值时也可以用lingo/lindo来用,但是用GA(遗传算法)的话可以解决更为复杂的问题,所以尽管有时候可以用lingo来解,但是如果用GA来解,这篇论文就会更加容易得奖。因此得奖论文里它的影子屡见不鲜也就不足为奇了。# ~; b$ J/ s- {: m2 d/ S8 C
    6 ]  N# i6 Y  c: ~4 ]8 l  F- ]
    遗传算法的本质其实就是一种优化算法,当决策变量10多个或者更多时,而且目标函数不是整数次幂,用它可以求出的精度达到0.0001,借鉴了达尔文的进化论和孟德尔的遗传学说。其本质是一种高效、并行、全局搜索的方法,能在搜索过程中自动获取和积累有关搜索空间的知识,并自适应地控制搜索过程以求得最佳解。) ]* g2 C" e2 M) y3 N0 V0 x0 @

    $ F& O- f0 @2 v" O- \+ h. c' R+ r首先来了解一下遗传算法的生物学基础:- m* J# r7 e' T  P" B6 ?$ q# u9 r) r
    ) |; ]* N( X) r/ G
          在一定的时间里,有一群兔子,其中一些比另外一些兔子跑得快,而且更聪明,这些兔子被狐狸吃掉的可能性比较小,因此它们中的多数就存活下来并繁殖更多的兔子。当然,一些跑得慢而愚蠢的兔子也会存活下来,只是因为它们比较侥幸,这些存活的兔子群开始生育。生育的结果是兔子遗传材质的充分融合:一些跑得慢的兔子生出了跑得快的兔子,一些跑得快的兔子生出跑得更快的,一些聪明的兔子生出了愚蠢的兔子,等等。在最顶层,自然界不时地变异些兔子的基因材质。所产生的小兔子平均来说要比原始的群体更快更聪明,因为从狐狸口中生存下来的父代多数是跑得更快、更聪明的兔子。同样,狐狸也经历相似的过程,否则兔子可能跑得太快又太聪明以致狐狸根本抓不到了。兔子的生存哲学就是以自然选择学说为核心的现代生物进化理论,其基本观点是:种群是生物进化的基本单位,生物进化的实质是种群基因频率的改变。基因突变和基因重组、自然选择及隔离是物种形成过程的三个基本环节,通过它们的综合作用,种群产生分化,最终导致新物种的形成。在这个过程中,基因突变和基因重组产生生物进化的原材料,自然选择使种群的基因频率定向改变并决定生物进化的方向,隔离是新物种形成的必要条件新物种形成的途径和方式有两种:渐变式和爆发式。渐变式主要通过变异的逐渐积累而成亚种,再由亚种形成一个或多个新种,新种又分为两种类型,即继承式新种形成和分化式新种形成;爆发式不通过亚种这一阶段而迅速形成新的物种,其分为三种类型,即杂交产生新种,染色体结构变化形成新种和多倍体化的新种形式。遗传算法杂交了渐变式和爆发式的两种思想。
    8 O0 O( A  ?! c/ j! i- ?8 K) [! p
    % d' Z6 u) T! K2 X4 W* q总而言之就是通过遗传算法就是找到一个很贴近的全局最优解,而不是我们一般说的某个区间上的最优解。
    & n/ v) p% L7 l$ ]9 b- g- F
    : V6 [8 P; N1 s; m5 c' Q9 P3 S; h
    遗传算法的实现过程
           我们把函数曲线理解成一个一个山峰和山谷组成的山脉。那么我们可以设想所得到的每一个解就是一只袋鼠,我们希望它们不断的向着更高处跳去,直到跳到最高的山峰(尽管袋鼠本身不见得愿意那么做)。所以求最大值的过程就转化成一个“袋鼠跳”的过程。
      i3 O+ |9 [! p% n
            遗传算法的实现过程实际上就像自然界的进化过程那样。首先寻找一种对问题潜在解进行“数字化”编码的方案。(建立表现型和基因型的映射关系)然后用随机数初始化一个种群(那么第一批袋鼠就被随意地分散在山脉上),种群里面的个体就是这些数字化的编码。接下来,通过适当的解码过程之后(得到袋鼠的位置坐标),用适应性函数对每一个基因个体作一次适应度评估(袋鼠爬得越高,越是受我们的喜爱,所以适应度相应越高)。用选择函数按照某种规定择优选择(我们要每隔一段时间,在山上射杀一些所在海拔较低的袋鼠,以保证袋鼠总体数目持平。)。让个体基因变异(让袋鼠随机地跳一跳)。然后产生子代(希望存活下来的袋鼠是多产的,并在那里生儿育女)。遗传算法并不保证你能获得问题的最优解,但是使用遗传算法的最大优点在于你不必去了解和操心如何去“找”最优解。(你不必去指导袋鼠向那边跳,跳多远。)而只要简单的“否定”一些表现不好的个体就行了。(把那些总是爱走下坡路的袋鼠射杀,这就是遗传算法的精粹!

    # G: v; n- U+ H1 s* e
    所以我们总结出遗传算法的一般步骤:
           开始循环直至找到满意的解。
    1.评估每条染色体所对应个体的适应度。
    2.遵照适应度越高,选择概率越大的原则,从种群中选择两个个体作为父方和母方。
    3.抽取父母双方的染色体,进行交叉,产生子代。
    4.对子代的染色体进行变异。
    5.重复2,3,4步骤,直到新种群的产生。

    . f" C$ [: I4 O" d/ I 1.png . N9 R7 Q# v! ~. u
    2.png
    & Z8 v( m. o; o; ?: j 3.png " H: D2 _, S- S  u. h) \
    4.png
    ' k9 S2 l6 O8 ?: @; x' F 5.png , S9 i2 \  e; U& d: D+ j
    6.png ; ^- i8 x! a4 c0 [2 ~$ @7 ?1 a0 m) k
    7.png * P" m! e+ b& h' r. B
    8.png ! Q9 h9 d5 G, Q, {
    9.png
    + H" y) p' v4 p. F# g% Q9 T' _ 10.png 3 w4 D" l8 q; E- I% c
    这样子就完成了第一次迭代,经过451次迭代运算,得到最佳染色体组及相应的最佳适应度(最大函数值)为:+ c+ u. q1 s3 o! s4 `* v
    11.png 0 O1 m# O. t& c7 h7 U! g8 O
    9 {( L2 `( v6 O8 l
    ( M- ^: a% h- _0 [6 t7 j
      x' F( J5 m) B; U; d! t# P% x
    最终送大家遗传的全套例题代码,代码的解释也是傻瓜式说明,下载看了包会!!!
    2 F0 [; q% W% }2 J' `/ b4 C; V6 F3 H2 b$ q. N( m! T' |
    + M/ {/ ~" G& p. f5 ?6 p
    / S  W9 r: a3 T( z3 i
    3 l2 t, s7 q! o9 P

    代码资源.rar

    3.61 KB, 下载次数: 76, 下载积分: 体力 -2 点

    遗传全套代码

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏1 支持支持0 反对反对0 微信微信

    52

    主题

    12

    听众

    676

    积分

  • TA的每日心情
    奋斗
    2021-6-27 15:42
  • 签到天数: 27 天

    [LV.4]偶尔看看III

    版主

    国际赛参赛者

  • TA的关系
  • 群组冬令营普通班

    群组Latex研学群

    群组2018美赛护航培训课程

    群组2018美赛冲刺培训

    群组2017科技论文写作

    回复

    使用道具 举报

    ojbk        

    0

    主题

    3

    听众

    34

    积分

    升级  30.53%

  • TA的每日心情
    奋斗
    2018-11-25 01:10
  • 签到天数: 18 天

    [LV.4]偶尔看看III

    国际赛参赛者

    回复

    使用道具 举报

    3963095 实名认证       

    1

    主题

    4

    听众

    88

    积分

    升级  87.37%

  • TA的每日心情
    开心
    2020-12-31 16:13
  • 签到天数: 20 天

    [LV.4]偶尔看看III

    邮箱绑定达人

    群组2016国赛备战群组

    回复

    使用道具 举报

    豆子豆        

    0

    主题

    1

    听众

    1

    积分

    升级  20%

    该用户从未签到

    回复

    使用道具 举报

    503054785        

    0

    主题

    15

    听众

    117

    积分

    升级  8.5%

  • TA的每日心情
    开心
    2019-4-14 18:23
  • 签到天数: 12 天

    [LV.3]偶尔看看II

    自我介绍
    -
    ) Q' D3 V6 ^) O% ~6 z4 R
    6 G8 e5 n6 ]2 {8 R
    % V, g1 H; a5 }
    666666666666666666
    & D* k8 r" X3 r+ s: V( @" `
    回复

    使用道具 举报

    0

    主题

    1

    听众

    2

    积分

    升级  40%

    该用户从未签到

    回复

    使用道具 举报

    0

    主题

    1

    听众

    4

    积分

    升级  80%

    该用户从未签到

    回复

    使用道具 举报

    0

    主题

    4

    听众

    23

    积分

    升级  18.95%

  • TA的每日心情
    奋斗
    2018-9-14 11:08
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    自我介绍
    美赛嗨皮
    回复

    使用道具 举报

    873461312        

    0

    主题

    0

    听众

    1

    积分

    升级  20%

    该用户从未签到

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-12 20:41 , Processed in 0.517426 second(s), 108 queries .

    回顶部