设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 7959|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!
, P9 ?) G0 J2 a- U6 T$ w另外Control里有个Pull Control是怎么一回事啊?
/ c- a+ b4 P" {6 r% L0 l! B还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好
; }/ a* e. [2 j, n在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
: m3 l6 q$ i* t; x$ {: |is
( x' Z6 _7 o+ A* _i : integer;
& S( x7 R- V, O9 t3 d  mobj : object;
! r! h% Z3 R) I4 k" a! p: e2 E) Cta : table[object,datetime];8 X7 N1 D: E( }2 M7 c
do7 a4 Y' {- G8 P2 F9 N9 \! D
ta.create;
4 D) P) G# Q* S2 B% _/ W" afor i := 1 to buffer.nummu loop
; F+ x6 u, y) e7 k  O9 q0 _8 pta[1,i] := buffer.mu(i);
2 C" R# U' H) ?- I& G6 ita[2,i] := buffer.mu(i).time;
8 P( T8 e0 h% I7 ?% Anext;
5 g  u& {& ?# X0 }, R4 t+ i" u3 ?ta.sort(2,up);
' `& ]* W# B1 \- p0 S# N! ~* x: O1 Wobj := ta[1,1];  c3 j" Q) K: B. I- {' N2 B
obj.move(machine);( G# Q/ h$ K$ `& V6 f* }
end;
* J& B8 G2 g: ?* q+ J上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
- E1 W1 L# \& \4 [# G4 h' V嗯,可以不用placebuffer,用buffer比较好
5 ~6 ^2 u0 s3 s, L4 f在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即5 B, R0 U: w2 Z7 G3 E
is $ u  @2 k4 ^2 |7 W1 h5 y5 g& m& D/ r) H
i : integer;
4 l4 G+ v* u8 J6 ?4 r5 o2 S7 fobj : object;- s, ?' s& W, `( i( Z3 L
ta : table[object,dateti ...

0 I, y4 @0 R# F8 z! Y/ y非常感谢你的回答啊。9 r: H; c% ?" E+ [0 r7 _
这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
/ W1 |" p/ ^8 z1 |* M嗯,可以不用placebuffer,用buffer比较好- Y0 V: z# R  y4 R! k
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即4 J' _/ A% \# z7 T
is 5 \$ X3 [. B, _( _5 |+ K$ Q
i : integer;% {: ~) a7 U4 D/ q0 G
obj : object;
% }- x& J+ B3 v% t, Y# mta : table[object,dateti ...
, g3 b. M1 O4 U" |3 @+ ?
liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。0 H" ?' ], Y! L5 s  T9 `7 T! S; q
请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表 , ^7 q9 K; G" g7 c: u( ?" l
嗯,可以不用placebuffer,用buffer比较好. [" S7 Q+ e* y% l$ i+ b( z9 }
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即8 ~$ H. [- E5 {# q. l8 g
is
0 ]9 b+ H1 x9 A* a; k( Ui : integer;  B, z9 h7 H8 b5 x! v
obj : object;% y1 }0 b5 P9 F" `
ta : table[object,dateti ...
1 K8 H/ D1 ]1 C: n, n4 d7 O
( l: z: c5 I% l0 q. C+ ]
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。. `, ~9 b( G8 _, L1 O& |0 Q5 \$ L
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??: w$ l9 J8 y" V/ t+ h
2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
  k0 T& h( k0 i& i' o5 i+ g% @个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表
7 g* g1 d5 B6 Z+ N7 N" w# y! O4 O8 ?& J8 L: ~9 v
( }+ t4 p( u( k: r8 q
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
& P; N4 g1 H! b  U' t1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...
: b8 S3 Z; O% v% |+ L
是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?
: A- k, {) H5 o# D感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好. u; d$ c- J5 X
: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
# C  D7 P! O( m4 ?# \; B# 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  c9 J/ u8 |/ a8 }
i : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q/ B" n$ m1 n( |0 r; N
obj : object;
: ~0 o% P- F3 k0 Z. P- g2 J) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];
  q& @1 G3 V& T+ P* Z) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo
8 R; _! g% W. D+ D. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m
2 N0 P& q; Z8 N1 e  Gfor i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T
+ t0 O3 s; [3 ~2 k6 Xta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F+ y' O) `9 v6 S: X- q/ q. B
ta[2,i] := buffer.mu(i).time;* K5 h/ |% I, L, K) m' c5 Q0 P
/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;8 U) Z8 y7 ^/ M' P/ o' x
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, X5 G# i4 H/ Q# ?. D0 D
obj := ta[1,1];
/ P4 H( X; T9 l9 w8 F7 W. X: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);1 R) U) u  W' h, M$ {! ~& b6 E0 f
4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J
/ H! R8 g- V, `1 h上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-1-26 15:16 , Processed in 0.024512 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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