订货管理仿真及优化
, x9 d( n b/ i% D8 c ~) V$ @系统描述:
`8 k8 v ^7 c(1)员工类型:公司有三级员工,根据技能高低分为A级员工,B级员工和C级员工。) C. i8 e" D( V: {3 `
(2)订单到达:平均每10分钟到达一个客户订单
8 Z. G% l0 j- p7 D# l; Y(3)订单处理:% `1 {1 L$ H' d6 s- L/ M9 h
a) 订单到达公司后要由工作人员进行处理,该处理由一个C级员工进行,该处理方式有两种(计算机或人工),处理时间为期望mean=10分钟(计算机)或15分钟=(人工),标准差为mean/10的正态分布。
8 ~9 N! s1 m& v! jb) 处理好的订单进入确认阶段,在该阶段,工作人员打电话和客户进行确认。该工作可以由一个B级员工或C级员工进行,处理时间均服从10-40分钟的均匀分布。
2 t4 o9 I, W0 w0 a" g* m6 uc) 经过确认的订单送到仓库进行配货,每个订单由一个A级员工进行配货,处理时间服从20-40分钟的均匀分布。0 x5 E6 O% e( J0 Z. X3 h7 f
d) 检验、包装。检验合格后进行包装、发货,否则重新进行配货。配货合格率为90%。该过程可以由一个A级员工或一个B级员工进行,根据检测设备不同处理时间为testandshiptime=45(新型设备)和50(传统设备)。# \% [3 h a) z' {) u* q2 l
(4)成本:' u) }& c7 B& L3 y! |8 \4 }
单个订单销售利润=100
Z2 b L5 n' _; O6 J) U人工成本A=80,B=70,c=60! o* K, Y1 K3 t; w. k2 ^& Q5 y3 ~
计算机处理成本=50,人工处理成本=1
7 j* S2 V7 Y& D& e4 {4 X4 F新型设备成本=60,传统设备成本=45
; x3 [9 X6 t! n3 k(5)优化目标:
4 O: _- a2 T: {. O收益最大化,其中收益=销售利润-人工成本-订单处理设备成本-检测包装设备成本
! f- A% v# h u2 `: k变量约束:$ F+ V! `1 x4 C7 W9 \
mean={15或10}7 j5 l3 B0 o8 { A i3 }! c
testandshiptime={50或45}
& O E3 N; V2 d: X: oA级员工数量={2 to 4}
0 Z. J2 \+ Q( ~8 hB级员工数量={3 to 5}( x1 C) m3 g. e. k. m+ y
C级员工数量={3 to 7}
' X% @4 r2 t7 C3 J: _7 K8 K5 u订单处理工位数={1 to 3}
# r; p- k! h' X4 D+ h n! S7 `! f/ s订单确认工位数={3 to 4}
+ E U: w: t$ d9 g检验包装工位数={3 to 7}
' n( J( N1 W( Q% t T4 F3 a 根据以上要求仿真优化,并回答结果:需要多少名A、B、C级员工?订单处理工位为多少?是计算机处理还是人工处理?订单确认工位数是多少?检验包装工位数是多少?5 U# n `7 A! }& M
- ^3 V! H: d( p7 l" N7 F# d _4 G
, A4 W+ W, ^' l' ]& {+ Z6 k5 i
7 |4 K' B( j R6 |0 M; N
& K& h2 z) J9 V- |! \7 A
8 j% Y% V" @; K' s6 f0 ?
3 `; t; }# o* e: c2 g. B1 B
, l* Y5 N e) T
$ x1 t* S% x x. T) n
* u1 F1 y2 o) B' @" c1 C7 @
+ z# R. l0 Z8 o, o, `0 E% V% `) ^
7 L+ q9 P0 J5 D目标函数程序代码(!行为解释说明,其中变量为自定义变量元素,)
3 B' W' D. w/ }$ x* `. D V.Profit = 0.5 |/ c! C, }5 q8 u" h! |+ L
V.Revenue = NSHIP (Order) * 100.02 p$ T8 i% U4 ~) L& N, j9 ~
V.Cost = NQTY (stafflevelA) * 80.0 + NQTY (StaffLevelB) * 70.0 + NQTY (StaffLevelC) * 60.0
% p; m3 M5 J3 @2 w4 l3 _ IF V.AverageLoggingTime = 15
/ u1 K+ A/ Q6 b( a V.LogCost = 1.09 M, ~. ]0 @/ H
ELSE- W5 X% t, M/ f8 Z1 @- G b# m `
V.LogCost = 50.0
$ l# u% i# y+ H* g1 @# R" B ENDIF7 F$ X0 F7 ?* [1 S5 }
IF V.TestandShipTime = 50
1 `( `$ [. y: K* U0 n U V.TestCost = 50.0
4 n, J8 k) ~- i: q, A" Z ELSE9 C9 }" j/ f& Z2 x$ R
V.TestCost = 60.0
$ `& z2 | G. _- q$ n: s! C& R6 r ENDIF
7 ?5 n0 E. [. x3 G2 Q V.Cost = V.Cost + NQTY (LoggingOrder) * V.LogCost + NQTY (Testing) * V.TestCost# {% q P3 a, v3 |7 }9 F& z
V.Profit = V.Revenue - V.Cost
& X/ `5 T: f i6 Z RETURN V.Profit2 S& q1 u. Y% o
! M! M, i" Z1 [9 l$ d6 g定义完目标函数后,菜单model->optimize..,在左上角variables定义约束条件,在右上角选择目标函数,且为最大化,左下角选择运行时间run,右下角选择算法, |