设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4983|回复: 3

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

[复制链接]
发表于 2010-2-2 12:03:24 | 显示全部楼层 |阅读模式
初学em-plant,要求做一个模型。现在遇到了问题,求高手不吝赐教。& ^8 O: T$ g! @1 @3 i' n; Z5 `* v

. C: d& {6 S$ O某生产车间根据订单生产。订单到达的日期可从table中读取。每笔订单会要求多件产品,各订单可能要求在不同的流水线上生产不同的产品。
: \3 r( }6 R$ {0 L- t' X9 L/ b+ ]: e! c/ h
我现在考虑在source里产生大量的MU,同时每个MU读取table中的订单到达日期。MU从source出来后移至一buffer,在buffer中判断该MU下步该去哪个机器。同时,首先需要判断目前的模拟时间是否已经超过了订单抵达的时间。这是最重要的,这样才能与实际情况相符,即先订单后生产。4 g/ q+ u6 P5 F5 G& A. j. Z; y4 G5 ^
; r5 h# l/ J+ @; x
如果我使用如下method与buffer的exit
( o6 d( ]9 ]( V! w; t! b$ ]: I* L+ Q+ B: l. E7 y6 {
if @.arrival_time < EventController.simtime
7 ?" }# R" k5 D$ C3 Q" k  |" Q9 a    then 。。。。。。。。
/ Y. c! ]+ s3 S/ f# Q8 g1 b8 |. o7 U
6 S; P: P* p/ q@.arrival_time为MU的属性,在source中已从table读取,每个MU有各自的订单抵达时间(可能相同,即属同一订单)。此语句仅在buffer中判断一次,其后任凭新的MU进入,也不再判断。4 a* s/ L2 V' u

' D/ Z- `% n  `- r6 {如何使得buffer可以不停判断其中包含的所有MU,并且选择符合条件的运出?
 楼主| 发表于 2010-2-2 13:28:37 | 显示全部楼层
如何不按照先进先出的原则使Mu退出proc?
发表于 2010-2-4 00:26:41 | 显示全部楼层
自己编一个程序,该程序由Init调用。
$ l" z( P$ s6 H用一个tablefile,第一列为产生的时间,第二列为产生的个数。- G' a3 D4 K; s' x) X& w
5 y, C) q/ }4 n* a7 N& x
程序可以这么写
% D! F9 l( a% ]" W) B) z. o7 Pwhile i < table.yDim loop8 K! z2 D* a" m4 `
  wait table[1, i+1] - table[1, i];% \' y; p1 M) A7 L4 ~6 d
  for j := 1 to table[2, i] loop0 @1 }4 u  T/ z9 _' g
    myMU := ...create(Buffer);
6 I3 i5 O8 X. [  next;
4 p+ B6 X: T+ R  U! {8 J3 @  i := i+1;
2 f+ Q7 _4 r- c" E1 Cend;
1 X& U* B7 u* P6 w) s7 e3 B$ w4 G2 H6 N$ D1 {
注意,Buffer设置无穷大。
 楼主| 发表于 2010-2-7 10:39:28 | 显示全部楼层
感谢楼上的帮助。应该可行,我去试试。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-19 05:18 , Processed in 0.015306 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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