QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2938|回复: 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 名飞行员(包括他 自己在内)进行训练。每名飞行员在完成一个月的飞行任务后,必须有一个月的带薪假 期,假期结束后才能再投入飞行。/ d8 l- o5 y' f" |$ P
    5 h# U; P( W4 X! Z. U
    已知各项费用(单位略去)如表 10 所示,请为甲方 安排一个飞行计划。" ^, T2 J9 ]- m1 q3 C9 [

    $ w3 H, `& ^, {: i1 s* I$ I( U: N1 T如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在 内)进行训练,模型和结果有哪些改变?
    3 j! C: L% @0 W: o  j4 k: _5 t$ I
    8 o! U; E. E1 T. x8 ~* Q  U( Y1 d9 Z- Z6 w& K  b/ {1 S) I- N
    7 h, z- u. P# S- {
    (1)问题分析
    7 K9 s0 i. G, @! e+ ^, n. y
    : V: C* |& N) Y8 r1 I  l这个问题看起来很复杂,但只要理解了这个例子中所描述的事实,其实建立优化 模型并不困难。首先可以看出,执行飞行任务以及执行飞行任务后休假的熟练飞行员数 量是常数,所以这部分费用(报酬)是固定的,在优化目标中可以不考虑。/ _& v2 s. _" s# R5 _

    : }8 S$ k/ a$ c% E9 p(2)决策变量
    ) ?  z2 Q0 E7 p' w/ a9 y
    , g8 _9 `5 A9 x% h设 4 个月开始时甲方新购买的飞机数量分别为   ( i=1,2,3,4 )架,闲置的飞机数量分别为  架。4 个月中,飞行员中教练和新飞行员数量分别为   ( i=1,2,3,4 )人,闲置的熟练飞行员数量分别为  人。 $ V( @, [& `1 H3 e' {+ V+ {
    ; |5 K) w7 ^, j9 b4 P9 y
    (3)目标函数4 o% W- _; F) _- V! B

    & e  d$ p0 D8 r" Y优化目标是 3 r8 t: Q* \# y) D3 n; {/ \$ \5 z

    / [9 t- x$ D2 O0 ~9 {2 Q+ C
    ' C& O% B0 f! r0 K  i4 I- T3 r8 C% R9 T& A
    (4)约束条件" ^/ f% ^) J0 A+ P+ K$ O9 |% j

    $ n* P+ C- z" T; ~, L2 D1 q1 Y需要考虑的约束包括:7 k8 ?% p: Q) Y; I- G

    6 a* A: ]- c, c% b' Q  H1 Gi)飞机数量限制。4 个月中执行飞行任务的飞机分别为 100,150,150,200(架), 但只有 80,120,120,160(架)能够返回供下个月使用。
    : V: d; s0 F/ H3 W* |3 J
    6 l8 L/ c1 r" A8 U. }) v
    6 j. w* F$ {4 Q+ J& O8 [( [
    5 C- p: x. h% ~7 c- n9 B0 o& sii)飞行员数量限制。4 个月中执行飞行任务的熟练飞行员分别为 300,450,450, 600(人),但只有 240,360,360,480(人)能够返回(下个月一定休假)。% b! l( }7 y+ e( A& {, A, g

    3 K; |/ @1 ~6 o! D# n' k6 H" k: a( B' t3 Z/ N
    # p+ V  Y9 M- m2 u3 U4 M8 d9 [
    (5)求解 编写 LINGO 程序如下% d# @) V( n9 O& {, B! `

    0 ?& q' }; d1 `model: 0 S' N0 n. [' [$ v3 q4 |
    sets: 8 m$ ~- n/ e4 ^
    col/1..4/:c1,c2,c3,x,u,v,y;
    ( g( G7 V: b3 Lrow/1..3/:b1,b2;
    ! F5 y9 M8 C! i2 Gendsets 6 ]" e7 _! z- G( X
    data:
    ; B( c. E/ W; j7 }. Mc1=200 195 190 185;
    $ E  U# x* R. v) y  j5 c* Qc2=10 9.9 9.8 9.7; : o: I3 D  x; ?: ^$ F6 H
    c3=7 6.9 6.8 6.7;
    & T: J. q. b0 T% I/ u/ Y* Ib1=70 30 80;
    & V, ?" C) ^. Tb2=450 210 240; 7 i9 b& _& X# w/ M2 R' n
    enddata1 w- A& v# Z$ u5 u7 _/ ?1 O, ]" L7 Q! R
    min=@sum(col:c1*x+c2*u+c3*v);
    7 r$ K+ U4 |! d* z+ K" Ny(1)=10; ! r5 L( X$ D8 f4 g) r9 R
    @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));
    % L+ _" M1 v% e6 v0 ~9 k) |end
    1 F( K! U: t9 C( C
    ; u$ E+ [7 N9 `1 r( [9 X* j$ K" Q% E" s8 e

    : k9 b0 {( b& o+ X+ f: N7 W2 v6)问题讨论
    , s/ R2 t; L5 A& C' G
    7 @5 u1 f1 h  Q: i) E; @9 ^如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在内)进行训练,则应将教练与新飞行员分开。设4个月飞行员中教练为 (人),新飞行员数量分别为  (人)。其它符号不变。飞行员的数量限制约束为 0 V: D% {- f4 m+ d' [4 p4 H
    5 u  o% K3 R) g% a

    & l- M; C# C: [. b$ X* I0 d. Z% z9 m6 R4 B$ F0 [& _* `
    目标函数作相应修改,输入 LINGO 如下: $ [$ k6 _! @* e

    # m7 U4 S* ^' p3 f& G; f, vmodel:
    * \! D! W3 h9 @sets: " O5 ^- A0 |9 e+ J$ h3 ]/ r
    col/1..4/:. b* _. ^% q( t  `' B
    c1,c2,c3,x,u,v,w,y; & n2 H- n1 Y1 \, ?; w' M
    row/1..3/:b1,b2; 5 n. r5 v" t0 J) T/ ~; B
    endsets
    $ T# y. c" I0 @3 g. l5 xdata:
    " G) H1 X% S: y* d7 R. kc1=200 195 190 185; : K$ K7 H& H9 D/ S/ Z
    c2=10 9.9 9.8 9.7; 1 r: c/ a% `0 Q/ _3 J( z
    c3=7 6.9 6.8 6.7;
    , N) j  t, ]& a3 o5 H6 `b1=70 30 80;
    7 }$ U  S6 u+ j/ @# ^% r1 K  hb2=450 210 240;
    ; k3 f- d/ m& k: u6 Yenddata * a8 V  c% Y" M" q8 w% `! u
    min=@sum(col:c1*x+c2*(u+w)+c3*v);
    ! r9 U' K  i& x7 m( E4 {y(1)=10;
      ^( P: }  R, @0 l0 @@for(col(i)|i#lt#4:y(i)+x(i)-y(i+1)=b1(i)); u(1)+v(1)=30;
    6 Y$ I! O0 Z+ `& E; [3 M@for(col(i)|i#lt#4:u(i)+v(i)+w(i)-u(i+1)-v(i+1)=b2(i)); / W9 P) T/ d' {2 S# c
    @for(col(i)|i#lt#4:w(i)<20*u(i));
    4 f8 C) T* {9 z% y5 M" b2 y@for(colgin(x);@gin(u);@gin(v);@gin(w);@gin(y));
    4 I# c# Y( \& X) f, Fend
    4 y2 `8 m  k2 K6 x" D
    . e  s& N7 r( f! B' Q7 t
    + M( d8 x: ~% Q$ R0 T7 j; a) ^————————————————/ S! y, A' Y' C5 p# X+ b
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。1 M2 c2 r# M- H
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89414595  a- M! h; F% X7 G! u; C) n

    & w, V& D0 {  w6 V9 S1 |
    " M: a+ q3 G" S, [% z3 y
    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-11 05:30 , Processed in 0.401903 second(s), 51 queries .

    回顶部