全球FlexSim系统仿真中文论坛

搜索
查看: 20250|回复: 16
打印 上一主题 下一主题

根据全局表更新合成器的合成清单

[复制链接]
跳转到指定楼层
1#
zorsite 发表于 2015-11-25 11:27:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
随手翻译了一下,不成体系。搞清楚合成器的第一个输入端口和其他输入端口的区别可能更容易看懂。. E7 O( g$ F5 X  d7 h7 r
  1. /**根据全局表更新合成清单*/3 j; m$ Z7 `4 g6 q
  2. string tablename ="订单表";
    $ l; `' d* i0 X- E; z
  3. /*
    ; g1 i" U! j( n" P6 _% ?9 b# N  O
  4. This option should only be used on Combiners.
    ; m$ }# u2 m% `; A
  5. 这段代码只能用于合成器。
    2 r4 u8 B, T- R: ~
  6. Each column in the GlobalTable is the component list for a single itemtype.- w: ?% f% e& u3 j9 ]
  7. 全局表中的每一列是被合成临时实体的清单。
    " {0 b8 R, U* ?6 l* ^
  8. The itemtype of the first flowitem to enter is used to find the correct column.( y9 X9 e3 X3 D! c1 q8 F  P
  9. 从第一个输入端口进入的临时实体的类型决定了在全局表中的哪一列去查询合成清单。
    1 c$ u4 ~9 w; y% p
  10. It is assumed that the global table has a row for each input port number 2 and higher.
    ! j* a2 z2 I  E" k( @
  11. 全局表的每一行都代表着一个编号大于等于2的输入端口。; e# W" k4 l; ?, H# ]
  12. */
    - g& d: g: l. P9 r% z

  13. 9 W' e, {! o) g& f
  14. if(port == 1)
    & J# i- \: Y+ e2 _/ X
  15. {  //The trigger on entry code fires each time a flow item enters the combiner.; P- _* [1 [' p7 k' J$ @" t
  16.    //For this reason we check to make sure that the port entered is equal to 1: }) d% g5 ?. x- G: O, s% K6 n7 A4 n
  17.    //because only the container will enter through port 1." z5 m1 ~0 |9 m  G6 k: E! N
  18.         //每个临时实体进入合成器都会激活进入触发,所以必须要检查临时实体是否是从第一个端口进入的。: z) E' ^2 s- Y" Q
  19.         //只有从第一个端口进入的临时实体才是托盘等容器类临时实体。1 d% g+ }/ O4 U' n: o. u
  20.         //在上文已经解释过,第一个端口进入的临时实体的类型决定了采用全局表中的哪一列来设置合成清单。
    ' t" L7 }% o1 }0 l  e9 R( V5 V
  21.   //The component list in a combiner is set up as a table.  This allows us to use the cell commands to obtain the node that contains3 B! z& @  B- @
  22.   //合成清单以表格的形式存在。我们可以使用cell命令来获取数据节点。7 L3 k5 u6 [2 H
  23.   //the number of items to retrieve from each port.  Once you know what node contains the information you can use the setnodenum
    ! b4 _/ }7 {1 J" j1 L. J: X$ i# F
  24.   //command to set the component list number based on the global table.
    - E* U: Q( n. R' ~& e$ p# o6 l, C
  25.   //当你知道数据存储于哪个节点之后,你就可以读取全局表中的数据,然后使用setnodenum命令在合成器中设置合成清单。
    " n: P& ]4 ^! x. m: E
  26. & }  f4 N  E5 z3 j
  27.   treenode thelist = getvarnode(current,"componentlist");
    , n* h! C/ E# L' R# `
  28.   treenode thesum = getvarnode(current,"targetcomponentsum");
    5 J  @5 }' ~0 ~( v
  29. //更改合成清单需要对两个数据节点进行设置。一个是componentlist,这个节点有一列数据,记录了从每个端口输入多少个临时实体。
    ) t8 T) }- e$ I+ Y( Q4 q, @
  30. //另一个是targetcomponentsum,记录本次打包的临时实体的总数。
    & b/ L5 V+ S, S, r/ L# g
  31.   setnodenum(thesum,0);6 }$ {% c/ ~% I2 w0 v- m! i
  32. * n/ C7 t. a) @' A9 u' ]0 G
  33.   for(int index=1; index<=nrows(thelist); index++)
    / }/ G  n: ^9 l7 Y' M
  34.   //componentlist以表格的形式存在,只有一列。如果合成器有n个输入端口,那么就有n-1行。(第一个输入端口输入的是容器)
    ! J- z# b* e( r* S" G+ Z
  35.   {* a. ?3 x0 _3 k$ `1 s
  36.     setnodenum(cellrowcolumn(thelist,index,1),gettablenum(tablename,index,getitemtype(item)));
    & ^8 E+ w) o2 z( b0 h4 Y/ `3 J5 J
  37.     //第一输入端口进入的临时实体的类型,决定了使用全局表中的哪一列数据。
    " b( ]! Z; `) e$ X! _4 I
  38.     //把该列数据全部读取出来,依次写入componentlist。
    ' M7 C, g3 L9 m
  39.     inc(thesum,gettablenum(tablename,index,getitemtype(item)));- R4 Z6 t& V, ?* O
  40.     //同时更新targetcomponentsum的值。
    4 l! W9 H9 A3 m) [5 K" @
  41.   }
    5 e* F" C2 X# u
  42. }
复制代码
推荐
 楼主| zorsite 发表于 2020-4-1 20:39:49 | 只看该作者
河上羊 发表于 2020-1-30 16:20
0 q8 e* m# ], x) F* |) J/ n您全局表中临时实体类型1,怎么跟发生器生成的临时实体1绑定的呢?我运行的时候好像是混乱的。
% @5 ?( Q. _0 C: ~6 L3 z1 @3 o5 a
这里涉及到几个知识点:
" m' _1 g* l! w+ N发生器产生不同类型的临时实体(box)2 s' w* m3 G) A  W( J4 q  b' K
托盘发生器产生不同类型的容器(pallet); L/ [- e! }, t! I7 U
2 \4 X! f) g/ J$ ~% B2 ~
暂存区的send to port选项设置为“根据类型发送”,以此让不同的box从不同的端口进入合成器。
4 c# X9 y+ z2 @) E5 u0 x3 d0 i% ^( z3 @
合成器根据进入托盘的类型在全局表中查找相应的合成清单。" f( P; K4 ]; l  C! \, I

9 p! v: z) O6 X不要着急,多看多思考,再看再思考,又看又思考,慢慢就知道是怎么回事了。
2#
大摸鱼 发表于 2015-11-26 22:31:57 | 只看该作者
感谢加老师分享,这么详细的解释对初学者来说是巨大的福音啊
3#
草色青青 发表于 2017-3-29 14:40:12 | 只看该作者
1# zorsite 0 [! h+ @+ ~1 m/ H. z, u
" }+ s- o& L1 G7 p2 I1 F9 A, a
老师,仔细阅读了一下你的解释,我有一个疑问,那如果我是有几个合成器,每个合成器只加工一种零件,也就是每个合成器只有两个输入端,一个是临时实体类型(托盘)输入端1,一个是零件i的输入端2,那这样设置m*n的全局表(m是处理器个数,n是托盘的类型数)还能正确更新合成清单吗?还是谁需要对每一个合成器都重新设置一个全局表?请老师讲解一下
4#
liuzhifan 发表于 2017-3-30 09:39:17 | 只看该作者
3# 草色青青 ( F4 }# h- a/ v" J
你的问题可以解决呀,所有合成器可以读取同一份全局表,但是读取不同的列就行了
5#
 楼主| zorsite 发表于 2017-4-18 07:24:37 | 只看该作者
本帖最后由 zorsite 于 2017-4-18 07:40 编辑 ) o3 O9 Y' f# d, J& f4 |4 ?/ Z" V( Q

7 f* I0 g- d* t) w9 k 3# 草色青青
$ A$ q4 e: z. U/ k. f假设你有3个合成器,分别只接受类型为1、2、3的临时实体进行合成。
6 h7 k( O6 k, A! ~3 i  g
托盘类型1托盘类型2托盘类型3
合成器1321
合成器2123
合成器3251
( a/ x7 C' P! |% k

! w- L' j$ r* n: @5 p2 a$ b2 R. F以第3行,第2列为例解释一下这个表格的含义:
( @+ W% z8 {8 N+ ?, `2 d当第3个合成器(第三行)接收到类型为2(第二列)的托盘时,从上游拉取5个(第三行第二列的值为5)类型为3(合成器3只合成类型为3的临时实体)的临时实体进行加工。
% Q- A5 O3 i% y  V  D& I. ~# V/ i1 s) A# g" q8 V
仍然是根据全局表更新组件列表,代码如下:
  1. string tablename = "GlobalTable1";
    ' U" G% i0 v6 d5 U0 K
  2. if(port == 1)8 ~* b8 c/ u9 N8 T; B
  3. {/ y3 M8 d' Q7 ?4 L+ G
  4. int row=ipopno(current,2);
    # P( o8 f7 c7 j9 p) E
  5. int col=getitemtype(item);: _/ m- k+ t1 K3 ~; o
  6. double num=gettablenum(tablename,row,col);) z1 R, F- }3 c) l
  7. treenode thelist = getvarnode(current,"componentlist");
    7 E, `" `4 v& y8 m( U
  8. treenode thesum = getvarnode(current,"targetcomponentsum");$ _& W' ^1 R% C! L: V& [
  9. setnodenum(cellrowcolumn(thelist,1,1),num);( K/ s# }9 ^, ^) q! a5 L& Y- T# x( B; r
  10. setnodenum(thesum,num);3 A5 }% n/ [) F/ [0 v, J
  11. }
复制代码

本帖子中包含更多资源

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

x
6#
 楼主| zorsite 发表于 2017-4-18 07:35:09 | 只看该作者
本帖最后由 zorsite 于 2017-4-18 07:39 编辑
( i0 f3 Q- \+ ?# t0 E' Q9 ?2 E4 k# D) H
' Q% t4 t0 @$ L# U- @7 w( g2 a7 Z更多的时候,我们使用的是这样的表格:
托盘类型1托盘类型2托盘类型3
临时实体类型1123
临时实体类型2121
临时实体类型3121
: }/ h1 v, r- L9 H& y0 b; R: L
2 x8 Y# C6 @6 @: K
只有一个合成器,进入不同类型的托盘时,拉取不同数量的各种类型的临时实体来进行打包。

本帖子中包含更多资源

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

x
7#
lulu-luka 发表于 2017-4-18 11:23:57 | 只看该作者
Mark~
8#
lulu-luka 发表于 2017-4-21 06:10:24 | 只看该作者
6# zorsite , t* }2 g1 n( E8 V7 r: X

( B, ~1 F( J- h5 n: x! k& ]4 b* z+ J8 O6 F1 @& T; p5 Z
刚刚学习了这个例子,第一次发现合成器的上游可以不需要与输入端口个数相同的实体,只需要一个实体多次A连接就形成多个端口。所以在使用合成器的时候有n个输入端口,但很有可能只有有小于n的上游固定实体。感觉很有趣啊。
9#
eb_sun 发表于 2017-4-23 14:04:13 | 只看该作者
谢谢分享,激发了大家的学习兴趣
10#
eb_sun 发表于 2017-5-7 22:58:21 | 只看该作者
再次温习合成器代码,谢谢楼主大神的模型及其详细解释!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2025-6-29 16:21 , Processed in 0.110353 second(s), 16 queries .

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

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