设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4836|回复: 3

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

[复制链接]
发表于 2010-2-2 12:03:24 | 显示全部楼层 |阅读模式
初学em-plant,要求做一个模型。现在遇到了问题,求高手不吝赐教。8 J; F4 N$ Q& A- g

% s2 b; x# G" G某生产车间根据订单生产。订单到达的日期可从table中读取。每笔订单会要求多件产品,各订单可能要求在不同的流水线上生产不同的产品。
7 j$ g. Y1 e6 `: d* Y# _" P- Z6 |/ y0 I0 ^$ R- l$ V0 n$ o
我现在考虑在source里产生大量的MU,同时每个MU读取table中的订单到达日期。MU从source出来后移至一buffer,在buffer中判断该MU下步该去哪个机器。同时,首先需要判断目前的模拟时间是否已经超过了订单抵达的时间。这是最重要的,这样才能与实际情况相符,即先订单后生产。' ]; S# c1 A* ]' {/ s

* V7 Q" l8 E% D& I如果我使用如下method与buffer的exit
  X' }- y4 ^) v. C* M9 e" X! ~
+ r' R3 H+ L4 n) h2 J* @if @.arrival_time < EventController.simtime , R5 m( m' W& `2 n* r4 S1 L
    then 。。。。。。。。
! Q1 u* }8 l# s) W' i6 }) M- v
5 S8 R9 u+ N" @/ V0 b" W@.arrival_time为MU的属性,在source中已从table读取,每个MU有各自的订单抵达时间(可能相同,即属同一订单)。此语句仅在buffer中判断一次,其后任凭新的MU进入,也不再判断。
* H* X: P+ d- B5 x- M2 G  f8 s
! x  o( I7 G! ?. U7 _3 D如何使得buffer可以不停判断其中包含的所有MU,并且选择符合条件的运出?
 楼主| 发表于 2010-2-2 13:28:37 | 显示全部楼层
如何不按照先进先出的原则使Mu退出proc?
发表于 2010-2-4 00:26:41 | 显示全部楼层
自己编一个程序,该程序由Init调用。1 I  i/ I% v- U) u( @! R
用一个tablefile,第一列为产生的时间,第二列为产生的个数。
" Q1 N- s$ w4 N
7 n6 X1 f3 x6 }2 ?程序可以这么写% a, P2 x+ {' D+ K- Y
while i < table.yDim loop" s3 g5 z  j# r! @7 Q
  wait table[1, i+1] - table[1, i];
. A" S+ s" O+ b  for j := 1 to table[2, i] loop7 p# c* R/ V$ N9 k4 X/ j- t
    myMU := ...create(Buffer);
" ?/ d' X( Q! D/ g  next;
. U/ I8 \: l7 `! [  i := i+1;
: s) y& X8 S- U9 `end;- w/ ^$ S, U9 F0 `) Y9 b8 {
3 Y# u7 q+ b" s4 Q8 u$ M  q9 H6 a
注意,Buffer设置无穷大。
 楼主| 发表于 2010-2-7 10:39:28 | 显示全部楼层
感谢楼上的帮助。应该可行,我去试试。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-5-19 08:42 , Processed in 0.017085 second(s), 16 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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