设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8885|回复: 6

[求助] 调度优先级

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

最佳答案

查看完整内容

嗯,可以不用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比较好
3 w1 ]7 f" C! o在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即$ m0 F1 q6 {& W3 ]" L- V" i
is % r5 u, b1 i* _$ W
i : integer;
0 a- M; p: F/ _& F( ^obj : object;+ K$ }5 G$ @! p2 G0 l
ta : table[object,datetime];5 t9 K3 A0 o# A4 y" q) ]8 C- Z9 Z
do
9 ~/ R* U2 D# c* n, C! Ota.create;
1 B, o& g  Q/ N( Qfor i := 1 to buffer.nummu loop3 v8 D# I8 m$ d9 T  \" B
ta[1,i] := buffer.mu(i);2 |  K& O1 s6 h  e* A3 N0 o1 I/ S
ta[2,i] := buffer.mu(i).time;2 ?) w( K2 m3 o7 d9 ~' K7 c  p3 i9 x
next;
& Z9 _; k' e3 {) ~2 \ta.sort(2,up);# A: a. I) ^- g2 x9 x
obj := ta[1,1];6 c1 d, C! _8 d. z, O  H3 u
obj.move(machine);* x' Z+ {! ~1 A
end;6 k3 Q4 H6 z5 k- W. f& {
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
& s7 ?5 H' s1 P嗯,可以不用placebuffer,用buffer比较好8 ~: }1 @! {2 q4 W' c& w6 W8 M
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
1 r3 F0 ~3 C3 z* V/ L: _is ) T6 d9 c/ }# N7 ?
i : integer;0 H$ K) E$ b4 D+ J9 U3 c
obj : object;
2 ~3 N7 Y/ S* `$ S( V0 {* ~0 I* U( ?ta : table[object,dateti ...
0 ^1 J2 Y' a+ i$ [
非常感谢你的回答啊。
. l) B/ Z% ^; j/ X: W8 e这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 / F1 T2 ~6 w/ n8 O, {
嗯,可以不用placebuffer,用buffer比较好
* t  O* F7 f. w1 _在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
7 z6 m" ^; G3 G  o( ais % H* ]" l( S4 }/ v! I
i : integer;7 l7 [" P. Y: s1 R! n
obj : object;
* {5 m0 a8 s5 ota : table[object,dateti ...
, h! ^3 R- v# t4 P8 {8 U5 ^; s
liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。' {# d, B5 v3 [! l
请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表
# ^4 N+ E' z* I6 i% k7 j嗯,可以不用placebuffer,用buffer比较好
) m. X; q0 U) q1 @在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
+ _* w2 j. p, ^6 M% dis 2 l7 a+ S7 g' Q  X! G  v' O% o
i : integer;' H1 p8 V1 d; k% o$ z% X
obj : object;3 I, i) V/ i2 q4 N& v
ta : table[object,dateti ...
: k, g) f; o# s& {# i+ Z
% d: P9 w% z) K- N
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
. W  p5 m, A# x9 r  }2 z! G( t  k1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??
" U# P) M/ j1 Z2 Q2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
- h* F& Z5 C( ]5 |! h个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表 ( M3 H1 ~7 e$ Q) h; g

  X0 ?  z' q& }5 ~' O, T* o: \
2 F1 L) ?( i8 K9 u; h# f+ v我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
) E# L. ~% n- \3 X& j1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

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

本版积分规则

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

GMT+8, 2026-6-30 15:43 , Processed in 0.013411 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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