设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8725|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!( P0 |! P  \8 U7 `9 X; j- w7 R
另外Control里有个Pull Control是怎么一回事啊?
3 ^9 U4 l) |- @4 b3 p( |+ v! r还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好4 e. H8 M8 W4 i" ?& w& w1 c. e1 G
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即! ?% d6 e8 J9 W3 J1 {
is , ^3 {9 ]* A2 U2 }' p( }
i : integer;  L9 G  U7 }5 P2 x& _7 i; T
obj : object;2 o# v! j2 Y: Q# q0 p# q6 r
ta : table[object,datetime];) d- [# T, ]( _  ^7 {/ {- S
do
. B; H0 p6 f  c- }ta.create;, E% \' J, j. `% r
for i := 1 to buffer.nummu loop
. g! I- D1 R$ O$ L+ V6 Zta[1,i] := buffer.mu(i);% b; [4 K8 [$ \& S- o8 d" {. y: k
ta[2,i] := buffer.mu(i).time;( o1 K' m! q3 q+ ]. n" ]' d
next;5 R! {  K' s" L- {  b- K5 V* R$ O
ta.sort(2,up);" v5 f3 W0 v# m' Q5 ~
obj := ta[1,1];
$ e  d. M: ~, u8 R" ~6 W4 Zobj.move(machine);  p4 I+ b0 p7 }3 Q$ M
end;
; ]: J/ i6 l6 r0 s' O# n上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 1 ~$ P0 I0 y/ H5 _/ Q' H; x  [
嗯,可以不用placebuffer,用buffer比较好/ Q+ V8 m1 c! v1 M" l  ]
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即' C0 f6 K7 `+ I8 D
is & p! S7 F2 M/ G0 R- l
i : integer;
& a% q# N  t, A& ]# w1 u: bobj : object;/ n( z8 v9 x  k+ [4 h
ta : table[object,dateti ...
' j, N2 E$ I! j3 g" a$ ^
非常感谢你的回答啊。. G3 p" ~* o$ U% p. p- b+ y6 `, w
这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
! h0 o2 z: w: e8 L' O' A+ K嗯,可以不用placebuffer,用buffer比较好
+ T+ q( p( ^( l在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即8 h. b9 l4 E; ?9 t3 m. H) [
is
+ F9 j1 Q, y( ~) K1 f1 V3 d- \$ Ai : integer;% Y( o: f0 a4 i4 n. V  R& F$ T& e
obj : object;9 r8 B9 R- r8 w6 |! a" k7 C
ta : table[object,dateti ...
& u3 w& O, m  N- ?6 [' n2 x6 k
liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。
$ W7 b8 {* r; v, S请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表
/ v9 P9 y" j. h' Y6 [4 `嗯,可以不用placebuffer,用buffer比较好- E9 k- F; w- ^  V$ _: c
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
4 e" @& J2 B& h. g! I1 Gis
% ?/ k* [' @0 ~$ `i : integer;
5 c9 B; X* R( q- R" O& O( Nobj : object;
$ b8 B" Q# g' Vta : table[object,dateti ...
% D6 ~; [. _' q9 j# E; r- o4 u
4 G  T- `4 j% p0 o$ ?' [
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。$ g  w- G+ ]  W: N
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??
* k: V# ?( E3 C3 H2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
1 ^/ B* p1 s+ T  n个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表 % l; h6 g! l2 c/ q# ]/ e

% \) N, L% ]& Q5 Q0 e
0 ?; O" [4 f7 d$ S; k- k: K! c我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。, H) y7 F" I& ]! _# c/ i
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

; r9 B3 ^; b0 C# X! w8 L是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?, A8 I5 @) |' A! K: @
感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好
) \1 M: q# H1 i! N5 g4 M% Z4 i: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即! N% K/ M2 K2 O+ c2 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
+ P- ^! G4 a' B6 \% z. f% }i : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q0 y& M  h' b" z. k4 u
obj : object;( b+ o* g& Q, p
) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];
  }/ P  `& n) |* ~! h) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo8 e8 t; m1 X% J
. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m- V3 ~2 u  r/ O2 X, f' V
for i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T) z' j2 y  \, I: l2 E# j
ta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F) |* R7 [# [4 |+ d( Y6 A: L! z# z2 n9 d
ta[2,i] := buffer.mu(i).time;
  t8 Z9 R' }# v$ e$ r1 M/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;7 L3 B2 F: a9 E2 U8 Z* ~9 |
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; ?& q* }" Z2 L! T5 U
obj := ta[1,1];
9 }3 |* x8 n2 Z% w& h: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);4 A, ~% |) V4 d: e, U
4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J6 s! c7 w& W' n0 M
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-6 21:54 , Processed in 0.015492 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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