设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4059|回复: 3

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

[复制链接]
发表于 2010-2-2 12:03:24 | 显示全部楼层 |阅读模式
初学em-plant,要求做一个模型。现在遇到了问题,求高手不吝赐教。
. u+ Z( G3 ?! I8 k6 y) g) P
2 s7 y" ~/ E0 e* H" R- ^  q某生产车间根据订单生产。订单到达的日期可从table中读取。每笔订单会要求多件产品,各订单可能要求在不同的流水线上生产不同的产品。; T9 |# Z" j" H3 y! q" C
8 H" b) M; m6 E0 @. O8 h1 w, I
我现在考虑在source里产生大量的MU,同时每个MU读取table中的订单到达日期。MU从source出来后移至一buffer,在buffer中判断该MU下步该去哪个机器。同时,首先需要判断目前的模拟时间是否已经超过了订单抵达的时间。这是最重要的,这样才能与实际情况相符,即先订单后生产。
/ Y7 s9 b+ w/ K1 I1 V( U
2 [/ l; \7 i: h5 Y如果我使用如下method与buffer的exit% v1 r! }" K% T; N. y- m

' s( X4 b8 h( E) b# H3 B2 [8 Qif @.arrival_time < EventController.simtime
8 V3 O  u1 R! `% s; k7 z* _    then 。。。。。。。。
* i, c$ G% I" d2 A, [$ u% q# A. D8 Y& B" S9 `
@.arrival_time为MU的属性,在source中已从table读取,每个MU有各自的订单抵达时间(可能相同,即属同一订单)。此语句仅在buffer中判断一次,其后任凭新的MU进入,也不再判断。
$ i0 o( X. d' b
1 z8 i6 a3 Y; c' q. K& [2 e如何使得buffer可以不停判断其中包含的所有MU,并且选择符合条件的运出?
 楼主| 发表于 2010-2-2 13:28:37 | 显示全部楼层
如何不按照先进先出的原则使Mu退出proc?
发表于 2010-2-4 00:26:41 | 显示全部楼层
自己编一个程序,该程序由Init调用。
  s) T; V3 ^. D# G; }用一个tablefile,第一列为产生的时间,第二列为产生的个数。* j' p* Z3 q- {6 p. `/ F

# @, \4 M0 I1 I3 c5 g9 M8 z( V程序可以这么写# H$ d  @; Q7 V/ q% G
while i < table.yDim loop! Q' o! B9 G0 f* ?
  wait table[1, i+1] - table[1, i];7 {9 u" H5 z0 U' K! N6 e
  for j := 1 to table[2, i] loop
3 o( H0 [* n4 D  w& U9 F7 F2 ~    myMU := ...create(Buffer);8 ~7 }5 u/ I" D/ _7 y( K6 _
  next;5 s  R7 t3 G/ s! e3 {$ `% T0 L* c3 D, L2 Q
  i := i+1;
8 Q- K* i2 D6 O. d# r3 ?. Yend;% a( D) P- }5 E# t2 b

1 _. @  o4 ^& t) |( ]( i注意,Buffer设置无穷大。
 楼主| 发表于 2010-2-7 10:39:28 | 显示全部楼层
感谢楼上的帮助。应该可行,我去试试。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-11-6 16:52 , Processed in 0.014864 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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