设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8158|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!
6 v3 x) `7 d: ~4 C5 W另外Control里有个Pull Control是怎么一回事啊?' I/ E) S( S8 B5 {; X; D+ ^; N/ 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比较好
; ?. l/ W/ b+ z1 ]& t4 t  u8 F在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
; Y2 N6 _5 y; Q$ pis
, c& D; K; l( c3 a. I$ p5 J) Di : integer;+ Z" A2 p9 T" H0 V( E& E
obj : object;. p3 e8 p- E& H) B( N1 O3 {6 t* M
ta : table[object,datetime];
7 ^* S# p8 r+ }$ s" ldo4 W5 \  {+ Q9 w$ a! |. M% N& l7 r4 ~: n$ \
ta.create;, {: R( ^$ y5 o+ ?. Y" C9 U
for i := 1 to buffer.nummu loop3 z! u  `/ v4 [, X6 h5 D
ta[1,i] := buffer.mu(i);1 u9 L# j5 I0 j, i; I  U
ta[2,i] := buffer.mu(i).time;7 a( P8 o  p+ L" ?
next;
! Z9 @8 u- o$ W* f* i' p/ }7 E1 H4 Qta.sort(2,up);
: A4 d' J% Z/ `! D  a: x3 w" ]obj := ta[1,1];5 ~6 e; i' a- M" z- U" d
obj.move(machine);8 |5 K. v$ B$ K2 c4 i9 e- ?: L( M$ e
end;
! Z' s, G/ I6 Q' |, |/ b上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 7 e( c3 d3 m4 n
嗯,可以不用placebuffer,用buffer比较好5 A$ z5 z: J$ {& B+ s
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
0 `1 m8 ?) T& D1 ^! zis
" ]# w6 D0 c. w% {( \" g0 r2 Li : integer;
; Q1 |2 C: d0 f/ ^. X+ Zobj : object;
1 U) W) W0 B; `4 X9 y. D, z: Pta : table[object,dateti ...

: r' u" T2 ?8 w* l非常感谢你的回答啊。
  f8 j) W/ [) x/ Y9 N) K这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
  F1 y7 U: `$ m2 I7 L; a嗯,可以不用placebuffer,用buffer比较好
' p8 l/ l0 r% z0 d1 n在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即" u1 C5 B1 d9 p# M0 ~4 ]% d
is
  A- [  s* G" B' k1 z! Li : integer;
9 b! m  B7 G% Wobj : object;
' |  t$ \# ^- H9 E' lta : table[object,dateti ...
! Y; D: }4 R7 w0 {7 l1 _8 r" X
liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。
! C: \1 f$ D  K/ A+ s0 h9 h请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表
2 Z: D$ z" ~) I  O6 [嗯,可以不用placebuffer,用buffer比较好. X7 o; t9 x7 S# _1 f* J6 o4 K, _
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
7 h: ?: d2 g2 a7 @+ u) O+ P$ _is
. D( z$ b: R% Z8 t) l0 D  ci : integer;
# \  k- Q$ X" a! }. \% n; ~3 W2 Dobj : object;; T4 w  j4 |- `8 b! H
ta : table[object,dateti ...

; i8 g& X" ]5 P
4 u# |' j0 k0 \4 s6 R1 E* ~我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。; M7 s, I- n" h7 e. E
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??$ g" ?( u; A; v$ ^+ W& M7 J0 d: i
2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。: J" }! P6 X+ R! R! R- V' R
个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表
5 L, d) v, E+ I* f! v1 o# h. F/ y) |0 e# ~+ ~7 [+ C1 {
# ?% i) b( h! z  J9 B. Q* ?9 M' A! F
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。) _9 ?4 a/ J3 d" ]7 @: R
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

2 U' q2 n* R" h. m& U  K是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?
2 [7 y& n! C' j/ D- c感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好* j( Q. p4 }& m( f# a+ \
: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即! g, B( e) I% V! Y, P; V
# 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
4 Z0 h) @( b1 B+ ai : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q
8 w& W& l! b: B* t. mobj : object;$ {# ~7 X6 z- K$ `
) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];3 w/ [( t" c: B! y! m6 ?
) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo( e) r$ h8 a7 n4 X7 A9 |# {! B6 M
. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m0 h$ _! g& y6 F3 W5 A: R
for i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T" O' a% G& _. h8 Q1 y2 u) O7 b
ta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F( W6 _3 P. n( S  S  D
ta[2,i] := buffer.mu(i).time;+ }! F( `0 A+ E$ p" a5 w
/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;
4 Q3 W/ G( _1 Y2 `" |! O  z8 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# o* f2 s3 H9 S  C
obj := ta[1,1];
3 O; C/ {6 l' H  D6 x6 S0 c% q: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);
3 I* W) f9 g5 H+ c2 }4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J+ K; T3 |6 h8 j* S- Y1 w$ D4 Y: A
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-1 21:06 , Processed in 0.025259 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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