设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8072|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!
) i7 W4 E5 T8 Y* \; i6 }9 P( L另外Control里有个Pull Control是怎么一回事啊?& j! j2 R4 L# Y% E  j) t- K, m
还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好
5 O& x; y6 v/ m+ n在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即- V- T8 g: r# [0 G. b% B; @( c
is ) `& t7 \6 p! L* p  z
i : integer;1 |1 b; F2 r' s! @# ?5 g' V
obj : object;/ D) m2 t: m  a: f: [) B0 i4 @: M) Z
ta : table[object,datetime];
/ E  z, p1 w, a7 A4 rdo  |, P8 U, H* C8 H1 O8 u7 N  e
ta.create;
* l3 a; a' n3 B" f6 Efor i := 1 to buffer.nummu loop
4 @( S& T; a- x; n& p" Wta[1,i] := buffer.mu(i);
+ _6 y: ]6 v$ Wta[2,i] := buffer.mu(i).time;
& |. i* u9 @8 vnext;9 M+ C& t" Q2 U4 M
ta.sort(2,up);6 B0 g0 l: g1 r- Y" |
obj := ta[1,1];3 Y' N" S! L- W# C' H8 l9 G; y
obj.move(machine);$ l- {! J; v% L  }. u+ Q
end;" d3 q* i4 Z6 w
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 8 n* C4 ^0 V+ x% P4 s7 c  P- j
嗯,可以不用placebuffer,用buffer比较好
  i  h# {# G+ S6 _: Z# R在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
- d" C7 g0 v# `$ ^" o& p2 H1 tis
; ]* v; ?6 A0 b0 o' L# T: X+ ui : integer;$ L# R6 X% K' G1 \' J4 c0 m
obj : object;/ P+ \9 B9 W! V3 |- t
ta : table[object,dateti ...
4 Z$ I. B0 m6 e
非常感谢你的回答啊。4 H( Z9 y2 E  c' [4 B9 Q8 B6 {
这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
" H$ a+ G1 ?& b9 Q嗯,可以不用placebuffer,用buffer比较好
( L3 h& {. Q& \7 F- ^在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
) z) M9 c+ G; Xis + ~0 B. Y' J& {6 O
i : integer;
! ?; N8 d$ g3 c' h1 Hobj : object;: g& [' J/ u+ H/ {; U$ `5 B5 v' g
ta : table[object,dateti ...
. q2 h; U! T$ s
liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。2 h" ^* C! [9 e$ V1 y% _
请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表 4 @2 b0 ^. q; O5 c6 a( M2 N
嗯,可以不用placebuffer,用buffer比较好
8 w1 V) D3 ?/ {- U9 h* W1 ~1 [在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即2 l$ |) {. C% Y5 @% q" ~5 S1 ?) n
is 1 l" e, T! r* _. ?& @8 |0 n; [* J
i : integer;
, R3 y- M+ q( d) w$ v: sobj : object;
# u. T7 G4 C( g9 m1 t/ n% pta : table[object,dateti ...

- ^, O4 V; c% j* x& E' p9 y
; y& w% F. A# t8 c$ h( N6 s7 Y我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
  {4 z) w- b9 L9 h1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??
, u4 Q% O( b( R# r8 o6 Y: F4 ~3 Y2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。! p' _( U0 I7 {- S9 S6 g) r
个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表 4 X1 C4 I# m; u8 O* \, d; p
5 u8 k# r) t5 @- L% O5 k! Z
7 e3 U) J# S& |# n; O. |* `; l6 ~# c
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
7 l5 S" i% J  E, R5 E6 u: ]- ?1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...
! s0 R) h% W) X7 H6 w! d7 c7 u$ q
是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?7 F- k9 \3 q$ j) N2 H8 i6 i3 Z
感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好
6 A) S! w" Z$ F9 }7 ?0 ^0 Z4 P: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
1 ?" D0 K, M+ v' I# 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
+ v- L2 A; d# W, l9 li : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q5 e9 Q) f8 u8 a1 N  N
obj : object;
1 u) {, B2 Y6 U- W- W) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];
5 v4 J4 I- n0 d, D% n, ?5 Y1 ^6 m) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo
' B9 L! g5 E% S6 S$ [$ S" t. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m% t8 b( r4 m+ q
for i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T" ?4 \/ D( D! \+ s+ C3 i; p2 |
ta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F: H9 }) k3 c- ]0 t# \+ a: f" j7 B
ta[2,i] := buffer.mu(i).time;
1 Y7 q8 h6 z; p/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;0 E) M2 I: _  U- V( Y
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
+ r: m& F& Y: j" |0 |& C- Qobj := ta[1,1];
) g. Y" {/ K1 Z" e/ Y! f: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);
( ^9 y+ F4 v5 `: S! S# e% o" D7 v1 T" I4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J. W, D1 X  m# ?' b* l- M0 v
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-15 16:44 , Processed in 0.017604 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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