设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 7100|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!( G/ m, i5 t# a, W, B3 w6 y' C3 }
另外Control里有个Pull Control是怎么一回事啊?
5 `. c2 W; B; @- f' E还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好
: f6 t# X2 `& Z2 }2 F8 _在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即# X- V6 }, j+ [$ z2 `- a( W6 D
is
* ~3 Q" n* }! q8 O4 Q) \5 Ni : integer;8 H  h5 E3 L0 i
obj : object;0 f* a2 j: V" x& C0 f1 r& V
ta : table[object,datetime];
( M4 j1 K1 c5 p* h2 Edo
- d  U! v( H9 _* r! xta.create;/ M) W; X; y9 a, N. O- z; Q3 Y
for i := 1 to buffer.nummu loop
: |1 }, j0 Z# j- lta[1,i] := buffer.mu(i);1 \0 m1 S# f; [% q2 D
ta[2,i] := buffer.mu(i).time;
6 Z, P/ X2 X( y5 wnext;
( X/ s7 \4 B- {) Z8 _2 wta.sort(2,up);7 x6 u7 U6 q) b) m) X8 S' X  @' w
obj := ta[1,1];/ f- P! I! K% t
obj.move(machine);0 j# n& T& V+ i3 d0 t" n; K
end;8 U, T+ E; s4 A2 ~2 y. n
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
6 t+ g6 `6 C& M! D  t5 U嗯,可以不用placebuffer,用buffer比较好
  y  N! N) C  K& K0 z在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即3 _* h* T9 b3 X! O0 X! B, {1 J* M
is " @- G( }! E: r4 [
i : integer;0 t/ C/ k: V* e: D/ X& N) y
obj : object;/ |( A7 C- ?7 l8 ^  [* v  V
ta : table[object,dateti ...
. F/ x7 i. G1 D  i
非常感谢你的回答啊。
) B* @  q/ x' `& W4 O% o+ N* U这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 * j* \3 W7 A6 [, q' R7 H+ r+ x: N* g
嗯,可以不用placebuffer,用buffer比较好1 \. Q9 T/ }. O' a& e8 [* I- _
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
% e. v2 d4 r; X' c* P( his
2 l& X) T" R. S7 G8 `6 U% @  i6 Ni : integer;
9 ]0 `: U- F* K" E5 ?8 i4 O) ^obj : object;7 [4 ?1 k2 v0 a0 T8 L2 R! E
ta : table[object,dateti ...

6 R0 }9 q1 o3 A4 Q3 \liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。
/ Q( K8 w" x# J" x/ ^5 }! m请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表 # d1 k/ h, e% f2 N( [1 u- G  d3 h
嗯,可以不用placebuffer,用buffer比较好: W: K- Y( ^1 J* E0 V; F) ^( U
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即% p; z( _- `2 `$ E2 L( u, V
is
, o( ?2 r  Q8 `4 _) t2 x( s1 mi : integer;  \5 [" R: }3 n
obj : object;& f9 _! E! g  u
ta : table[object,dateti ...

: [4 N* r5 H4 f1 _
' Q  B# n. Y* C% z我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
& _( ]: [- {/ Q& T7 k1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??* p+ y3 x+ `: P+ D# j) \
2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
  z" D6 u- i7 \# A5 d个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表 3 B" q- r2 {4 I. j

+ ^* }# A, h, y8 a7 V4 I3 J) @  T; B3 Q: C* B0 o3 }5 b5 p
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。* w  V" X* p* T9 r8 \
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...
# x- n/ j: v, [7 e
是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?. ^  [) ]/ E% S) k. r# O/ x) V0 S% U; x
感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好
( a. p1 @$ t7 L& `2 j5 ?: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即6 }6 i! f7 j9 n. b8 Z
# 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: D% O1 M8 ~( |1 [, x
i : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q9 F! a( X! O. b* D* C8 Z1 E
obj : object;% _" e1 Z6 w2 `, G' y
) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];5 l7 {! p% R( W4 x
) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo0 t" z5 S* Y5 L2 U) M  [
. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m
; v' R& t4 \0 Z6 I$ A7 ^8 z( ^for i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T8 y+ G$ ]+ b- R9 @
ta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F
% q0 n8 F+ M  ?, l* x6 `% Y! z6 `2 q% zta[2,i] := buffer.mu(i).time;; Y, c# W9 {& e: u. ~& O8 i. M
/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;
1 p' Q7 \! C6 w7 B1 f8 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$ L% A; `5 n# s& V# x
obj := ta[1,1];. u$ L6 L* |- K, W, p2 A
: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);
& n# }$ g3 T- {4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J, d1 i( n9 ?7 Z2 t" m
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-11 06:07 , Processed in 0.017756 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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