设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8097|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!
- z. a  H8 N  v; w% [! p另外Control里有个Pull Control是怎么一回事啊?
0 w5 v9 _: d  z还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用placebuffer,用buffer比较好 在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即 is i : integer; obj : object; ta : table[object,datetime]; do ta.create; for i := 1 to buffer.nummu loop ta[1,i] := buffer.mu(i); ta[2,i] := buffer.mu(i).time; next; ta.sort(2,up); obj := ta[1,1]; obj.move(machine); end; 上面所提及的buffer.mu ...
发表于 2009-5-25 15:05:19 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好/ v8 C/ c2 B7 X' N- R; c2 c
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
3 b6 V. c+ p7 q1 i8 qis * \$ V2 Z+ _. ]
i : integer;
1 r4 A7 H' s- z7 K# r  n6 Iobj : object;6 q( e, W! v, ~9 [5 F! l
ta : table[object,datetime];+ x; r: R; A; B2 Y0 l0 q" C5 ^
do
0 m% U1 J: D0 Z0 i6 ]4 Tta.create;
. J7 s' E( h3 h6 F6 Mfor i := 1 to buffer.nummu loop
. |7 c% O9 |, h9 u% q3 l; Z% ~ta[1,i] := buffer.mu(i);+ G+ }( ^- s: P8 n2 ?/ z
ta[2,i] := buffer.mu(i).time;
+ ?" J) w1 U, h; ]! j: ~$ m2 Dnext;
2 a+ K& q1 o/ p* i1 `" kta.sort(2,up);( Y( K% j, S, ~! a+ }
obj := ta[1,1];# b, ^+ e5 E7 |( B5 P/ @/ ~
obj.move(machine);
" @6 [# B0 x8 {6 N  o5 p/ {, lend;8 q6 R7 p* k: Z
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 - f- x: L# W0 D1 v  T! c! S! B8 x
嗯,可以不用placebuffer,用buffer比较好
  T3 a; O$ M( v9 M' |3 S. q- h0 a在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
& N( e5 C, z% y2 w( U0 f% Zis , d1 f) r; V! x. c: k7 @' w
i : integer;* V9 ^2 Y' `7 j$ P# ~
obj : object;
2 L9 ~2 K6 u% B/ f$ N8 P! V- j0 Mta : table[object,dateti ...
$ S9 C. u+ y5 |/ F$ k/ Z, ]
非常感谢你的回答啊。
0 P8 \+ V9 X, T: Q* j/ A3 G. ]这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
, Y' U) }8 `% I0 t. ?: D/ c& Y嗯,可以不用placebuffer,用buffer比较好, z" v: `& x8 D) b
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即# E/ K  j) c2 N2 c6 o8 G% ?
is * Q9 y. v; p: t& `: j$ l& @  S
i : integer;
% w2 G  K( r2 X9 G5 \1 x- dobj : object;
- y2 B; j5 J$ c  tta : table[object,dateti ...

6 r) C  x1 B# U1 ?; Vliysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。
1 g9 ?! v; W# {' h$ I请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表 7 ?8 r6 c/ A7 l, ]7 U% l
嗯,可以不用placebuffer,用buffer比较好
4 a+ y5 M! h1 y% J; h" ^在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
5 g5 U4 K/ R7 C7 s4 P9 f6 Ais
+ }, g  O: q7 c2 g* P( ]% qi : integer;
/ L" |' S% z7 S$ wobj : object;( D$ M* s) Y3 @$ b& F, T
ta : table[object,dateti ...
1 O$ ]8 B9 h' o% F3 V1 `7 r: X, `

# w/ X1 a1 e8 H  {- c我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。! R" X4 Z5 V  O. V
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??
* b6 e+ m/ B7 K  `9 s& t1 w2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。) b4 V: K* S  [3 `: g% _. H6 a
个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表
4 L7 O. k0 j5 E' ^5 \* |4 G- F  ^5 ]
, t9 K# G- o9 y8 C3 s2 w$ _( F$ L- a
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
8 l% J3 `2 O3 l8 l/ b; R1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

  D/ _, i, ]; j- @, q7 k是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?
' `7 y% w. R; b, t+ ~) g感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好
5 ?. R6 n- {' H$ s& b7 O* w  L: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
4 ~1 k+ |- R: I! ^  h# u: S6 {' U6 S" T3 s) Twww.simulway.comis 仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast- _  S8 P! A6 X  Z; `2 R  c
# m. X' Z8 B# ?# ~1 i* l$ o# bi : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q% p( `+ e! A! j1 u- u2 ~" c% F
obj : object;; U8 e% g% l. ^, \2 X
) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];/ s4 }' Q$ F, ?' K1 A) v/ K+ b
) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo
2 d" \) u3 E: `" |. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m5 D2 V. m" d! _6 J1 B$ ]' f+ o) N
for i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T
: u" O) q; M- n8 Y5 N: Kta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F% ?6 C; p# t# k
ta[2,i] := buffer.mu(i).time;
* M& G) ^% ?! V7 L4 `; b/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;6 E! S9 l8 q- y, Q% a9 V! ^
8 n* ~4 i) V, P, P/ H仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastta.sort(2,up);/ j* v5 ^! h2 _. q3 K/ p, X# v- K  r/ y8 {1 ?8 W
obj := ta[1,1];
: E1 l6 m" J! @1 S4 \" ]: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);, h5 d4 s; r0 y1 X; G
4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J
9 C! w& Y& b6 \! K( `/ r" ~上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-21 22:21 , Processed in 0.019382 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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