订货管理仿真及优化
# [+ y4 a7 p7 p7 v系统描述:
7 m- G+ _/ W; p, U# x. V(1)员工类型:公司有三级员工,根据技能高低分为A级员工,B级员工和C级员工。
9 p" [# Q9 A4 D$ P(2)订单到达:平均每10分钟到达一个客户订单& b W0 j% B. _6 T/ r7 A: z
(3)订单处理:* M( [( c6 ]& a, L$ S+ ?2 v b
a) 订单到达公司后要由工作人员进行处理,该处理由一个C级员工进行,该处理方式有两种(计算机或人工),处理时间为期望mean=10分钟(计算机)或15分钟=(人工),标准差为mean/10的正态分布。
% ~3 G0 ?# ]/ R8 Zb) 处理好的订单进入确认阶段,在该阶段,工作人员打电话和客户进行确认。该工作可以由一个B级员工或C级员工进行,处理时间均服从10-40分钟的均匀分布。2 N1 q/ @: \/ y) ^" B
c) 经过确认的订单送到仓库进行配货,每个订单由一个A级员工进行配货,处理时间服从20-40分钟的均匀分布。
8 o1 O0 v- V2 U0 q0 \# h5 P0 i% qd) 检验、包装。检验合格后进行包装、发货,否则重新进行配货。配货合格率为90%。该过程可以由一个A级员工或一个B级员工进行,根据检测设备不同处理时间为testandshiptime=45(新型设备)和50(传统设备)。
# o6 [2 t9 @* E8 J5 B. s(4)成本:
# [" {) ^2 l! J0 }( \0 ^- z单个订单销售利润=1001 o" w+ Z8 r6 [% }9 x
人工成本A=80,B=70,c=60
6 U5 S' P' l6 E& g E; J& S* q计算机处理成本=50,人工处理成本=18 @6 j! P% y- \* G; m
新型设备成本=60,传统设备成本=455 u$ U3 ~" ?* F: N; q+ `; b% @ k
(5)优化目标:
! M1 \% [1 H( F2 k0 i收益最大化,其中收益=销售利润-人工成本-订单处理设备成本-检测包装设备成本
* I! r { W4 h$ C. p9 s% ?7 G+ K8 L" W变量约束:
- i1 n! L8 P' _' ?mean={15或10}2 ]' u, D. H7 u [6 K! \7 T) |
testandshiptime={50或45}% c h1 _! C9 v) M, p0 g" P
A级员工数量={2 to 4}
. a$ q- [7 C% B% }B级员工数量={3 to 5}
. V* x1 u: }# U, Q( e0 k7 p- ]" r dC级员工数量={3 to 7}4 k3 g; s1 {; N& }+ H. z+ f8 ?
订单处理工位数={1 to 3}* n; U4 g" O; J$ k1 ~& I
订单确认工位数={3 to 4}) W- @- S) o; Z, \9 ]0 |. z
检验包装工位数={3 to 7}
d) u( E; B2 y0 G) J9 a# D+ C& U 根据以上要求仿真优化,并回答结果:需要多少名A、B、C级员工?订单处理工位为多少?是计算机处理还是人工处理?订单确认工位数是多少?检验包装工位数是多少?
6 Z; B7 o/ Y" ?( v6 o) Z) b" q; B' {5 O, y+ L$ H
# t8 d4 v& I' w7 e' I$ I6 y2 o& G; r8 |; H( ^' l
8 J1 F" U, P3 m: H8 r: j. n
% z J; {, M5 g/ `0 M, m; C7 B0 b. _: m
, }4 p0 ^) C% y. k. u! Y% J
1 K1 J! A1 y# U6 L3 z6 W2 U, L% A: l9 x: G( A; I
: t" r8 |, C$ Z, d
1 F. z) `3 O) z& G
目标函数程序代码(!行为解释说明,其中变量为自定义变量元素,)
) [3 U# N% r* d0 [; o+ m' F V.Profit = 0.
) f! f- _( A' [, ~ V.Revenue = NSHIP (Order) * 100.0& u2 j1 d; j; h* F# H
V.Cost = NQTY (stafflevelA) * 80.0 + NQTY (StaffLevelB) * 70.0 + NQTY (StaffLevelC) * 60.03 I9 \# u3 Z! U6 A. s' ~+ h# T
IF V.AverageLoggingTime = 15
' G% p: |# ^0 N: u/ d V.LogCost = 1.0
' I. l2 L5 u# E$ N& s ELSE
- ^5 o0 N7 ]: M4 Z" Z: O4 S7 U V.LogCost = 50.0
8 V8 f1 [+ n# C C4 B ENDIF
) w$ d4 D, R2 a+ w IF V.TestandShipTime = 50 $ z5 Z; R- x+ p2 d5 A
V.TestCost = 50.0, r8 |9 e4 Z( }( d
ELSE
! K/ U+ \0 T2 Q; }7 D V.TestCost = 60.0
0 n2 c1 b3 N6 r% p! _ ENDIF, i$ N9 ]& J t: g, r
V.Cost = V.Cost + NQTY (LoggingOrder) * V.LogCost + NQTY (Testing) * V.TestCost# @/ \/ D# i- ~
V.Profit = V.Revenue - V.Cost0 ?3 c0 ]" R6 x* K! w
RETURN V.Profit
# `2 e- Q' D* T1 M
9 g4 j5 I4 l+ |' a定义完目标函数后,菜单model->optimize..,在左上角variables定义约束条件,在右上角选择目标函数,且为最大化,左下角选择运行时间run,右下角选择算法, |