全球FlexSim系统仿真中文论坛

搜索
查看: 36|回复: 0
打印 上一主题 下一主题

更改Task Executer堆叠规则

[复制链接]
跳转到指定楼层
1#
更改任务执行程序的打包方法可能很棘手,并且类型之间也可能有很大差异。在本文中,我们将探讨每个 TE 的默认打包方法,以及如何更改它以适应模型的需求。Attached 是一个模型,它演示了默认的打包方法和比较。该模型也是获取 ASRS、起重机和 Robot 的预制代码的最佳位置:
, U9 X1 ]: z# d# Y! I2 g! nTask Executers上的默认堆叠
TE 上有两种类型的默认堆叠方法
AGV、作员、叉车、ASRS 和 basicTE 都使用简单的上下堆垛方法:

& T2 s- a  S+ E( c) U. I
其他 TE(电梯、机器人和起重机)根本不将箱子分开,因此它们看起来都像是彼此重叠的(这是因为它们一次只能携带一件物品):
" u: `# u2 e) r
更改堆叠模式:AGV、作员和BasicTE:
对于这些对象,更改堆叠方法相对简单。
1.向对象添加 5 个标签:numx、numy、xshift、yshift 和 zshift
2.在属性面板中添加 OnLoad 触发器
3.通过转到 Visual-Set Location 设置触发器>Set Location
4.输入此代码
current.xshift+item.size.x*((item.rank-1)%current.numx)-current.yshift+item.size.y*(Math.floor(((item.rank-1)/current.numx)%current.numy) - (current.numy-1)/2)current.zshift+item.size.z*Math.floor((item.rank-1)/current.numx/current.numy)0 H: l+ M# [# L% X' Z3 G7 a
这3个对象之间唯一不同的是标签值。标签“numx”和“numy”设置 x 方向上的对象数量和 y 方向上的对象数量。例如,AGV上的3x3网格会将“numx”设置为 3,将“numy”设置为 3
3 u; v2 r. N1 o9 d6 a9 M# Z
  
" w* b9 B) W2 ?$ S  
x轴
Y轴
z轴
  
AGV自动导引车
  
1
.5
.5
  
算子
  
.75
.29
1.10
  
基础 TE
  
0
0
.85
电梯、机器人和起重机:
这些对象与上述 TE 的对象非常相似。您将按照上述相同的步骤作,但在On Load(加载时)触发器上,选择仅在框中粘贴自定义代码。它们的代码略有不同(由于堆叠的方向/方式不同),您可以从上面的模型中复制。但是,您仍将向 TE 添加标签。您可以使用如下标签进行设置:
  , q+ t' \! V& D3 i
  
X轴
Y轴
Z轴
电梯
.7
1
.095
机器人
.34
.35
.2
起重机
.2
.5
-.25
叉车:
这是最容易更改的对象,因为它已经内置到TE中。
要更改堆叠模式,只需添加一个OnEntry触发器并选择Transporter Stacking Method,然后将值更改为您想要的值。

  X0 g9 [7 m! \: Z/ n- d* a8 w2 h) X2 R5 ]
ASRS
对于这个,您可以通过编辑模型树来更改堆叠方法。
更改它的步骤简单但具体:
1通过右键单击并选择Explore Tree来打开对象的模型树
2.在 ASRS 节点下找到行为节点
3.在下面添加一个名为“eventfunctions”的节点
4.在您刚刚创建的节点下,添加一个名为“OnPreDraw”的节点
5.将下面的代码粘贴到该节点中(您可以编辑此代码以根据需要更改堆叠方法):
inheritcode();TaskExecuter current = c;Object followingObj = first(current);double numx = 1;double numy = 4;double xshift = .95;double yshift = 1.45;double zshift = .1;while(objectexists(followingObj)){double x = xshift+followingObj.size.x*((followingObj.rank-1)%numx);double y = -yshift+yloc(node(">visual/drawsurrogate/Lift/Slide", current))+followingObj.size.y*(Math.floor(((followingObj.rank-1)/numx)%numy) - (numy-1)/2);double z = zshift+followingObj.size.z*Math.floor((followingObj.rank-1)/numx/numy);double xFactor = 0.5;double yFactor = 0.5;double zFactor = 0; setloc(followingObj, x, y, z, xFactor, yFactor, zFactor);followingObj = next(followingObj);}
; C8 c( x5 C2 q
需要记住的一些事项:
每个 TE 都可以由用户完全自定义,因此我认为看起来正确的偏移量对您来说可能看起来不正确,好消息是它非常可变!

. m2 U: H  O% I

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|全球FlexSim系统仿真中文论坛 ( 京ICP备14043114号-2 )

GMT+8, 2025-6-28 03:47 , Processed in 0.079778 second(s), 14 queries .

Powered by Discuz! X3.3© 2001-2013 Comsenz Inc.

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