设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8541|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!0 {" a5 g( c- g, E* `# }. a
另外Control里有个Pull Control是怎么一回事啊?& T0 D& K# F& |8 m- W2 J8 m# 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比较好
2 z( n0 g) G+ X& f在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即0 @- ]4 k4 q; q5 J( w
is
1 J, y. w8 i# v% p. q% ^4 ii : integer;
7 g; x' D, @0 T3 Robj : object;. q6 Q/ c2 N, T/ {
ta : table[object,datetime];
, N' \3 v) z) m8 qdo
" Q. j6 ]7 e# u" X0 j( C9 Gta.create;4 E2 C! J4 q4 x0 v# q
for i := 1 to buffer.nummu loop
' E+ J3 k" `4 \6 Y6 b7 Dta[1,i] := buffer.mu(i);& S2 p* x# |9 Y  L) L0 ^0 t" ]. G
ta[2,i] := buffer.mu(i).time;
7 Y/ e3 @$ R0 Q" B/ [next;1 t+ {) y% C, r2 H
ta.sort(2,up);
2 `, y* T  s& X: B5 jobj := ta[1,1];3 W7 ]7 J, B' a+ }
obj.move(machine);' ^. z; r; A8 g# t5 f6 c1 ?
end;
7 o0 N- w9 t8 d- L上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 + U  E1 G. _9 d( F3 v$ k( S+ W
嗯,可以不用placebuffer,用buffer比较好. B' f* p( a, W7 Y& l
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即, f; N3 z3 z6 e. J/ l' T; L/ P
is
* t6 I% K/ G* O6 ?. r) i1 Ri : integer;
3 n4 Y" N) p. xobj : object;' ], Q8 u4 [5 y  N
ta : table[object,dateti ...
& L8 k$ b" d4 G8 N; {# f
非常感谢你的回答啊。6 K4 u( R) ^3 P- r
这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 ) R0 p9 o! i7 ]0 m+ g
嗯,可以不用placebuffer,用buffer比较好
; M" V  q' i) M" r1 T% }在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
* i$ N5 ^2 Q  }. i7 }, I8 Ais
. E' A# c& D' d) Z( Wi : integer;
8 F8 I3 Q8 |# a% Q3 T7 q/ A1 P8 {9 {obj : object;
, i+ ~. Y8 h" P7 J& D0 x! fta : table[object,dateti ...

: a  m& X( ]" f! Uliysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。
. w9 O# H$ e# x$ f4 L( ?# {  ~请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表
# p) z% b& E7 L4 C6 U6 H嗯,可以不用placebuffer,用buffer比较好
' C& c; S3 l/ D在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即5 O$ ~7 H  F) v8 |4 [8 B5 S
is   N0 V) s0 O) C. S+ `7 `
i : integer;" {( h+ C0 M8 ?6 B+ w
obj : object;
( F1 X% N/ `: R9 yta : table[object,dateti ...
4 x! v4 b( `# r9 |- o& k

3 M6 {) W' @: Q6 l我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。- k2 o! b3 u; @2 F
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??5 A2 O6 c/ `# [  ^# L
2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
1 x$ b1 F+ H) h& o& g个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表
; h! U5 {2 f1 f4 r
  H1 ]: `  X" y2 f/ ]  ?& j4 O9 G0 W) K* C! W" z
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
. N& W" V5 F1 Z) Z0 W6 @1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

: o3 [( ?% {; u/ S0 q3 n是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?
, F" q! y" u# P: O. i. d感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好
0 O  `' T9 h3 }! m8 p9 L4 g( I: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即5 E" \" J$ \( N# {: ^6 _. W( 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  c
; R  i& {0 f: Z9 b8 [i : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q* U; l$ z8 k* u
obj : object;
0 C) l2 N+ ?1 P' J4 V) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];
$ i+ s% P- t, \" e0 s( A5 b. o) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo
: K8 [0 J: J3 `. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m
  Q% m% N7 f. Y) W" vfor i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T
  D9 i2 l$ m& G7 Y2 p! m* E0 Dta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F
+ {" _8 _& ~& T$ g3 {ta[2,i] := buffer.mu(i).time;7 Q* B& e& x7 P7 f" K6 T: h
/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;
. C4 ^# w5 O2 e' j  P* c+ R: n8 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
% m% G- Q" U# @% e+ Oobj := ta[1,1];
3 W4 L4 ^) M+ \, A: n) i: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);6 z- [$ w1 l# D- d6 A
4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J' {$ [4 z: @, v- y7 X9 {
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-5-7 01:37 , Processed in 0.016141 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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