设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4693|回复: 3

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

[复制链接]
发表于 2010-2-2 12:03:24 | 显示全部楼层 |阅读模式
初学em-plant,要求做一个模型。现在遇到了问题,求高手不吝赐教。
# i7 J  }) |/ L" ^+ g- I/ x5 N, {" {
& ?7 |5 T) |( m; w1 _某生产车间根据订单生产。订单到达的日期可从table中读取。每笔订单会要求多件产品,各订单可能要求在不同的流水线上生产不同的产品。6 }* e3 ?! S3 L) }, F4 s

8 T1 p' q/ |) R. S: Y我现在考虑在source里产生大量的MU,同时每个MU读取table中的订单到达日期。MU从source出来后移至一buffer,在buffer中判断该MU下步该去哪个机器。同时,首先需要判断目前的模拟时间是否已经超过了订单抵达的时间。这是最重要的,这样才能与实际情况相符,即先订单后生产。
0 G# c- x5 G4 d+ g
2 y6 m  M' ^# ?' T+ X3 h, B如果我使用如下method与buffer的exit
5 `, _8 O4 a5 r; o2 a+ m# L) Y) Y" d! c$ X2 ^8 I4 J) P
if @.arrival_time < EventController.simtime
. J. D, S& d5 U0 P! }# C    then 。。。。。。。。
& H0 v$ k7 w0 [! e
/ ^) j- a9 G7 V% i% ]7 r' I@.arrival_time为MU的属性,在source中已从table读取,每个MU有各自的订单抵达时间(可能相同,即属同一订单)。此语句仅在buffer中判断一次,其后任凭新的MU进入,也不再判断。
. ]) m  E( g/ I" b. w9 a, n" l/ |* Z
如何使得buffer可以不停判断其中包含的所有MU,并且选择符合条件的运出?
 楼主| 发表于 2010-2-2 13:28:37 | 显示全部楼层
如何不按照先进先出的原则使Mu退出proc?
发表于 2010-2-4 00:26:41 | 显示全部楼层
自己编一个程序,该程序由Init调用。* Y4 y, c5 ?, L) X; O* `
用一个tablefile,第一列为产生的时间,第二列为产生的个数。/ y4 ]  r7 Q9 [
& E4 @  X0 V+ W7 M) j" |# `
程序可以这么写
2 U7 W4 `( V4 m6 l$ n! j. mwhile i < table.yDim loop
0 A2 v* c' T) e7 w7 E# l  wait table[1, i+1] - table[1, i];, c  r2 L8 O6 ^- C1 q
  for j := 1 to table[2, i] loop
; J/ j0 j. D% k+ y% _    myMU := ...create(Buffer);& s) D& b1 v0 ^2 S$ P& Z; ~& l7 o- j
  next;7 h9 U' ]4 O4 I4 P) M1 X* C
  i := i+1;* o) b0 v- V1 h
end;, f. ]9 X4 ^% r! v7 E9 E# z9 \
+ I6 Q9 c! q) s# l7 y
注意,Buffer设置无穷大。
 楼主| 发表于 2010-2-7 10:39:28 | 显示全部楼层
感谢楼上的帮助。应该可行,我去试试。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-4-18 04:24 , Processed in 0.020240 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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