设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 7813|回复: 12

[求助] placebuffer 和buffer的区别

  [复制链接]
发表于 2011-10-9 15:59:57 | 显示全部楼层 |阅读模式
placebuffer和buffer的区别是什么?分别在什么情况下可以用?新手一个,请大家赐教!
发表于 2011-11-9 09:06:52 | 显示全部楼层
同问
发表于 2011-11-9 10:36:39 | 显示全部楼层
PlaceBuffer对象中的单元可以通过method语句访问,即可以将零件放在其中的某个指定位置,也可以从某个指定位置提取零件。, k4 c" T( J: n/ E3 e" J
Buffer是PlaceBuffer对象的简化,它不能指定MU进入Buffer对象中的特定位置,即用户不可操控零件在Buffer中的位置。
发表于 2011-11-9 11:10:48 | 显示全部楼层
老马多拉 发表于 2011-11-9 10:36 0 c* H/ {$ S6 I4 Y$ p
PlaceBuffer对象中的单元可以通过method语句访问,即可以将零件放在其中的某个指定位置,也可以从某个指定 ...

% H" [6 S% T4 r/ ^如何设置placebuffer中的内部位置的数量
发表于 2011-11-9 12:28:34 | 显示全部楼层
把placebuffer看成一维数组,数组大小就是属性capacity容量大小,引用第i个位置就是placebuffer[i]
. i1 \( [6 r  R2 z) [8 J  R2 _
发表于 2011-11-9 12:30:57 | 显示全部楼层
如果要从placebuffer[i]取东西,先判断placebuffer[i].empty是否为False
 楼主| 发表于 2011-11-9 14:51:51 | 显示全部楼层
太感谢啦!
发表于 2011-12-4 12:13:58 | 显示全部楼层
同问,谢谢啦
发表于 2012-3-24 11:35:30 | 显示全部楼层
楼上正解。。
发表于 2012-4-7 22:08:45 | 显示全部楼层
周老师您好,我在建模的时候遇到一个问题,有一个装配工位M1,工位前有一个暂存区,会有J1,J2,J3,J4四种工件到达暂存区,可能同时到达,也可能以任意顺序到达,其中J1与 J3,J2与J4装配,我的问题就是这种情况下如何判断J1和J3装配 。J2和J4装配。
2 g% l4 d/ U0 [/ P* K我之前的思路是用2个buffer(B1,B2) 和一个singleproc(m0),method是:
/ ]6 E# b( G8 ^
: Q1 o! v7 ^) Zwaituntil  m2.occupied 1 L7 d+ c0 f' \, m6 ]/ y
         and B1.OCCUPIED prio 1;5 }& T2 C9 s4 u: z
if B1.cont.name="j1" and m2.cont.name="j3" then
9 F* ~4 E9 O( _& p; s# ~+ P                m2.cont.move(m1);
) }7 O* h* w5 {                B1.cont.move(m1.cont);        
+ ~1 g0 u3 J  ]9 C* Q                --@.move;
- @' y5 g! r# P                elseif         B1.cont.name="j2" and m2.cont.name="j4" then
8 W* W! a7 f2 s2 j9 @0 _% E4 d                m2.cont.move(m1);* ]' f7 e7 A7 ^7 X" L
                B1.cont.move(m1.cont);
9 s. D9 W9 ~+ n; p9 w2 A) s/ bend;3 j6 N- Q- z7 s  R8 B% E( }7 u
但是出现两个问题1:两个buffer需要容量满才可以;9 |. P6 o! N( Y9 K, c# V* o5 K* X
2 如果先到的是j1和j4就不会装配,停机了。
' P" A" ]" U* v8 v) `周老师,麻烦您指导下,谢谢了。3 T  M0 H+ y8 m% G3 j! p! i
发表于 2012-4-8 19:59:17 | 显示全部楼层
基本思路大致这样:! ]2 m1 Q3 D0 t7 X: |4 C
1、缓冲区采用PlaceBuffer,缓冲区的加工时为0,容量大小自己定义;(注意AM和M1之间不直接连线)6 z' m1 x3 D: f5 Y" a6 E7 Y# k
2、在M1之前可以建立两个虚拟工站(不一定这样做):M101和M102,M101先和M1连接,M102再和M1连接;6 f/ Y5 d7 s$ B: n+ m
3、撰写一个Method,假设命名为AM,则只要有工件进入PlaceBuffer就触发AM;或者装配站M1有工件离开就触发AM;5 O/ |* v6 @9 @" g3 ?4 y  P# a8 l
4、AM的写法:遍历AM,以i为循环参数,当AM[i]/=void时,表示AM的第i个位置有一个工件,如果AM[i].cont为J1/J3,然后遍历AM[i]以后的其他单元,如果该单元的cont为J3/J1,就将两个单元的内容J1(J3)送去M101,再将J3(J1)送去M102;
7 _2 x2 a# l" K( _9 c6 @, C* v5、对于单元内的cont为J2/J4的一样处理。
发表于 2012-4-8 20:03:39 | 显示全部楼层
1、缓冲区采用PlaceBuffer,缓冲区的加工时为0,容量大小自己定义;(注意PlacBuffer和M1之间不直接连线)
$ u0 y7 g3 O, E1 A) V) ]
发表于 2012-10-28 18:36:43 | 显示全部楼层
我这愁呢,谢谢诸位了,哈哈
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-7-3 04:54 , Processed in 0.016767 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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