QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2905|回复: 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 Y! s# I% l& k$ x9 C  Q1 e

    ; f, ], f. X. w" ^% d已知各项费用(单位略去)如表 10 所示,请为甲方 安排一个飞行计划。" x% A- I/ D2 |$ [% J3 b

    - T2 W# P8 {: R6 u1 g, s) z% ^4 a- F: x如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在 内)进行训练,模型和结果有哪些改变?
    : A6 _4 T; t4 l& W6 E+ {0 h. f, x- E: G) J

    0 \% v1 [$ h9 N+ r: S( r% d
    % u; O* F/ f5 m1 k8 \' }(1)问题分析
    8 ~+ [9 o% C# {
    # A6 E: r3 `' F/ t% n& r% X这个问题看起来很复杂,但只要理解了这个例子中所描述的事实,其实建立优化 模型并不困难。首先可以看出,执行飞行任务以及执行飞行任务后休假的熟练飞行员数 量是常数,所以这部分费用(报酬)是固定的,在优化目标中可以不考虑。. K& S4 O8 {& M5 L5 m

    / A$ Q/ ]( s* O* L% o1 [  \(2)决策变量
    % n% l  j' V2 s% \3 V2 v: J( I0 P% F- s) E; W% t
    设 4 个月开始时甲方新购买的飞机数量分别为   ( i=1,2,3,4 )架,闲置的飞机数量分别为  架。4 个月中,飞行员中教练和新飞行员数量分别为   ( i=1,2,3,4 )人,闲置的熟练飞行员数量分别为  人。 3 A* i# P( Z) W" G

    1 A6 e7 X/ s" Q! X4 e(3)目标函数
    8 w& o( N0 o2 r6 x' s( k% s8 P- B+ D$ G' z: j2 R% G
    优化目标是 ) k' p+ U9 {2 g
    , O7 M; x& h+ k/ i

    9 E& u4 P7 H- I8 ^% n# ]
    ; t+ l; d5 x: U5 o- Q; q* X1 f1 v6 v' {(4)约束条件2 F% {8 U* S& W
    ( w3 Z  B# U* e; o/ E) ^7 {2 E; B3 S
    需要考虑的约束包括:
    - [) z( V; x) `- T6 b$ o" {/ D+ _8 r, p3 a3 ?0 }
    i)飞机数量限制。4 个月中执行飞行任务的飞机分别为 100,150,150,200(架), 但只有 80,120,120,160(架)能够返回供下个月使用。
    1 Q9 r# R+ @+ q$ ]5 x5 n" |3 ]" `# p# h9 s3 ]3 ^

    " J- ^/ e/ |0 b( `9 W. k5 `7 ^& g* k' U) w
    ii)飞行员数量限制。4 个月中执行飞行任务的熟练飞行员分别为 300,450,450, 600(人),但只有 240,360,360,480(人)能够返回(下个月一定休假)。
    ) T" R5 }" C0 [4 K2 V( g2 m7 I5 j) \7 x8 v4 L

    / e& q, p4 Q" B# e0 Q
    0 T2 [6 j# k8 a$ ^4 ~(5)求解 编写 LINGO 程序如下/ J+ u; s# k0 ^( f4 ^2 X
    . A7 x4 r9 r* X, {. Y
    model: - l9 x) _/ q% w) Q: y
    sets: - Z  Y6 r' `0 d
    col/1..4/:c1,c2,c3,x,u,v,y; ' I+ j+ s/ D0 c9 @* Q9 Z
    row/1..3/:b1,b2;
    , G) ^6 x' T. J3 @% Iendsets 4 H! Y! F3 m3 A# w' n. I# D
    data:
    3 l% j1 \  ?  U- j; Mc1=200 195 190 185; 6 N* N9 h4 W; w2 j9 q6 R' {1 x
    c2=10 9.9 9.8 9.7; & p& }3 B" s6 ?  Z+ B
    c3=7 6.9 6.8 6.7;
    & R1 R5 X' U- Z, e, s" bb1=70 30 80;
    1 i( ]4 [) c' x. W; n0 d. {+ qb2=450 210 240; / |1 O+ b  h3 n, o! G
    enddata
    / k, T* S0 L$ p- b& Vmin=@sum(col:c1*x+c2*u+c3*v); 8 l9 V% Q* g- y, u
    y(1)=10; 9 i$ {$ G8 w1 K' A" ~- U' c2 i
    @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)); 4 g+ h. }/ Y5 t* R* N0 {
    end
    4 [( A5 q* |$ p6 Y$ t, W3 y1 T- Q

    ' I  V. [; x- u# v7 p3 G* s4 ^" @% n7 }' Y- u8 `& a
    6)问题讨论
    " Q; b4 u; C6 r+ V: Q# V( y3 ]2 A, s; f: t# D! v- \
    如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在内)进行训练,则应将教练与新飞行员分开。设4个月飞行员中教练为 (人),新飞行员数量分别为  (人)。其它符号不变。飞行员的数量限制约束为 + `: z4 Q$ U; P1 O( }: c1 ^

    ' ]" G0 d% j- ?( I* @) e
    " t# @. g* P6 K- ]7 F
    6 T0 ~, I1 |# s6 O( A6 U目标函数作相应修改,输入 LINGO 如下: % z: u0 y, ^  n

    5 |/ H  e  G+ u  [  R( k# dmodel:
    " Q. }5 Q# q( z: f# m  s7 gsets: 8 V% @( P0 x2 R# m0 l
    col/1..4/:- C- m3 a5 ^8 a8 `; M
    c1,c2,c3,x,u,v,w,y;
    9 D8 X4 Q6 \$ U6 Crow/1..3/:b1,b2; # `  D1 X0 X; x; K
    endsets
      w9 o( z6 i# s1 i6 t# i. \data: " z  Y+ g+ Y% U1 {
    c1=200 195 190 185; 2 \0 ^' X! R/ }! f) P
    c2=10 9.9 9.8 9.7;
      E  `3 D' k; B  }: h. cc3=7 6.9 6.8 6.7; 9 L) ~' f$ b4 N2 o7 t1 l
    b1=70 30 80;
    7 U( e- ^: s7 }! D) m: Cb2=450 210 240; ! F% \. R, a* U7 `
    enddata
    3 c' i8 N! ~5 [* W, @min=@sum(col:c1*x+c2*(u+w)+c3*v);
    ; ^# H5 t; H: O  w) K+ hy(1)=10;
    " ]1 B* ], {, V2 i; G$ k! e@for(col(i)|i#lt#4:y(i)+x(i)-y(i+1)=b1(i)); u(1)+v(1)=30;
    & t. k( M) ?2 l( ]+ |1 e@for(col(i)|i#lt#4:u(i)+v(i)+w(i)-u(i+1)-v(i+1)=b2(i));
    % B6 a; x2 P/ V* J2 s/ @( [3 T. C@for(col(i)|i#lt#4:w(i)<20*u(i)); & n* O3 F! f6 P/ t8 u* c2 S
    @for(colgin(x);@gin(u);@gin(v);@gin(w);@gin(y));
    . A( e6 a# a, ^/ |3 i- D2 kend 8 B* Y3 `" ~  \8 x" p" ^! u: R
    & l2 z- [/ ~1 h- I+ W
    3 w# G! O4 J: A6 j& W
    ————————————————& d- R2 U& Z" c* y' S
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。. _2 }8 s5 L- V. V
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89414595+ A7 s# h  I( O
    3 ]- ?9 Z/ m4 W2 h$ ?

    + G6 o5 f3 V$ ^7 W* G
    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 03:04 , Processed in 0.363761 second(s), 51 queries .

    回顶部