QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3584|回复: 0
打印 上一主题 下一主题

[建模教程] 消防车调度问题 :用数学建模优化生产与服务运作中的管理问题

[复制链接]
字体大小: 正常 放大
浅夏110 实名认证       

542

主题

15

听众

1万

积分

  • TA的每日心情
    开心
    2020-11-14 17:15
  • 签到天数: 74 天

    [LV.6]常住居民II

    邮箱绑定达人

    群组2019美赛冲刺课程

    群组站长地区赛培训

    群组2019考研数学 桃子老师

    群组2018教师培训(呼伦贝

    群组2019考研数学 站长系列

    跳转到指定楼层
    1#
    发表于 2020-6-17 09:20 |只看该作者 |正序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    问题描述: 某市消防中心同时接到了三处火警电话。根据当前的火势,三处火警地点分 别需要 2 辆、2 辆和 3 辆消防车前往灭火。三处火警地点的损失将依赖于消防车到达的及时程度:记  为第 j 辆消防车到达火警地点i的时间,则三处火警地点的损失分别为
    + G2 a/ _5 {* w& O" ~& `: }  c& Z& y7 F

    3 L1 i! m9 F3 a% Z) @# m   ; 。目前可供消防中心调度的消防车正好有 7辆,分别属于三个消防站(可用消防车数量分别为 3 辆、2 辆、2 辆)。消防车从三个消 防站到三个火警地点所需要的时间如表 6 所示。应如何调度消防车,才能使总损失最 小? 3 l3 A8 ~2 s" b$ D+ {( w( `
    0 Q/ N" ]* Y* M

    8 Z. B* u6 Q2 G# ^
    : e$ V$ q8 E3 t; b. g2 _问题二:如果三处火警地点的损失分别为 ;,调度方案是否需要改变?
    4 p8 Y2 {; }9 Z# X  E$ S5 t/ p$ W+ a* G5 D, N. Z+ R8 I

    3 c0 b. G, f/ b, N. ~( b) f& q* t6 m
    (1)问题分析1 d( K  k. p3 Q' n6 R4 M; n

    4 ^) w) h# O# p- t9 l" W$ p" E) I本题考虑的是为每个火警地点分配消防车的问题,初步看来与线性规划中经典的运输问题有些类似。本题的问题可以看成是指派问题和运输问题的一种变形,我们下面首先把它变成一个运输问题建模求解。
    1 t1 y% Q0 c% i0 |: C- p1 E" t
    ) S' P: ~0 W) \# H$ A9 X9 z2 j(2)决策变量
    + N' w: w# z+ U# P1 b+ ?: H. `& n9 ?; P, g$ C8 ?
    为了用运输问题建模求解,我们很自然地把 3 个消防站看成供应点。如果直接把 3 个火警地点看成需求点,我们却不能很方便地描述消防车到达的先后次序,因此难以确 定损失的大小。下面我们把 7 辆车的需求分别看成 7 个需求点(分别对应于到达时间 . 用   表示消防站i是否向第 j 个需求点派车(1 表示派车,0表示不派车),则共有 21 个  0−1 变量.
    - x4 Z( n1 {: D
    $ j/ h( N" p: h8 ^6 Y: O  \- L. P(3)模型建立
    : ?8 A% Q* P) Y9 {: E" X9 e/ R$ t" \0 G( Y% B* F# P1 X& E4 F0 s& R
    题目中给出的损失函数都是消防车到达时间的线性函数,所以由所给数据进行简 单的计算可知,如果消防站 1 向第 6 个需求点派车(即消防站 1 向火警地点 3 派车但该 消防车是到达火警地点 3 的第二辆车),则由此引起的损失为 72 98 = × 。同理计算,可以得到损失矩阵如表 7 所示(元素分别记为 )。 1 q( {  J7 E4 b: g
    1 Y/ H4 [% L& y- q3 t
    . ^% \) I/ O( @# p
    4 G. P+ [6 Y) P0 w
    $ C6 i& I0 P+ d6 r- t$ P, V

    0 v, k, V: a* w0 I6 o8 J( c
    : J5 Z$ _2 C. P9 {, O于是,使总损失最小的决策目标为
    * U" E2 _' v$ M8 p7 x
    * u# }: w1 |9 v! \                     ( 1 )' ?% v. f1 m. u# F3 i+ H. p

    / p# S& S4 W, k" G5 i约束条件:
    1 H3 c1 w2 R; }) w3 [$ p5 d8 ?
    % h9 P7 Q% {) u& i. `约束条件有两类,一类是消防站拥有的消防车的数量限制,另一类是 各需求点对消防车的需求量限制。 ! o. @: T1 s/ F7 L
    记   ( i=1,2,3 )为第i个消防站拥有消防车的数量,则消防站拥有的消防车的数量限制可以表示为 : f" K, l# x* C1 b6 L$ L: |
                            (  2 )) k' N9 c$ K6 ?7 l+ d2 z! Z

    ( g4 }! H. P: w各需求点对消防车的需求量限制可以表示为
    ' R+ W# T9 Y/ x( A" h- V& x* N" y9 _. w# r: u+ w5 @  j9 l
               (  3 )* I- F' s5 Y/ Y* \# H. v2 @
    . u- a" z  W. t
    (4)模型求解 的lingo代码$ s7 ~* s8 t3 x
    2 A5 e* d% q/ x# h) \+ b
    MODEL:   X& x2 f; ]$ z& R; G$ u* V
    TITLE 消防车问题; 6 J. Q3 J: W' o: S. A
    SETS: . D4 \1 F  m; ]* e0 C2 E9 d; C
    supply/1..3/:b;
    % {$ R! |: W: K. W/ k. ?need/1..7/;
    4 r/ p7 {, ]3 elinks(supply,need):c,x; . S. t( ^& r; ]) X% t
    ENDSETS & S2 q* `9 M# r* _$ g. v
    [OBJ]Min=@sum(links:c*x);
    9 d5 l( W; ?. v, a2 g@FOR(supply(i):@sum(need(j):x(i,j))=b(i)); 6 D9 _/ l0 H+ q5 j( Q. _; t5 \
    @FOR(need(j):@sum(supply(i):x(i,j))=1); , ]! L( v. O0 }- k  J4 c
    DATA:
    / `' ~0 \: H0 k7 H) I4 s4 Xb=3,2,2;
    5 g9 u8 E; q9 L4 y4 F+ ^5 W( K! hc=36,24,49,21,81,72,45   ( [8 P. j: G, T; W
        30,20,56,24,99,88,55   1 Z; W/ H% L( w/ c# P# c6 t
        36,24,63,27,90,80,50; ! O" s( H- Q+ P6 Z, `# e
    ENDDATA
    $ K( v: C- O& O& H5 R) z6 j" CEND   k& K9 n; L! Q9 L4 X7 e
    求得结果为,消防站 1 应向火警地点 2 派 1 辆车,向火警地点 3 派 2 辆车;消防站 2 应向火警地点 1 派 2 辆车;消防站 3 应向火警地点 2、3 各派 1 辆车。最小总损失 为 329。
    4 p5 @2 U' f' o* J, n9 o& @- ]1 I: ?5 T, _5 Z! a$ q
    (5)讨论
    / j% i0 u+ {* r9 y* L' f
    3 F& s( U# `; a# Z" R- T; n1)这个问题本质上仍然和经典的运输问题类似,可以把每辆车到达火场看做需求点,消防站看做供应点。在上面模型中,我们虽然假设   为 0− 1变量,但求解时是采用线性规划求解的,也就是说没有加上 为 0− 1 变量或整数变量的限制条件,但求解得到的结果中   正好是 0−1 变量。这一结果不是偶然的,而是运输问题特有的一种性质.
    3 j( y* q( V& A* a3 ]  w2 R5 I0 I) F
    2 )在上面模型中,没有考虑消防车到达各火警地点的先后次序约束,但得到的结果正好满足所有的先后次序约束,这一结果不是必然的,而只是巧合。如对例题后半部 分的情形,结果就不是这样了。显然,此时只需要修改损失矩阵如表 8 所示(所示(元素仍然分别记为 )
    5 H9 U# M0 [6 F
    5 l- @2 R. y. \2 F
    + Z& g( g7 d) g  I# S" D
    + k; ?1 R9 H' v* F此时重新将式( 1 )-( 3 ) 构成的线性规划模型输入 LINGO 求解,可以得到新的最优解: 其它变量为 0(最小总损失仍为 329)' L, O" \7 C/ z/ }1 t

    $ |4 Y' e8 s$ p7 k) o9 r实际上,损失矩阵中只是 1、2 列交换了位置,3、4 列交换了位置,5、7 列 交换了位置,因此不用重新求解就可以直接看出以上新的最优解。 - a2 F8 G9 @& K4 M4 A0 O

    ) \2 |3 L) D1 R# F5 Y但是,以上新的最优解却是不符合实际情况的。例如,  表明火警地点2 的第一辆消防车来自消防站 3,第二辆消防车来自消防站 1,但这是不合理的,因为 火警地点 2 与消费站 3 有 9min 的距离,大于与消防站 1 的 7min 的距离。分配给火警 地点 3 的消防车也有类似的不合理问题。为了解决这一问题,我们必须考虑消防车到达 各火警地点的先后次序约束,也就是说必须在简单的运输问题模型中增加一些新的约 束,以保证以上的不合理问题不再出现。- n  J  |6 F  l; ^
    4 p3 x3 F* z; S
    首先考虑火警地点 2。由于消防站 1 的消防车到达所需时间(7min)小于消防站 2 的消防车到达所需时间(8 分钟),并都小于消防站 3 的消防车到达所需时间(9 分钟), 因此火警地点 2 的第二辆消防车如果来自消防站 1,则火警地点 2 的第 1 辆消防车也一 定来自消防站 1;火警地点 2 的第 2 辆消防车如果来自消防站 2,则火警地点 2 的第 1 辆消防车一定来自消防站 1 或 2。因此,必须增加以下约束:   (  4 )! t0 m: j' w; y' H" v% @$ [
    / {; `8 r1 G' F4 W6 g" ~- Z
    同理,对火警地点 1,必须增加以下约束:    (  5 )
    : E$ S! i; [' Y
    0 A7 F$ a2 R- T0 O对火警地点 3,必须增加以下约束:     ( 6 )
    : U5 L$ c2 k7 `0 F( |" V! P: J  J$ W6 z; }2 H# @
    重新将式(1)~(6)构成的整数规划模型(   是 1 0− 变量)输入 LINGO 软件如下:* G7 h2 `9 L3 d$ x2 h& V' C2 V6 W2 r
    1 v! Q  \! X* g
    MODEL:
    9 I- i* p4 p* ATITLE 消防车问题; , Y; }3 R9 `3 ^* H/ P
    SETS:
    9 M$ s+ Y2 ~! S# `/ zsupply/1..3/:b; . C1 a8 e* T) p
    need/1..7/;
    9 S) p& [+ d; y2 E2 I$ Olinks(supply,need):c,x; 5 N8 M4 S7 ]$ h. t7 e' Y9 p' Y1 ?
    ENDSETS 4 F% i( h' Y( B) o/ [& g
    [OBJ]Min=@sum(links:c*x); * `% X9 Y8 }/ g; g: H. D% Y; c% K
    @FOR(supply(i):@sum(need(j):x(i,j))=b(i));
    0 }0 }1 D1 K) t' ^# E* r@FOR(need(j):@sum(supply(i):x(i,j))=1); 8 k5 |* `. ^5 B
    x(1,4)<x(1,3); ( x' K# K- D. f* e
    x(2,4)<x(1,3)+x(2,3);   g$ q( e% ]) G" Z& Q
    x(2,2)<x(2,1);
    3 ~& I$ U) K7 P  r9 J7 }& J- |x(1,6)<x(1,5); ! o$ w. `, U9 K" D! P) \5 B% ]
    x(1,7)<x(1,6);
    8 h  x! g; ]6 ix(3,6)<x(1,5)+x(3,5); + ~, E% {) Y- C4 p
    2*x(3,7)<x(1,5)+x(1,6)+x(3,5)+x(3,6); % @) G8 M( O' h1 e  p, t) P
    @for(links:@bin(x)); # S0 i$ s6 j# S4 ]0 C
    DATA:
    / ]/ l8 d2 @: Lb=3,2,2; 6 S" a8 k0 b  `+ G: E& a3 [
    c=  24    36    21    49    45    72    81     
    6 A" r, V. {  [. ?$ y5 z- U; U" X    20    30    24    56    55    88    99     . j0 h, g8 y  T9 E! E0 }
        24    36    27    63    50    80    90;
    * d' E$ ?" L9 A. {* K1 q7 ^ENDDATA
    , E& ^! L9 S& j' ^END + Y/ \3 ?$ e9 J5 y9 O: }: v, k! h
    求解可以得到: ,其它变量为 0(最小总损失仍为 335)。也就是说,消防站 1 应向火警地点 2 派 2 辆车,向火警地点 3 派 1 辆车;消防站 2 应向火警地点 1 派 2 辆车;消防站 3 应向火警地点 3 派 2 辆车。经过检 验可以发现,此时的派车方案是合理的。 & D0 b  C; J9 ^/ z, L. r: _% v
    ————————————————
    ) w1 C) {% K3 S# {5 k9 ?版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    5 `2 \6 ?$ `1 W- ~/ Q原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89388172
    " B% L8 D8 r; t6 C& j4 _8 f9 n) a& A% m# s0 I# S
    & s4 X5 T  i1 `

    % y# L- Y! s+ C3 B) A7 k
    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-12 07:10 , Processed in 0.419123 second(s), 54 queries .

    回顶部