设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8056|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!5 S6 z. Y' |2 L, Y
另外Control里有个Pull Control是怎么一回事啊?
$ V: x4 x% u! M) R- m还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好
& x' ~- x4 ]) d' B* s: l在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
! n$ Q& Y1 P8 _: Nis
/ M% m# r( p: H% F3 D/ ~# ti : integer;* M# v' |% v. f3 I- h
obj : object;5 J3 O9 q: T3 @% v5 Z" H
ta : table[object,datetime];! w8 J" ^$ p9 X3 }1 |
do3 z9 x% h; m  J% d/ s. n; {
ta.create;7 [9 i9 Q% v/ F9 c) I/ ?
for i := 1 to buffer.nummu loop, f$ X: V7 g* D1 O9 w; R
ta[1,i] := buffer.mu(i);
# g, q6 U) z9 v! @* V+ X+ ]2 Fta[2,i] := buffer.mu(i).time;
1 p- n) p& @; }next;2 N& y% M( l& c
ta.sort(2,up);
1 {. i- v7 i+ iobj := ta[1,1];
/ r' W+ N  m5 _; S$ Uobj.move(machine);! R) @  \) H4 L. n
end;8 K2 V% l" |7 |2 K0 U  w
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 4 k* m5 E$ j3 Y1 p
嗯,可以不用placebuffer,用buffer比较好
; o7 Q) k# G2 g$ y" \在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即5 u! c! b; i$ S/ j7 B5 Z, E
is
" p; s1 V2 g- l. t& O$ ci : integer;4 j. h0 k9 o: _8 A/ G* B# O# w
obj : object;
, y  u2 r; {1 ?2 Y+ Eta : table[object,dateti ...
+ ~- Y9 @" r# p8 r5 b
非常感谢你的回答啊。8 V  Z# A( k; \7 M  M' R" {
这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 3 R0 X; t# |" T; w8 B( }& _# i
嗯,可以不用placebuffer,用buffer比较好
, g$ U' l! j& {5 z+ H# I, H在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即  c, Y$ E. n5 }. z3 g) ^3 m! P
is
7 b/ O2 \& m6 |5 N! }7 q+ b' di : integer;6 h6 a0 O. z! S* A, t
obj : object;
+ q* N8 U- c/ ota : table[object,dateti ...

) ^% j6 x/ j5 [* m6 Mliysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。: T, D, Q( y0 g9 Z# a. z) M- f3 Y
请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表 ! Y7 G1 n) j) r+ x0 V' j
嗯,可以不用placebuffer,用buffer比较好
; s# q6 Z1 }! T/ c在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
+ f9 Z0 A# q" m0 Z" N( ~$ Cis 0 R; w% A3 @! \3 p
i : integer;: Z( W- m) A, c  y: y
obj : object;
( U) f, P5 F, rta : table[object,dateti ...

; J  X1 D7 `( M5 [9 |3 F
3 }9 u7 O6 t. C3 J% k7 n我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。9 e, j+ X9 v! N8 b$ h) t; T
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??' u1 e% T4 m0 ?( Z2 o
2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
8 I: k- d. Y; i& F: x1 |7 x个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表 4 `" u9 k" N2 I; N4 Y- W

/ L$ \8 ^+ X$ q& b1 [! N+ y' S6 G
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
1 O- |3 E. p7 m0 w1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...
! V" e5 g' Q' I9 F- @& C% `, v
是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?: ^9 ?' k- F3 x8 Q* I* |
感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好# R' U) D0 O% w  B' [0 S) n& E
: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即- p& i8 }+ a! U1 ?! S: o4 ^: e
# 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
$ \  n$ d: C; s- B! Hi : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q' ^: b  y. [2 G9 E9 j6 W
obj : object;- K) A) k' i  }' Q6 ?
) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];
2 z5 I. \/ d& c/ Q% G) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo* W" u. \3 `5 q. O1 l
. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m# v# i' b8 ]6 ^& v; K! T
for i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T4 Z8 _" K; [; w0 E
ta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F
0 [+ _1 }, w* _, R' ?  s( Eta[2,i] := buffer.mu(i).time;0 Y# P  |7 s0 p6 R( W5 l4 J
/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;
/ x0 P' Y1 p' b0 K- }5 V) n5 L( }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
6 M6 G2 t- x# A( H7 aobj := ta[1,1];0 J2 j; c. j. v, k. `
: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);
" e$ r0 l. `9 m' [, h# R6 I/ D; V6 f4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J8 ^% k- L# _3 q2 T' z
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-12 12:29 , Processed in 0.015124 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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