QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2942|回复: 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 名飞行员(包括他 自己在内)进行训练。每名飞行员在完成一个月的飞行任务后,必须有一个月的带薪假 期,假期结束后才能再投入飞行。% S& [. `$ a* v+ h4 {1 d

    - i) q5 I# s" ]0 ]  H" m% e已知各项费用(单位略去)如表 10 所示,请为甲方 安排一个飞行计划。
    $ @1 e0 y( c6 T# h
    1 S' G% h7 e8 w0 w- G2 a8 q如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在 内)进行训练,模型和结果有哪些改变?5 Y; p7 |3 y$ ^% D% r. M7 @

    * ^" |  ]( g% z0 G; |8 ]$ H. R- ]2 y+ m. R% T2 m* ~
    / b* p$ x# l& h4 w1 U# ]* ^+ _3 M/ j
    (1)问题分析0 v9 c0 ?  [1 p! X& [# u

    & G5 _9 p: c4 t' }. a这个问题看起来很复杂,但只要理解了这个例子中所描述的事实,其实建立优化 模型并不困难。首先可以看出,执行飞行任务以及执行飞行任务后休假的熟练飞行员数 量是常数,所以这部分费用(报酬)是固定的,在优化目标中可以不考虑。( ?+ B8 ~* m& {2 b# l
    " p8 \  M! |6 a) m, S2 X4 m" }
    (2)决策变量
    ; P" h$ h1 l. b0 b1 R. t1 Y4 _+ T, ?! n) z
    设 4 个月开始时甲方新购买的飞机数量分别为   ( i=1,2,3,4 )架,闲置的飞机数量分别为  架。4 个月中,飞行员中教练和新飞行员数量分别为   ( i=1,2,3,4 )人,闲置的熟练飞行员数量分别为  人。 , _' T% U' i7 ~7 H, a

    5 P) n0 f7 h5 ^(3)目标函数! T  _+ P+ u: y( S2 z* l6 s
    9 g6 {# }0 L0 R4 Q1 W% h
    优化目标是
    , C  w. z( H: y' H$ I) m. t- p6 f" e. y3 q
    5 ^7 h% z9 S! Q* r
    6 u" e) b5 `3 D: g
    (4)约束条件5 v+ C/ P6 n1 a* m
    ' r7 F  w1 y5 }, t6 @
    需要考虑的约束包括:
    , A5 w0 A/ d  I! P
    8 G- ~2 n# L8 m. n% Zi)飞机数量限制。4 个月中执行飞行任务的飞机分别为 100,150,150,200(架), 但只有 80,120,120,160(架)能够返回供下个月使用。 # L5 o4 g5 q  p$ Y# \4 U
    4 V: E( B0 U6 g; C* K* p
    $ _+ P- c6 ^$ V
    2 c! f; g2 l+ e1 o# D
    ii)飞行员数量限制。4 个月中执行飞行任务的熟练飞行员分别为 300,450,450, 600(人),但只有 240,360,360,480(人)能够返回(下个月一定休假)。
    : ?/ b3 \) X' n8 W6 i4 g
      i% Y+ L, a/ e$ M
    1 j9 c2 B4 v# v5 ?$ @8 ]0 d$ T' z9 e1 v
    (5)求解 编写 LINGO 程序如下, g" y& `$ n/ [$ {! M- Q7 q
    5 e& @* _* ^0 d4 X, L/ j
    model:
    1 E" Z3 o3 p; r. K# Ssets:
    : U+ }: E# b9 Q2 m: e1 ]4 _col/1..4/:c1,c2,c3,x,u,v,y;
    $ r+ c" x- k" Q6 d3 }) k/ o# n- Rrow/1..3/:b1,b2; 2 ?8 {/ V" t3 B, J. Q2 ^
    endsets
    ; o2 N2 T: `+ Q2 v1 C4 hdata:
    3 W0 n6 q; P- D  D" U, ]/ Bc1=200 195 190 185; # f1 I! h: I8 S( ^! Z6 g
    c2=10 9.9 9.8 9.7;
    8 ~8 z$ J( ?; g1 G( a, b+ L1 `c3=7 6.9 6.8 6.7; + I) b6 K% V3 x: s* [' Y( V
    b1=70 30 80; / _: ]  L. U  U$ _- P0 O, A- a
    b2=450 210 240; ( J9 [+ |7 @/ M- \* S
    enddata
    8 {  {3 I" U( _8 Xmin=@sum(col:c1*x+c2*u+c3*v); * `0 B3 r- S& E) d9 c4 V! R; T9 o
    y(1)=10; + E; U* R( C3 ^' _" w
    @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));
    # I0 i4 D6 [, p3 v: _4 H1 R7 z' rend- I/ z$ I+ L& P4 q3 M
      U6 Z( r! {' D: H1 k1 N  M  ]# j1 f

    / j. v0 d. Y4 p* O3 Z0 K9 n/ z1 R0 f4 Y9 Q6 ^2 H
    6)问题讨论 6 k" J: u* y/ e0 ?5 `
    " O9 }% q; m5 y
    如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在内)进行训练,则应将教练与新飞行员分开。设4个月飞行员中教练为 (人),新飞行员数量分别为  (人)。其它符号不变。飞行员的数量限制约束为 3 s3 H8 |) Z* H# k
    ( b; A' r1 Y" {5 Q( Z$ v

    . Z2 f7 o! G5 f6 [3 n
    % B5 j; T. L% m6 x5 ~目标函数作相应修改,输入 LINGO 如下:
    0 ]! ^( l2 ^, K  S+ T/ ~- R$ V8 r# s4 E! t- Z. k! c: J
    model: - @6 g& [9 d7 W+ _, A  a) v
    sets: % D# G' y, f. O6 v( y% b
    col/1..4/:
    : T. h8 g. r2 V% j8 P" N4 a  Nc1,c2,c3,x,u,v,w,y;
    . s7 E( r% w& Q2 A, B% u& Irow/1..3/:b1,b2;
    - c8 m. u6 X$ [+ a3 ^& O4 Yendsets
    0 F; w0 o9 \: }1 L* L6 o+ a5 cdata: % o: \% D. {+ ]
    c1=200 195 190 185;
    ) a$ p; v/ y" Z6 I9 vc2=10 9.9 9.8 9.7; $ ?2 C& {3 b. N! s" J8 E* o( [
    c3=7 6.9 6.8 6.7;
    7 J$ z& {1 }  mb1=70 30 80; 0 }1 ~" w% ]1 s2 k; Y! Q
    b2=450 210 240; 9 L$ v; |2 r! A
    enddata ( U1 ^+ H6 R9 f% W, a  J
    min=@sum(col:c1*x+c2*(u+w)+c3*v); - `# J1 C  _0 H8 _- q5 L
    y(1)=10;
    8 g# ?% T. y/ H8 e@for(col(i)|i#lt#4:y(i)+x(i)-y(i+1)=b1(i)); u(1)+v(1)=30;
    % ?, `+ B  K( Z  K( ?& [@for(col(i)|i#lt#4:u(i)+v(i)+w(i)-u(i+1)-v(i+1)=b2(i));
    5 W& X  H) N! Q; ?7 z2 |9 [@for(col(i)|i#lt#4:w(i)<20*u(i)); 3 m" c* e4 C! R9 R/ g0 c0 w" y: f6 H) U
    @for(colgin(x);@gin(u);@gin(v);@gin(w);@gin(y)); 2 J1 k* u  S' e) A' v) V
    end
    ( H( A% y; O  F$ j' m. H9 f  q2 }7 E+ X+ C+ m# m
    1 h$ t9 s4 q' q' O
    ————————————————# j- e2 P2 d( e+ o# A6 S
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。! _, j! v) |5 `3 q7 J: y
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89414595
    ! `7 F8 E* |+ @$ B" p. q4 U5 ?5 B2 p4 u; B- w' g

    4 m* d3 o$ x6 Y+ C% G9 j% [4 u! j
    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, 2026-6-14 02:14 , Processed in 0.466624 second(s), 53 queries .

    回顶部