|
|
发表于 2012-4-7 22:08:45
|
显示全部楼层
周老师您好,我在建模的时候遇到一个问题,有一个装配工位M1,工位前有一个暂存区,会有J1,J2,J3,J4四种工件到达暂存区,可能同时到达,也可能以任意顺序到达,其中J1与 J3,J2与J4装配,我的问题就是这种情况下如何判断J1和J3装配 。J2和J4装配。
G. @0 _2 a9 v我之前的思路是用2个buffer(B1,B2) 和一个singleproc(m0),method是:' O8 R# s( K/ u# e) Q
) Y* n8 g* h) E# a- ~1 y
waituntil m2.occupied " K; }+ g( `' x# K' i
and B1.OCCUPIED prio 1;
3 j: P. v% Y' Z9 |0 a* A- b4 A" `" T* `if B1.cont.name="j1" and m2.cont.name="j3" then1 k, h; N) J6 n1 S7 _
m2.cont.move(m1);
* K8 C# V" V: ~% Z B1.cont.move(m1.cont); ; i+ s* ], a$ E8 F! z* n7 ~
--@.move;
& v$ `( E3 e5 ` elseif B1.cont.name="j2" and m2.cont.name="j4" then
* T) p! ?2 _' z7 |, _6 j m2.cont.move(m1);
) ^# l" o* ~. R" k6 B1 @, ]! b) j B1.cont.move(m1.cont); 9 U0 |+ j3 J6 d( M8 j; s
end;& j$ H2 G/ R% [3 ^
但是出现两个问题1:两个buffer需要容量满才可以;: W) N! ]# f1 h" m; g) c
2 如果先到的是j1和j4就不会装配,停机了。 L' \, Y- a' W ? J* [* s/ F8 `
周老师,麻烦您指导下,谢谢了。8 v& N' U6 V9 S+ v8 z+ s/ u
|
|