QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2906|回复: 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 名飞行员(包括他 自己在内)进行训练。每名飞行员在完成一个月的飞行任务后,必须有一个月的带薪假 期,假期结束后才能再投入飞行。
    4 O9 G' d7 }. w+ _5 z# A, M  `. ^! n  \( }. f0 `% |. {
    已知各项费用(单位略去)如表 10 所示,请为甲方 安排一个飞行计划。( d, X  x' H0 l8 V; q: P3 _/ U
    ! B+ x( d0 E8 {) r/ @
    如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在 内)进行训练,模型和结果有哪些改变?
    * q$ s, e& P: t( R( k
    2 P1 h* ]- y% x: ^2 l! e' J" f' z
    ) ?& f$ a4 F* ^) x$ ~) ]8 `
    . Z# k9 d0 O9 k(1)问题分析$ I1 a- A. q2 k# A  S+ x$ q, m# U8 z
    5 X. S4 ^# W* r( Z* m' F: Z
    这个问题看起来很复杂,但只要理解了这个例子中所描述的事实,其实建立优化 模型并不困难。首先可以看出,执行飞行任务以及执行飞行任务后休假的熟练飞行员数 量是常数,所以这部分费用(报酬)是固定的,在优化目标中可以不考虑。& X% V$ j, M/ x2 x) M/ s. Y9 J3 L
    ) _5 ^7 {3 t+ ~- P6 w
    (2)决策变量 . V7 A9 }; G! P; `$ [

    ; ]6 A4 y: g7 D设 4 个月开始时甲方新购买的飞机数量分别为   ( i=1,2,3,4 )架,闲置的飞机数量分别为  架。4 个月中,飞行员中教练和新飞行员数量分别为   ( i=1,2,3,4 )人,闲置的熟练飞行员数量分别为  人。 2 t% ?. I0 W/ p5 H; f

    7 s! w8 r8 a: j9 m(3)目标函数
    " y% g! {- V, I; v: n5 o4 o$ {& Q& B+ A* F
    优化目标是 & L/ X9 n  `" G! o4 q2 x/ L

    + h& U8 m' o* H0 |6 d% \9 I: z2 u
    5 k9 e( k3 a) t/ g* k4 l0 S% d' K
    (4)约束条件
    6 V# H+ D3 E! c' @& ]% j
    ; [) y( O9 m# d  A  {) n0 v$ B需要考虑的约束包括:
    4 n$ n+ x0 T0 X& N/ J7 t
    5 \: f2 V( ]- b8 K) Ii)飞机数量限制。4 个月中执行飞行任务的飞机分别为 100,150,150,200(架), 但只有 80,120,120,160(架)能够返回供下个月使用。
    ) K: t4 F% v) @, m0 C5 R
    - j" N% M6 G3 k$ [( i3 z0 D- ?% x; Z: |. e

    + z2 b0 z3 S) f9 C6 x2 H$ vii)飞行员数量限制。4 个月中执行飞行任务的熟练飞行员分别为 300,450,450, 600(人),但只有 240,360,360,480(人)能够返回(下个月一定休假)。
    0 w0 l' R. k! D& g6 B' p
    6 ~. U% f+ z) Z# Y: x4 H
    5 ]; _7 a& V3 n$ i$ L2 _
    2 L0 a- B  x% t6 L  l& ~# m(5)求解 编写 LINGO 程序如下
    ) V( y: a  j* ^. m% j/ ?9 e" W) o0 |
    3 u5 a! ]5 d  X1 {+ M  |2 b& a9 Nmodel:
    4 |1 `- K: Y. V) [" |sets:
    4 l$ R9 Y5 u- Mcol/1..4/:c1,c2,c3,x,u,v,y; ! ?2 ~" i- u# Z1 ^2 Z) Q0 o! w
    row/1..3/:b1,b2; : |3 J! C1 e& U
    endsets
    , e' J3 V8 _8 M0 O# o" S, J4 |data: 4 `/ M5 m% ~: |' n; |2 [- O/ z) @& p
    c1=200 195 190 185;
      A: H$ i. k$ h* M% X5 Ic2=10 9.9 9.8 9.7;
    ; s- j8 ~* h* `% @$ g) L$ Xc3=7 6.9 6.8 6.7; 0 p9 W7 M3 g' w* m, M$ S* b
    b1=70 30 80;
    " M# b- F- l$ m4 @. bb2=450 210 240; 9 k" o4 w- Y; e( A& H; Q
    enddata
    7 T+ Z2 E5 q! a1 O  Mmin=@sum(col:c1*x+c2*u+c3*v); 9 b' X. x$ f2 T" v/ ], n" g
    y(1)=10;
    ; {8 c  r, Z/ c: V1 V@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));
    - p; f' g* O' @  h) F3 Lend, j* K/ S: e$ h" s( ~# i8 A$ \

    : z2 b+ @+ s! ?6 ?/ o% X' k
    / H# N6 I  U0 }+ k. C& @/ Z  m6 v. n  C! A9 d5 ^3 ^" U7 E
    6)问题讨论
    2 c+ H5 o* f# X8 T- F' Z% S/ o. O# b
    如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在内)进行训练,则应将教练与新飞行员分开。设4个月飞行员中教练为 (人),新飞行员数量分别为  (人)。其它符号不变。飞行员的数量限制约束为
    . K3 r: J: m0 @( P' Y% s+ f
    9 C( O* O1 C, Z# c$ o- f) Z
    % {2 b8 `4 p+ Q+ |
    ! I% d, B; H9 B5 t5 }9 f, }目标函数作相应修改,输入 LINGO 如下: " s  l  ^4 z& K5 ~8 s

    , C3 @" N$ s0 G1 l) B- l5 rmodel: ' y! I; q' J' V) ]
    sets: ; S1 h3 I4 r% B3 G$ y7 Z
    col/1..4/:2 i. K  k6 u7 `7 z; G
    c1,c2,c3,x,u,v,w,y;
    ' \4 ?  A; G1 |  l. Xrow/1..3/:b1,b2; % T+ g* V3 J  R% |
    endsets
    7 o* H; F# F; k8 ?: [data:
    " }# M# f6 D  k/ S# F' U: R: F$ Lc1=200 195 190 185;
    7 v4 X$ F* S3 Uc2=10 9.9 9.8 9.7;
    & c& q0 r5 `+ B3 |* Ic3=7 6.9 6.8 6.7;
    : p8 a2 w, M" g1 H8 {1 ub1=70 30 80; ( r$ A+ {' p8 [9 h# u  G
    b2=450 210 240; 4 G( R+ Y2 q/ X
    enddata : u) O8 A0 E; g/ R$ t
    min=@sum(col:c1*x+c2*(u+w)+c3*v); 8 b9 @' c- c3 @( r
    y(1)=10; 5 d" Y# W5 x. N
    @for(col(i)|i#lt#4:y(i)+x(i)-y(i+1)=b1(i)); u(1)+v(1)=30; ( m! \. S) x3 X' {/ L
    @for(col(i)|i#lt#4:u(i)+v(i)+w(i)-u(i+1)-v(i+1)=b2(i)); 5 ~. i/ b+ h2 x
    @for(col(i)|i#lt#4:w(i)<20*u(i));
    - A2 [5 o7 W+ ?. `9 b@for(colgin(x);@gin(u);@gin(v);@gin(w);@gin(y)); 7 g7 z/ w: V* x; a& S
    end
    8 G( v6 s' u) E# L$ W
    % \' A% ?( {, ~' L* c
    ! J& D: `2 z( [3 t" w1 y% m————————————————
    ( m% `# Z& ~/ N( b/ s& W版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。( P0 P: D% t& n8 P3 R3 ~% }
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89414595; Q& J- B" W9 f- C! v

    + h: ~3 c  A% q: l" G4 x# o
    $ P5 i# M& K4 [% p9 a3 n
    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-4-12 04:36 , Processed in 0.288864 second(s), 50 queries .

    回顶部