QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2910|回复: 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 名飞行员(包括他 自己在内)进行训练。每名飞行员在完成一个月的飞行任务后,必须有一个月的带薪假 期,假期结束后才能再投入飞行。5 K0 q! ?) B9 \6 T; R
    0 c+ u! Q3 _7 C: v9 o9 A
    已知各项费用(单位略去)如表 10 所示,请为甲方 安排一个飞行计划。5 d1 N$ U0 I" q
    5 n% K9 p1 U: a3 N% M. }. }
    如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在 内)进行训练,模型和结果有哪些改变?- y: u/ i# ?7 s9 }5 P$ w: M
    ! M- R3 x/ q; Y

    3 Q# B/ q& j$ M3 H6 w- h7 d
    0 h8 `/ N& r3 l8 w& k(1)问题分析
    - {" {7 S* ^; w- i0 C4 u
    9 v0 X  V1 e" {7 V  p& ~  k8 [( d; U这个问题看起来很复杂,但只要理解了这个例子中所描述的事实,其实建立优化 模型并不困难。首先可以看出,执行飞行任务以及执行飞行任务后休假的熟练飞行员数 量是常数,所以这部分费用(报酬)是固定的,在优化目标中可以不考虑。
    ( B( @. p- M  `8 a
    # f( b' U  }) H0 B2 T(2)决策变量 " q" x8 c! p, x. t

    1 a) t/ G: M0 C# b设 4 个月开始时甲方新购买的飞机数量分别为   ( i=1,2,3,4 )架,闲置的飞机数量分别为  架。4 个月中,飞行员中教练和新飞行员数量分别为   ( i=1,2,3,4 )人,闲置的熟练飞行员数量分别为  人。
    1 u( f7 e# j9 p- h# r& c7 g7 s2 M" V# m) s2 |# l1 x2 B- E
    (3)目标函数
    ! D; g7 Y, d8 V+ {& v) F! i: t
    0 ^) G+ A& h& d4 _优化目标是
    8 V% s% I& r% ], G: U( D$ P# ^
    $ d$ Y" a' i' T' I; Q; h6 M+ T, D2 s

      j+ ^& f1 T" S8 e% S4 m$ I(4)约束条件# H- U: G2 |# A6 H/ m
    7 z: a$ [1 A$ t# X" Q
    需要考虑的约束包括:9 l3 g! u* \. e/ s( n8 S9 X4 w
    - h7 e3 n0 W* P. p' b4 A/ L
    i)飞机数量限制。4 个月中执行飞行任务的飞机分别为 100,150,150,200(架), 但只有 80,120,120,160(架)能够返回供下个月使用。
    ( r7 r! t1 ^. e3 Y7 T
    / ]9 u$ S2 \3 J' l" N% K6 |: K, ~- C6 c' v% _: }

    7 {$ j. Y! v+ c3 N  Zii)飞行员数量限制。4 个月中执行飞行任务的熟练飞行员分别为 300,450,450, 600(人),但只有 240,360,360,480(人)能够返回(下个月一定休假)。
    6 w* F7 W9 v% |# S5 ?* r6 ~2 s5 p  i# ?$ F+ j
    . Z% [. w# f% x
    2 R- d/ O+ H  u: {3 C) i
    (5)求解 编写 LINGO 程序如下9 }- P% O( u- v

      W* V  A! F' s6 D! q7 ~# n" ^model: - r8 M, d8 _( J5 x- |
    sets:
      Y$ K( P- E9 u- A. S2 M8 dcol/1..4/:c1,c2,c3,x,u,v,y; 5 e& q. q& w$ d9 s' A+ T9 m$ Y
    row/1..3/:b1,b2; ! X; {- k. P9 `: w' R4 J& D9 m
    endsets 8 g  ~$ y5 E; j8 P
    data:
    7 N* h( p5 D; H( l6 o( i6 j) uc1=200 195 190 185;
    ; h3 G0 o  k2 g1 Z  r3 ^9 d& u3 j7 zc2=10 9.9 9.8 9.7; 0 ~  Z5 I: U0 Y) o& S& d4 ]
    c3=7 6.9 6.8 6.7; $ f3 B  @" w. C
    b1=70 30 80;
    ! W1 K, J3 v- a9 T: X' Q$ _6 Wb2=450 210 240;
    : R; |  M7 I. I4 t0 denddata4 e# v: T8 Z, Z( z: w  A" R
    min=@sum(col:c1*x+c2*u+c3*v);
    / ?" P1 b7 s1 ?9 `* D. y5 m: Ay(1)=10;
    6 p5 E" h9 T; M1 v7 W3 [" _# s2 L@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)); 8 O& d5 O" A. ~. z3 K
    end
    % o7 p/ \$ T$ c7 M' Q" ^. p9 c5 T( Y! V' t, M6 F5 I" a

    6 o7 p: u9 U0 |* q" N6 \& l9 o+ m. T, P8 w, V2 ~+ l
    6)问题讨论
    / T1 d* n' r8 \3 A+ C, ?; p1 k( X6 l, v
    如果每名熟练飞行员可以作为教练每个月指导不超过 20 名飞行员(包括他自己在内)进行训练,则应将教练与新飞行员分开。设4个月飞行员中教练为 (人),新飞行员数量分别为  (人)。其它符号不变。飞行员的数量限制约束为 7 j" R: Z) l: r0 j1 c$ ~/ h* X0 r

    # s+ d. u9 w7 c1 Y
    : Z1 A8 y+ l. ^. r4 j# t7 W( R5 ^( k4 D
    目标函数作相应修改,输入 LINGO 如下:
    ) z; Y9 c. z- H3 X
    # z! {" l% z- y6 @* i' Bmodel:
    ( m# _  p* _2 b* D6 X% Vsets:
    2 Q" ?: J- O9 c2 d( Icol/1..4/:
    9 L( {) s) w6 k- d' pc1,c2,c3,x,u,v,w,y;
    , |9 Z$ s% o7 H' irow/1..3/:b1,b2; 2 |+ g" h: r' S# ]0 _% R& W
    endsets 9 k2 E" }) L5 _
    data: & W* k: ~) V, l" g' V
    c1=200 195 190 185;
    % }5 X' Y( k) xc2=10 9.9 9.8 9.7; * o2 _  @8 z* O; b
    c3=7 6.9 6.8 6.7;   r% ?8 W6 g; H, H
    b1=70 30 80; " d  x  q" A1 f" T, a) U6 @0 w- `
    b2=450 210 240;
    7 d; j$ g- Y9 f6 t3 g. U: Menddata 5 U1 h2 Z8 _. x) z0 s+ D
    min=@sum(col:c1*x+c2*(u+w)+c3*v);
    2 y6 V) ^. }. |' W/ C7 m& u! C/ Q! fy(1)=10; # a- H, K9 f$ B: ]* E
    @for(col(i)|i#lt#4:y(i)+x(i)-y(i+1)=b1(i)); u(1)+v(1)=30; & @: a* n: G5 U( c8 `+ L& b
    @for(col(i)|i#lt#4:u(i)+v(i)+w(i)-u(i+1)-v(i+1)=b2(i)); . _6 L% Q7 |8 E  F  c
    @for(col(i)|i#lt#4:w(i)<20*u(i)); ! p# W' Q, K0 x0 c( u
    @for(colgin(x);@gin(u);@gin(v);@gin(w);@gin(y));
    & s$ {" ~4 Z0 U. t$ Nend 5 P6 Y5 _8 T  @% Y- h

    ! r, k4 F* M- g. a
    3 T4 U2 T' y$ a————————————————
    ! i. `6 Z$ J7 N$ C5 K版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    + _+ F1 P% F6 K1 W) L$ O原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89414595
    9 @' B' c$ }* _2 _2 \1 c' y- a+ \( `# j+ x, g2 A+ J( i5 d" D8 m% z

    . \0 I- M+ f! s- n9 X6 [
    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-17 06:48 , Processed in 0.419386 second(s), 51 queries .

    回顶部