设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8003|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!1 T# |' L9 q/ }' z: D
另外Control里有个Pull Control是怎么一回事啊?
- ^  M/ ?, ], S4 d/ Z" I% u5 O) y还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好
" c9 X8 h0 ?9 r0 P* s在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
2 |5 m+ S- z3 M9 _* s7 j/ b1 ^) |is
  t( |2 G( x! U/ pi : integer;. X$ i) c# I  }, m
obj : object;6 ]7 d% u4 n! ~, a4 m% t
ta : table[object,datetime];7 d- I- H- a5 p# v6 V
do, a- \. r2 W& Q
ta.create;
& f# `6 l, c" J2 i6 Vfor i := 1 to buffer.nummu loop
9 o5 s9 |% @' C3 d) Sta[1,i] := buffer.mu(i);
; \6 Q8 U' U6 Q, h4 c3 n" sta[2,i] := buffer.mu(i).time;
0 E- Z. v0 M. R9 H6 ]next;7 i) [3 s# P( X8 e1 c
ta.sort(2,up);( |, h, y- z, ^7 U+ f( W
obj := ta[1,1];+ O% Y* L  y2 ^( V1 Y% _0 F
obj.move(machine);
: X4 i7 M( z* r7 J* Y; y+ O$ `end;& C) y$ \  d+ J  [
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 % O; L$ R7 @% e; D6 v! A
嗯,可以不用placebuffer,用buffer比较好
1 S# u8 x7 t8 T: e- b在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
! }5 N) Z& i. [: n) R- e) x1 Qis
0 \" E" h0 e% i0 fi : integer;
0 j  l' S9 J$ G! n; T- robj : object;! V$ f% J  _9 J; r) _# r
ta : table[object,dateti ...
" R# F2 x0 J  \6 t7 K
非常感谢你的回答啊。
1 h3 D' ~! k3 O这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
* M; i: F1 o/ F- R4 c嗯,可以不用placebuffer,用buffer比较好
' k) q# z  u! b0 ?在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
% R( E3 W7 P$ Qis 5 d! o3 O3 C1 w" z% U, R" r
i : integer;* V0 S  v7 H* o! J
obj : object;# Q7 k/ f5 W& C
ta : table[object,dateti ...

7 `" d; ]: r9 r; d8 J3 F; v$ rliysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。
) J3 C' B# `' G请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表 - B6 A2 ]; t$ b
嗯,可以不用placebuffer,用buffer比较好/ d5 I1 l! C. k* P" K. e: ^
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即, O6 i  ~4 v: R- V
is ; s7 k4 h4 E0 J2 ]" [9 ^. g
i : integer;
7 z5 S# \- @, o1 v8 O; Bobj : object;
" F, t7 {0 ]& |( ~ta : table[object,dateti ...
: [/ ^( `" H" v* r
, i( v5 O# c( ?8 A
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。, e/ K, G, k3 {- [( j/ _
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??
9 x9 t: N( i4 ~( i, a3 J2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
: i2 G* }) N6 D' |; u个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表
' z" |$ |* Z! E: x
/ F) n/ a# c$ a2 ~
1 o( r; f! y8 b我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。, Z. P4 S" I# J/ |
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

0 K9 w, f/ b5 m& k( V8 Y  @是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?
+ o! ?4 ~) M: ]感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好
9 L* G# u3 \, X: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即" g1 A/ K) z- ~; c4 E$ R3 x
# 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! x3 n) [$ b/ \+ p6 e9 Z
i : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q
# S6 q) }. }! R. w; c+ ?% w% w4 Uobj : object;  V& N" H! l/ k* b! i$ c! z
) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];9 ^6 `+ J/ u+ C- C
) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo5 n1 I8 L" r3 K- }& H' [9 S# v
. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m0 j- ]. i( T# {7 A5 U
for i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T
, u& c. f) ~( Pta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F
0 i/ I& c  g1 a. fta[2,i] := buffer.mu(i).time;( F5 N3 t0 U6 [1 i- P( O
/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;- H5 `! ^4 P2 J: M
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, X8 _, n" O9 q8 d# r% f
obj := ta[1,1];
: U& [1 y( x+ z$ E, p) l3 b: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);' P8 g, M0 H  L# J1 G" x- N
4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J$ }  k) M% ?8 \. {
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-4 15:50 , Processed in 0.020285 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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