全球FlexSim系统仿真中文论坛

搜索
查看: 3400|回复: 1
打印 上一主题 下一主题

FlexSim新技术主题4_任务序列概念说明3

[复制链接]
跳转到指定楼层
1#
Clay666 发表于 2019-7-8 10:25:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
备注说明:
此部分文档截止到此就全部翻译完成,主要是在概念上解释了任务序列的相关含义,自FlexSim2017版本开始,软件厂家更倾向于使用PF模块来实现任务序列,而不是代码。
相较于代码实现,PF模块实现更加简单直观。

: g2 P( Y4 V5 r5 [5 \, o+ K
* ^; }6 N% R1 U; v! x
1.    Coordinated Task Sequences
Coordinated task sequences are used for operations which requiresophisticated coordination between two or more task executers. These tasksequences implement concepts like allocation and de-allocation of taskexecuters, as well as synchronizing several operations being done in parallel.
协调任务序列用于需要两个或多个任务执行器之间的复杂协调的操作。 这些任务序列实现了诸如任务执行器的分配和解除分配之类的概念,以及同步并行完成的若干操作。
Commands
Coordinated task sequences are built anddispatched using a set of commands which are mutually exclusive from thedefault task sequence commands. The commands for coordinated task sequences areas follows.
使用一组与默认任务序列命令互斥的命令构建和分派协调任务序列。 协调任务序列的命令如下。
createcoordinatedtasksequence()
insertallocatetask()
insertdeallocatetask()
insertsynctask()
insertproxytask()
dispatchcoordinatedtasksequence()
createcoordinatedtasksequence
The createcoordinatedtasksequence commandtakes one parameter, namely a reference to an object. This object is designatedas the task coordinator who holds the task sequence, as well as coordinates thetasks. The task coordinator can also be one of the objects that is allocatedwithin the task sequence. It can be any dispatcher or task executer object.Note that selecting a task coordinator doesn't mean allocating that taskcoordinator. A task coordinator can be coordinating any number of coordinatedtask sequences at any one time. Also, unlike regular task sequences,coordinated task sequences are not queued up. The task coordinator will startexecuting the coordinated task sequence immediately when you dispatch it, nomatter how many other coordinated task sequences it is coordinating.
创建协同任务序列只包含一个参数,即对对象的引用。这个对象被指定为任务协调员来安排任务序列。它可以使任何一个任务分配器或者任务执行器对象。注意选择一个任务协调员并不一位置分配改任务协调员。一个任务协调员同时能协调任意数量的协同任务。同时,与常规的任务序列不同,协同任务不能进入任务池排队。无论协调多少其他协调任务序列,任务协调员在你分配给他任务时立即执行。
insertallocatetask
The insertallocatetask command takes fourparameters. The first is the task sequence. Second is the task executer ordispatcher to give an allocated task to. When the task coordinator gets to anallocate task, it will actually create a separate task sequence with anallocated task in it, and pass that task sequence to the specified taskexecuter or dispatcher. In the case that it is a dispatcher, meaning you wantto allocate any one of several task executers, then you can use the returnvalue of this command as a key to reference the specific one that getsallocated, since you don't know exactly which one it is at the time that youbuild the task sequence. The third and fourth parameters are the priority andpreempting values of the separate task sequence that will be created. The fifthparameter is optional, and specifies whether the task is blocking. By default(0), the task is blocking. If 1 is passed in, then the task will not beblocking.
insertallocatetask命令有四个参数。 第一个是任务序列。 其次是任务执行者或调度员给予分配的任务。 当任务协调器进入分配任务时,它实际上将创建一个单独的任务序列,其中包含已分配的任务,并将该任务序列传递给指定的任务执行者或任务分配器。如果它是一个调度程序,意味着您要分配多个任务执行程序中的任何一个,那么您可以使用此命令的返回值作为键来引用已分配的特定执行程序,因为您不完全确切知道在构建任务序列时它是哪一个。第三个和第四个参数是将要创建的单独任务序列的优先级和抢占值。第五个参数是可选的,指定任务是否阻塞。默认情况下(0),任务阻塞。如果传入1,则任务不会阻塞。
insertproxytask
The insertproxytask command is similar tothe inserttask command, with one parameter, the second, added. The secondparameter specifies which allocated object you want to do the task. As the taskcoordinator is the one actually executing the task sequence, once he gets to aproxy task, he will instruct the allocated object to do the task by proxy.Notice that for involved1 and involved2, you can either pass in a key or astraight reference to an object.
insertproxytask命令类似于inserttask命令,添加了一个参数,第二个参数。 第二个参数指定要执行任务的分配对象。 由于任务协调器是实际执行任务序列的任务协调器,一旦他到达代理任务,他将指示分配的对象通过代理执行任务。 请注意,对于involved1和involved2,您可以将键或直接引用传递给对象。
insertsynctask
The insertsync task halts execution of thetask sequence until a specified task, referenced by its key, is finished. Ittakes two parameters: the task sequence, and a key value of a given proxy task.It is important to note that proxy tasks which are specified for different taskexecuters, by default, will be done in parallel, unless a sync task is specified,whereas proxy tasks given to the same task executer will automatically be donein sequential order, without the need for a sync task.
insertsync任务停止执行任务序列,直到完成由其键引用的指定任务。 它需要两个参数:任务序列和给定代理任务的键值。 重要的是要注意,默认情况下,为不同的任务执行程序指定的代理任务将并行完成,除非指定了同步任务,而给予同一任务执行程序的代理任务将按顺序自动完成, 并不需要同步任务。
! t* b4 x# B9 C2 U. ]1 Z

5 G: w- a  y1 |  Q- d# @& M
1 o7 E4 K" u+ M/ q" P* ~
+ |: Y% I+ I. l" z+ i! _

# y& {. a& W  u: b! H3 B& u) j: X; b) F) `& l* p# l; W
2#
 楼主| Clay666 发表于 2019-7-8 10:25:20 | 只看该作者
insertdeallocatetask
) R$ Q. |- C4 m) v: F5 Q' X4 P2 u3 Q8 t/ q7 T
The insertdeallocatetask command de-allocates a specific task executer, referenced by its key. The first parameter references the coordinated task sequence. The second parameter is the allocation key for the resource you want to de-allocate. The third parameter is optional, and specifies whether the task is blocking. By default (0), the task is blocking. If 1 is passed in, then the task will not be blocking.: n$ U$ a& W( ?

* n4 f3 M6 [- t: s8 \The above code creates a coordinated task sequence that organizes the two task sequences, as shown in the diagram below.
/ J$ i, j. D3 S6 n$ p0 q
3 _" D9 ~8 e  G& i. J& linsertdeallocatetask命令取消分配由其键引用的特定任务执行器。 第一个参数引用协调的任务序列。 第二个参数是要取消分配的资源的分配键。 第三个参数是可选的,指定任务是否阻塞。 默认情况下(0),任务阻塞。 如果传入1,则任务不会阻塞。
2 S* D3 P8 Z; F- x% o: _- |. j9 D  I
# \) S' B8 Q  z
3 @  i6 ~* O. k- o
Coordinated Task Sequence实例6 \+ y3 y9 d1 G7 M
/ ~. O' O5 d1 ?8 B) M2 I, e
% `  b6 R8 }$ C& R1 q8 e; O3 I
/ p: _$ N& L6 I8 \) ~1 w

4 s7 h. \- v* J3 g& p* C/ {0 x. f) |4 k  @& k$ i# B
treenode ts = createcoordinatedtasksequence(operatorteam);
; f, G' `9 ^* K9 v! J" x5 d
+ n0 ]3 ^) H6 @; gint opkey = insertallocatetask(ts, operatorteam, 0, 0);
/ b! r0 Q6 t! j' n9 s
$ K3 o' {$ m- D. G/ s/ @int forkliftkey = insertallocatetask(ts, forkliftteam, 0,0);
3 j2 |3 N7 x- ~0 N9 l# Y" }0 I, t- S1 T, T/ A1 i, s  M* k
int traveltask = insertproxytask(ts, opkey, TASKTYPE_TRAVEL, forkliftkey, NULL);
% Z4 F9 d* D! N! A( R# @, J/ n$ \3 B  l; u( c
insertsynctask(ts, traveltask);
/ X0 t: p) ~) [6 u) E8 {. @8 l- |" q/ d* o
insertproxytask(ts, forkliftkey, TASKTYPE_MOVEOBJECT, opkey, forkliftkey);  t/ G  N3 n  ?# k1 ^3 H

2 d4 [+ p: R2 d# qinsertproxytask(ts, forkliftkey, TASKTYPE_TRAVEL, loadstation, NULL);8 @8 R/ p9 W1 p/ R8 `
3 G8 x* F1 k  D. c' B
insertproxytask(ts, forkliftkey, TASKTYPE_LOAD, item, loadstation);
# I' V6 O" x; V, o# V* k; B
0 q8 l% l- \) l/ m5 ]$ @/ J" |insertproxytask(ts, forkliftkey, TASKTYPE_TRAVEL, unloadstation, NULL);
$ T' V. z& [& n) S* ~" _  x$ o  k& x" U( \
insertproxytask(ts, forkliftkey, TASKTYPE_UNLOAD, item, unloadstation);
, R. x- V- m6 b( x
4 K5 Z  j, B3 B; Linsertproxytask(ts, forkliftkey, TASKTYPE_TRAVEL, forkliftteam, NULL);  V# f* l% L: u2 [2 C3 C: o& j
9 `) W3 \: Z4 u% d
insertproxytask(ts, forkliftkey, TASKTYPE_MOVEOBJECT, opkey, model());% ~$ z0 a! J" H8 B2 }+ K7 C
+ p8 R% l0 B; D4 N7 z' q; R: o
insertdeallocatetask(ts, forkliftkey);6 z9 s1 P1 `8 H% r6 R( Q. X( A' H
, W9 b. u' P: t) K5 E+ g& X
insertdeallocatetask(ts, opkey);
  g* n( z1 K& c$ Q0 g* K5 L  b; }; L/ U! f! ~0 i: N
dispatchcoordinatedtasksequence(ts);
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2025-10-26 04:22 , Processed in 0.073889 second(s), 13 queries .

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

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