设为首页收藏本站

最大的系统仿真与系统优化公益交流社区

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4774|回复: 3

[求助] 如何在特定时间段后同意MU通过

[复制链接]
发表于 2010-2-2 12:03:24 | 显示全部楼层 |阅读模式
初学em-plant,要求做一个模型。现在遇到了问题,求高手不吝赐教。
6 M: `/ \: j$ I9 G8 Q# r5 ?9 C( N/ D0 L) C2 a. |9 R+ T, j7 D
某生产车间根据订单生产。订单到达的日期可从table中读取。每笔订单会要求多件产品,各订单可能要求在不同的流水线上生产不同的产品。5 V/ j# U$ B% `' ?2 }

# w7 x3 m- m' ~% |  d3 ^# x我现在考虑在source里产生大量的MU,同时每个MU读取table中的订单到达日期。MU从source出来后移至一buffer,在buffer中判断该MU下步该去哪个机器。同时,首先需要判断目前的模拟时间是否已经超过了订单抵达的时间。这是最重要的,这样才能与实际情况相符,即先订单后生产。/ f" O3 `  M( ^  G4 u% A
2 x- U; F- y+ ]
如果我使用如下method与buffer的exit" R" M1 [, C# b- J: T- S: v: A

! [, K  T( j. h+ ?/ `if @.arrival_time < EventController.simtime 2 N8 q! ~' W9 a4 {2 d5 G# G
    then 。。。。。。。。1 V5 r, D. B* f7 @
2 R' s8 y" h. L% c- k+ N
@.arrival_time为MU的属性,在source中已从table读取,每个MU有各自的订单抵达时间(可能相同,即属同一订单)。此语句仅在buffer中判断一次,其后任凭新的MU进入,也不再判断。
1 v2 r  ?" p3 T8 u! k- |, t' ~
4 v1 _! `7 o% M7 `( {如何使得buffer可以不停判断其中包含的所有MU,并且选择符合条件的运出?
 楼主| 发表于 2010-2-2 13:28:37 | 显示全部楼层
如何不按照先进先出的原则使Mu退出proc?
发表于 2010-2-4 00:26:41 | 显示全部楼层
自己编一个程序,该程序由Init调用。
5 p" v& n2 r- l用一个tablefile,第一列为产生的时间,第二列为产生的个数。
) ]. _. ~/ V. ^2 a0 q' S5 K
" p# Y8 n& q% [6 M  M5 Z程序可以这么写
; a) F! @5 {4 {2 z3 c' _while i < table.yDim loop
( S# V: e6 i4 [# J1 b3 p/ T6 L  q  wait table[1, i+1] - table[1, i];* n! Y/ a# B; `: t2 I0 E
  for j := 1 to table[2, i] loop
  g# i1 r. G2 t" `    myMU := ...create(Buffer);
/ C/ r5 M# z6 ?0 N  next;
$ l- N; ?4 Y+ o/ `0 @, p- x, Q  i := i+1;4 |8 M4 N. [( W" \
end;  T' d4 ]" B% R9 v, D; }
& u4 \# ]" ^8 e' ]6 ?7 }  J+ g
注意,Buffer设置无穷大。
 楼主| 发表于 2010-2-7 10:39:28 | 显示全部楼层
感谢楼上的帮助。应该可行,我去试试。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|手机版|SimulWay 道于仿真   

GMT+8, 2026-5-8 09:07 , Processed in 0.014295 second(s), 16 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表