QQ登录

只需要一步,快速开始

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

[建模教程] 飞行计划安排问题

[复制链接]
字体大小: 正常 放大
浅夏110 实名认证       

542

主题

15

听众

1万

积分

  • TA的每日心情
    开心
    2020-11-14 17:15
  • 签到天数: 74 天

    [LV.6]常住居民II

    邮箱绑定达人

    群组2019美赛冲刺课程

    群组站长地区赛培训

    群组2019考研数学 桃子老师

    群组2018教师培训(呼伦贝

    群组2019考研数学 站长系列

    跳转到指定楼层
    1#
    发表于 2020-6-16 10:05 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    例题:这个问题是以第二次世界大战中的一个实际问题为背景,经过简化而提出来 的。在甲、乙双方的一场战争中,一部分甲方部队被乙方部队包围长达 4 个月。由于乙 方封锁了所有水陆交通要道,被包围的甲方部队只能依靠空中交通维持供给。运送 4 个月的供给分别需要 2,3,3,4 次飞行,每次飞行编队由 50 架飞机组成(每架飞机需 要 3 名飞行员),可以运送 10 万吨物质。每架飞机每个月只能飞行一次,每名飞行员每 个月也只能飞行一次。在执行完运输任务后的返回途中有 20%的飞机会被乙方部队击 落,相应的飞行员也因此牺牲或失踪。在第 1 个月开始时,甲方拥有 110 架飞机和 330 名熟练的飞行员。在每个月开始时,甲方可以招聘新飞行员和购买新飞机。新飞机必须 经过一个月的检查后才可以投入使用,新飞行员必须在熟练飞行员的指导下经过一个月 的训练才能投入飞行。每名熟练飞行员可以作为教练每个月指导 20 名飞行员(包括他 自己在内)进行训练。每名飞行员在完成一个月的飞行任务后,必须有一个月的带薪假 期,假期结束后才能再投入飞行。7 m2 o' l" M$ P

    ; [" g! n& A  \* E已知各项费用(单位略去)如表 10 所示,请为甲方 安排一个飞行计划。8 u# k) E; p" x/ Q
    ) Q6 p" ~% \; p0 _8 p8 S
    如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在 内)进行训练,模型和结果有哪些改变?  V5 u( r) ~6 k6 s6 r

    0 r& C: D3 e5 `$ D2 R4 X- _; ~  j/ z! z3 e, b/ C" o
    7 T0 ]+ c- @' u# h! o
    (1)问题分析4 {( y8 j- s1 M1 E+ p* M
    5 I7 w" U  q4 K) V' l& I  i' Y. M
    这个问题看起来很复杂,但只要理解了这个例子中所描述的事实,其实建立优化 模型并不困难。首先可以看出,执行飞行任务以及执行飞行任务后休假的熟练飞行员数 量是常数,所以这部分费用(报酬)是固定的,在优化目标中可以不考虑。
    . H, k+ b3 i! S4 k; H+ O1 X* r0 R7 s4 d! i
    (2)决策变量
    2 q4 ], [; r% O
    7 I; M5 r/ R' T- \( |$ h& [设 4 个月开始时甲方新购买的飞机数量分别为   ( i=1,2,3,4 )架,闲置的飞机数量分别为  架。4 个月中,飞行员中教练和新飞行员数量分别为   ( i=1,2,3,4 )人,闲置的熟练飞行员数量分别为  人。
    $ p0 ^0 K3 u: h1 `. `9 a8 ^' S7 F; }( ?- X& l# F, _4 H
    (3)目标函数
    6 t0 |2 U: m8 e# J2 q4 q! o  I6 x) R# e! M& N% X
    优化目标是
    " c, M; Z5 \4 |' ~
    4 G( V2 I1 Z  m. s" q: g' c$ O5 F2 f7 Y' W* j. N0 o

    % k3 {! _7 Y  U(4)约束条件9 Y- v' k/ _1 Z/ ]0 L" j

    1 F0 r+ P/ {8 o需要考虑的约束包括:
    1 L4 g8 E, H( u$ y) ~9 M
    9 P$ V" m4 |  Z' O) ^4 }i)飞机数量限制。4 个月中执行飞行任务的飞机分别为 100,150,150,200(架), 但只有 80,120,120,160(架)能够返回供下个月使用。
    9 E1 q& W: Z/ @$ A: X1 a, G; I8 E$ W; T: r5 k: i

    . m; v* P9 R; n% i: G" H' }6 ^9 ]3 L7 f( E* L0 Y
    ii)飞行员数量限制。4 个月中执行飞行任务的熟练飞行员分别为 300,450,450, 600(人),但只有 240,360,360,480(人)能够返回(下个月一定休假)。) Q- p: ~* M  _* ^, J

    0 }3 ?' [. i: R5 r/ H# S. z: c: |4 S" G& x. `, a
    0 N+ {7 |" c8 o: R7 x
    (5)求解 编写 LINGO 程序如下4 `% N# d& H+ o; ?8 K
    $ `7 d. W3 |7 v/ Y6 e! N
    model: # D% R+ e, B& m# h) B' n8 L8 l! ?
    sets: ' C4 q7 q: z+ F
    col/1..4/:c1,c2,c3,x,u,v,y;
    / t& u# T7 ^* }% }$ c$ ]row/1..3/:b1,b2;   J% ]7 U+ V! k$ X
    endsets : h% V- @0 a7 U7 D& _1 {0 P# ^. O5 m
    data: # ~, Y3 n% t8 w5 t$ a
    c1=200 195 190 185;
    ( m# m% r2 j4 O$ T% Y. kc2=10 9.9 9.8 9.7;
    - P$ G: e7 ~; g7 E4 O* M8 }0 bc3=7 6.9 6.8 6.7; 0 c. l- l8 V6 e/ Q. e
    b1=70 30 80;
    3 a$ M, P: t) D$ C& ~, `- j2 i" I4 ]b2=450 210 240; " z6 U) G- |2 z4 V. @  K
    enddata6 Y0 a9 Q  E  B* J
    min=@sum(col:c1*x+c2*u+c3*v); ) H9 m' g( }+ \$ I2 {: P7 @4 M( l
    y(1)=10; 6 g. x# V$ p8 b1 S3 J" U6 ?3 X
    @for(col(i)|i#lt#4:y(i)+x(i)-y(i+1)=b1(i)); 0.05*u(1)+v(1)=30; @for(col(i)|i#lt#4:u(i)+v(i)-0.05*u(i+1)-v(i+1)=b2(i)); @for(colgin(x);@gin(u);@gin(v);@gin(y));
    $ U  w: O8 @' T9 D1 bend
    2 `1 M& p8 k" h+ h" A( \; s1 b/ t% S4 e  z
    2 ^' [9 g- k3 ~/ }9 l0 S  y8 K
    5 y* X+ {* x' s  q1 ^
    6)问题讨论
    & i2 u5 F! [* ^3 N' E  V
    : a( w2 X. c/ K, l( O4 z8 `如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在内)进行训练,则应将教练与新飞行员分开。设4个月飞行员中教练为 (人),新飞行员数量分别为  (人)。其它符号不变。飞行员的数量限制约束为
    4 n3 r3 H- ~, @* w2 v1 D/ m! i
    ) [( G/ l: i# F. g: S' ^
    % @3 W  ^/ n% F1 f2 p4 {& q: {& l2 H# r  P3 q! _' ^8 r
    目标函数作相应修改,输入 LINGO 如下:
    # I- |: q7 X8 v- d: r' K9 X1 e
    $ F- q* Y/ z  z0 Dmodel:
    6 {) E- y( t* S3 [  Lsets:
    ( ^& A  t3 h" i- q- M" {col/1..4/:
    1 I; K, H0 J" @c1,c2,c3,x,u,v,w,y;
    9 m3 u: y9 y. Q  {/ ^; [. k; Wrow/1..3/:b1,b2;
    8 r% z2 R4 X- B3 j! }endsets 1 v+ z0 t5 ^; N: X" y  L
    data:
    ' u4 A' ~) ]* ]- C( a4 V* \+ M5 ec1=200 195 190 185; ) t( u8 ^  @" J6 [( _% T7 }1 j8 V
    c2=10 9.9 9.8 9.7;
    " t6 J2 Q  |4 F+ Lc3=7 6.9 6.8 6.7;
    ! Y5 M- R1 J8 l8 p9 O0 y9 nb1=70 30 80; / i8 R5 S/ y& N5 ?* g' C  L
    b2=450 210 240; $ o  r/ ~9 A3 _; Q; z' ^6 g
    enddata * |1 C( V5 U" |9 F& _
    min=@sum(col:c1*x+c2*(u+w)+c3*v); 6 p2 v8 b! r; o) p4 j) a! Y
    y(1)=10;
    7 b2 s) a3 w! w/ M@for(col(i)|i#lt#4:y(i)+x(i)-y(i+1)=b1(i)); u(1)+v(1)=30; 1 @2 K% Y! M( ~) |0 b5 W: T
    @for(col(i)|i#lt#4:u(i)+v(i)+w(i)-u(i+1)-v(i+1)=b2(i));
    7 u2 V# Z  W  {7 V@for(col(i)|i#lt#4:w(i)<20*u(i)); 3 D) ~. }) D5 Y4 |
    @for(colgin(x);@gin(u);@gin(v);@gin(w);@gin(y));
    ( p- s0 B& ^9 X+ {, hend
    $ [9 c7 |. w% q* t0 A& H& ]  y' u" V# D" z

      s8 \: z+ v  }) W" ~————————————————6 h- `) z8 f* P9 c+ l: x) x
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。: J% s1 t+ F2 M( ?6 m  q$ x" r
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/894145950 y9 y  |' b: s* D5 p
    ' O* ^! D% E( t' P3 Y
    / r& i( L8 P3 D( ~- [
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2025-6-20 02:54 , Processed in 0.390009 second(s), 50 queries .

    回顶部