订货管理仿真及优化& C- R1 H/ r2 H: l: ?6 q
系统描述:
2 ^% q) s. S1 {(1)员工类型:公司有三级员工,根据技能高低分为A级员工,B级员工和C级员工。+ U6 R6 y I! A
(2)订单到达:平均每10分钟到达一个客户订单+ K' i4 a! o# v) ~' m3 P: v' d
(3)订单处理:
: P7 w- |0 B7 `: ea) 订单到达公司后要由工作人员进行处理,该处理由一个C级员工进行,该处理方式有两种(计算机或人工),处理时间为期望mean=10分钟(计算机)或15分钟=(人工),标准差为mean/10的正态分布。
" ?. R9 G# [# K) s2 Kb) 处理好的订单进入确认阶段,在该阶段,工作人员打电话和客户进行确认。该工作可以由一个B级员工或C级员工进行,处理时间均服从10-40分钟的均匀分布。
( s3 v- K% x k! Q& qc) 经过确认的订单送到仓库进行配货,每个订单由一个A级员工进行配货,处理时间服从20-40分钟的均匀分布。- S( ~& c" L* j* P9 D1 i( O: v1 a
d) 检验、包装。检验合格后进行包装、发货,否则重新进行配货。配货合格率为90%。该过程可以由一个A级员工或一个B级员工进行,根据检测设备不同处理时间为testandshiptime=45(新型设备)和50(传统设备)。
, F K4 H) X; i" |( I6 V, I(4)成本:4 {# Y; {" Y" f" G3 C
单个订单销售利润=100
7 N6 R; X7 u, a6 ?- R) D9 q人工成本A=80,B=70,c=60) ^- R' E# R3 {' ^$ A( c7 A
计算机处理成本=50,人工处理成本=11 P8 r8 {. _8 g
新型设备成本=60,传统设备成本=45
- V3 N j" g4 {4 J7 y- z7 Y2 m9 v% ^(5)优化目标:( }1 E, p# ^9 n+ s) u
收益最大化,其中收益=销售利润-人工成本-订单处理设备成本-检测包装设备成本7 c( V- J) Y6 k9 M' O/ ]/ @! f
变量约束:% o, G/ o% x3 |+ q1 N1 S6 ~
mean={15或10}* e9 E* |& X) m5 A- L
testandshiptime={50或45}
- `. }. q% @9 |; FA级员工数量={2 to 4}) W* q5 n/ Y7 K) R1 ~
B级员工数量={3 to 5}
3 I. Z7 r. k& d$ P7 j' Y( yC级员工数量={3 to 7}
4 f) c$ B/ x+ T订单处理工位数={1 to 3}
9 c+ o% Q/ G2 s订单确认工位数={3 to 4}
. Q% T C+ {+ y6 F检验包装工位数={3 to 7}4 L3 O# |, m' p! l% F' C. h
根据以上要求仿真优化,并回答结果:需要多少名A、B、C级员工?订单处理工位为多少?是计算机处理还是人工处理?订单确认工位数是多少?检验包装工位数是多少?
% V- B+ M: m) k# K+ t+ J' U, }1 |5 y: }, l8 H- t$ n8 U) E3 `2 G
3 o# X7 |+ v! t) p
4 S$ w' o, d5 F/ h( ~0 o4 S: o$ z5 a) o: I
. i2 @: w4 z: D4 c
( R/ x4 T9 O% Y6 ?# } R) i8 F7 a3 K1 y/ o! v) M. o* j) Q
0 o; f1 Y6 U" L9 L8 @, V
- m6 S: A1 `3 ~/ u7 Q/ w T; Q" }% I: ~+ p3 [0 ^7 f
0 g3 {6 m% d, W1 G, @, @目标函数程序代码(!行为解释说明,其中变量为自定义变量元素,)
4 E* ^4 G+ G9 E6 S3 u. W V.Profit = 0.& i$ F( {! ? f) C( w G9 p
V.Revenue = NSHIP (Order) * 100.0
# Y) w2 N- p: u+ D( @ V.Cost = NQTY (stafflevelA) * 80.0 + NQTY (StaffLevelB) * 70.0 + NQTY (StaffLevelC) * 60.0
: v- c8 Q1 M3 L IF V.AverageLoggingTime = 15 ; I% A' J- L2 L5 w$ _; ^# Z
V.LogCost = 1.0
. L" Y. O x) g7 z! s7 E0 ~ ELSE7 f2 B- y, n% m" ?, N! i3 Y
V.LogCost = 50.0
+ k t4 c0 G5 Q: K4 F ENDIF
. ~# U& P/ `+ S2 V: r8 K IF V.TestandShipTime = 50 3 @6 s( `% @: E* z# a, }% ^# i
V.TestCost = 50.0* u0 D5 r$ ]) ~4 h7 J# @5 Z( @* l
ELSE
, I9 C& }: t5 X6 B( o* Z/ o V.TestCost = 60.0
+ s) e6 l/ w1 h# c ENDIF: f' k- f# U! J0 u# d3 X: J7 Q
V.Cost = V.Cost + NQTY (LoggingOrder) * V.LogCost + NQTY (Testing) * V.TestCost
5 {) A" b- Q9 X6 Z7 t$ b. A V.Profit = V.Revenue - V.Cost
" i' O& m. k0 L0 f! A, B* l! E7 l RETURN V.Profit
( }$ C3 [, O1 F7 d$ U1 `+ J1 A' A, m( a* [" h9 T- m3 L( a
定义完目标函数后,菜单model->optimize..,在左上角variables定义约束条件,在右上角选择目标函数,且为最大化,左下角选择运行时间run,右下角选择算法, |