订货管理仿真及优化
2 X* L, m( S& B+ r- u, x系统描述:( F. r! a$ Y; T- u8 J2 B
(1)员工类型:公司有三级员工,根据技能高低分为A级员工,B级员工和C级员工。
: F3 b/ w; K- R8 i: v(2)订单到达:平均每10分钟到达一个客户订单1 ?" ~( Y" l/ t4 U; ~8 v7 O
(3)订单处理:
& a* Z* q# b6 y% @$ s/ W+ k4 G5 oa) 订单到达公司后要由工作人员进行处理,该处理由一个C级员工进行,该处理方式有两种(计算机或人工),处理时间为期望mean=10分钟(计算机)或15分钟=(人工),标准差为mean/10的正态分布。8 k, f$ ]$ @9 o9 j, O& R# k' C
b) 处理好的订单进入确认阶段,在该阶段,工作人员打电话和客户进行确认。该工作可以由一个B级员工或C级员工进行,处理时间均服从10-40分钟的均匀分布。+ d; {' x2 W) S9 L
c) 经过确认的订单送到仓库进行配货,每个订单由一个A级员工进行配货,处理时间服从20-40分钟的均匀分布。
* U; q) N6 e- a7 }* f- X1 {d) 检验、包装。检验合格后进行包装、发货,否则重新进行配货。配货合格率为90%。该过程可以由一个A级员工或一个B级员工进行,根据检测设备不同处理时间为testandshiptime=45(新型设备)和50(传统设备)。/ Q$ J$ K* \: t2 F
(4)成本:: }: F- V% ~0 p! Z" v+ Z1 a
单个订单销售利润=1009 L6 L7 I, B8 v
人工成本A=80,B=70,c=60
+ k" w" D2 M" p计算机处理成本=50,人工处理成本=1
2 \8 x1 ^, S& Z1 C新型设备成本=60,传统设备成本=45# E7 z& o8 q4 M
(5)优化目标:" F( c% N3 A2 A7 {$ v1 ^0 T1 l1 s
收益最大化,其中收益=销售利润-人工成本-订单处理设备成本-检测包装设备成本) y) i3 U9 h6 y
变量约束:
( P% C, ^$ g, b7 m0 mmean={15或10}0 `# c9 }5 K$ Q
testandshiptime={50或45}
" a9 s. u% [9 O& tA级员工数量={2 to 4} R" V) x) ?" h q9 @, F
B级员工数量={3 to 5}& T, m; O- B2 h3 @- D- `
C级员工数量={3 to 7}( U& Y# L" S5 e
订单处理工位数={1 to 3}% M3 ^+ }2 B ]
订单确认工位数={3 to 4}' C) A' e. h; o, H0 ]) K
检验包装工位数={3 to 7}0 c* `. Q8 N' Y, ?3 _
根据以上要求仿真优化,并回答结果:需要多少名A、B、C级员工?订单处理工位为多少?是计算机处理还是人工处理?订单确认工位数是多少?检验包装工位数是多少?
+ d6 b" w% O0 r" k" c, t$ R
. U2 e( Z. H% q; y$ |9 u/ U( Z7 x) u2 E
5 R6 V. @) ^/ v/ x
# R N9 ?2 _ k8 d, |$ n7 W
$ J, V& |' S# y# F. V |4 E) I& F) g; }8 o, a( b5 k- b
{3 ]0 P c) ^: D8 E3 u
, s. T! e/ w: u* f9 H
( H9 ?' c6 w+ y0 H) A, b& Z m7 ^
: S& @ x" v$ v2 `& m- @( d
目标函数程序代码(!行为解释说明,其中变量为自定义变量元素,)7 r9 h# d8 X7 q2 ~
V.Profit = 0.- u% J0 f, p, S( t
V.Revenue = NSHIP (Order) * 100.09 A$ ^9 A, M# I* W9 H
V.Cost = NQTY (stafflevelA) * 80.0 + NQTY (StaffLevelB) * 70.0 + NQTY (StaffLevelC) * 60.0+ y/ J5 Q% T/ f! m) m" {: @( G
IF V.AverageLoggingTime = 15
$ X- f) r$ J0 B! K4 H V.LogCost = 1.0' u- W; v6 O* S2 z0 M
ELSE0 s" z/ V3 g+ `5 W2 Z3 ?: y* Z
V.LogCost = 50.0
7 T+ S* q; v' \/ m2 H ENDIF
) _* D& `8 K$ J) Y0 V; z# a IF V.TestandShipTime = 50
5 a! J% z1 H( Z V.TestCost = 50.0( H( ~" ?( ^+ ]$ v: K
ELSE
) {) I( c- C5 v2 U V.TestCost = 60.0# f- B! Z" b" @
ENDIF: z. F& J% E8 b5 l& r, ]! M
V.Cost = V.Cost + NQTY (LoggingOrder) * V.LogCost + NQTY (Testing) * V.TestCost
/ P" _9 }; R7 v) X4 V3 m+ } V.Profit = V.Revenue - V.Cost: p5 c" H- N, A& d2 N) I
RETURN V.Profit
6 |1 b$ u U4 _& R( ~
. W: \- I0 P# ?- ^( e定义完目标函数后,菜单model->optimize..,在左上角variables定义约束条件,在右上角选择目标函数,且为最大化,左下角选择运行时间run,右下角选择算法, |