设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 3825|回复: 3

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

[复制链接]
发表于 2010-2-2 12:03:24 | 显示全部楼层 |阅读模式
初学em-plant,要求做一个模型。现在遇到了问题,求高手不吝赐教。  e5 B* `. p2 Q5 U# s
1 |/ M: r1 A5 z9 s# I
某生产车间根据订单生产。订单到达的日期可从table中读取。每笔订单会要求多件产品,各订单可能要求在不同的流水线上生产不同的产品。( q' X9 F* \3 _, q+ m

2 D0 R. x6 [" v. _8 t: }0 B我现在考虑在source里产生大量的MU,同时每个MU读取table中的订单到达日期。MU从source出来后移至一buffer,在buffer中判断该MU下步该去哪个机器。同时,首先需要判断目前的模拟时间是否已经超过了订单抵达的时间。这是最重要的,这样才能与实际情况相符,即先订单后生产。( O5 u8 I# I2 T0 ~* U1 d6 ?

4 X) _: k4 l3 }/ H$ D5 A如果我使用如下method与buffer的exit
$ D0 [5 B* q( e* L
( T7 n! @$ Z+ I" m$ O, @if @.arrival_time < EventController.simtime ( Y$ X. S4 P; Z/ O7 R2 y) m
    then 。。。。。。。。6 t! i" B: C0 C; v, }

, D* }1 U3 |3 d9 F' g  M( n; g9 Q@.arrival_time为MU的属性,在source中已从table读取,每个MU有各自的订单抵达时间(可能相同,即属同一订单)。此语句仅在buffer中判断一次,其后任凭新的MU进入,也不再判断。% u: L4 W) Y# x/ ^0 y2 g9 W
+ Q+ s( T1 x2 I1 P$ t# u3 Y5 V$ A
如何使得buffer可以不停判断其中包含的所有MU,并且选择符合条件的运出?
 楼主| 发表于 2010-2-2 13:28:37 | 显示全部楼层
如何不按照先进先出的原则使Mu退出proc?
发表于 2010-2-4 00:26:41 | 显示全部楼层
自己编一个程序,该程序由Init调用。
* I' _4 [7 C2 `# w* _用一个tablefile,第一列为产生的时间,第二列为产生的个数。9 {( p3 v9 \+ Z1 M0 B

3 g! F: r: o: v4 B6 S程序可以这么写
* ?2 q: {; _( y% x+ Lwhile i < table.yDim loop
: a5 C. }3 Q8 r" [( h  wait table[1, i+1] - table[1, i];; s+ B/ ~! l& `" r) A' p9 h6 r6 S
  for j := 1 to table[2, i] loop
# n0 h7 W! o4 N! g( v# q; o3 ~% F    myMU := ...create(Buffer);$ w6 Z4 D, ?5 U. x3 f9 ^
  next;
. O, k* v+ }3 k: X0 |  v# |  i := i+1;- u7 L% F9 \) E
end;3 ^+ a; J, B# N' [

5 ^9 a8 I6 y9 f3 s+ q& F注意,Buffer设置无穷大。
 楼主| 发表于 2010-2-7 10:39:28 | 显示全部楼层
感谢楼上的帮助。应该可行,我去试试。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-14 22:48 , Processed in 0.014897 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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