- 在线时间
- 791 小时
- 最后登录
- 2022-11-28
- 注册时间
- 2017-6-12
- 听众数
- 15
- 收听数
- 0
- 能力
- 120 分
- 体力
- 36352 点
- 威望
- 11 点
- 阅读权限
- 255
- 积分
- 13866
- 相册
- 0
- 日志
- 0
- 记录
- 1
- 帖子
- 616
- 主题
- 542
- 精华
- 12
- 分享
- 0
- 好友
- 225
TA的每日心情 | 开心 2020-11-14 17:15 |
|---|
签到天数: 74 天 [LV.6]常住居民II
 群组: 2019美赛冲刺课程 群组: 站长地区赛培训 群组: 2019考研数学 桃子老师 群组: 2018教师培训(呼伦贝 群组: 2019考研数学 站长系列 |
问题描述: 某市消防中心同时接到了三处火警电话。根据当前的火势,三处火警地点分 别需要 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
|