设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8554|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!
8 Y7 u% P9 k. [. b: T另外Control里有个Pull Control是怎么一回事啊?
; ^- z; Y' n0 E* {4 Q还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好+ I3 T$ C: @+ h+ `; D7 R1 F" g7 u
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即1 C$ M7 M; w! }# y# G9 J
is 3 A5 u( x; y9 t, g
i : integer;
6 D+ a: g7 Q* G+ T/ Wobj : object;: c+ r. G8 e  \) V- c
ta : table[object,datetime];
8 {. T8 e& J8 x" f  K3 Jdo
6 t; l2 s" g! q" s) H) P6 _ta.create;
- q* y  U, c6 Y# s& q/ D& vfor i := 1 to buffer.nummu loop- j9 R  o3 N0 i8 X/ V& p! J
ta[1,i] := buffer.mu(i);
- A" \: H+ C/ G* ^0 Z4 nta[2,i] := buffer.mu(i).time;5 q8 V* v& d8 S
next;0 l3 r4 @5 o( C; b& E& _2 d6 [/ O
ta.sort(2,up);
$ W* M% X: G  y0 T5 P8 N7 j. Robj := ta[1,1];
9 k% n6 Z3 H) v4 Yobj.move(machine);
+ A. g( g7 x4 H- N3 e0 u  gend;
! q! Y  e. y. a! S7 _# }上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
9 i+ |# Q# ]1 ?嗯,可以不用placebuffer,用buffer比较好& t, f  B5 k( H$ |+ {
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即  \5 L) |- ~1 d* G8 v: d
is + g) n" P4 w/ s# o+ X
i : integer;; ^) N/ p3 U3 L" q# P! h
obj : object;+ q5 w( ]' f6 w3 m
ta : table[object,dateti ...

& A& U$ l# X1 X/ s& {$ |非常感谢你的回答啊。( j7 U8 c: m/ Q" C  ^/ ~4 ^
这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 / ~; V3 q) W# J' u" f: J; c/ o
嗯,可以不用placebuffer,用buffer比较好
5 X; C2 Q' y. D7 C在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
: B1 w1 ]* r7 S4 vis
1 o' S, m# j+ o/ c4 E) Z& ki : integer;6 ], L2 W6 i$ O. O- Q
obj : object;
( d: z! _7 E" ~) y' A/ W* ]ta : table[object,dateti ...
% B8 h: w" j1 _: F' s' M
liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。
4 K( ^4 s  r( R3 ?2 i; g请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表 $ y& h0 u4 s0 S+ U1 e6 B  J+ D& P, D/ e$ @
嗯,可以不用placebuffer,用buffer比较好. ?8 x9 F! Y, I/ n0 S2 Y; Z% M
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
: l1 P. Q, m( \7 f0 F& Eis
, P. q( b0 N; ti : integer;
; P- W3 g) j7 j5 e8 g7 M/ Y2 H7 lobj : object;
3 f' ]# N/ q0 w# i  Wta : table[object,dateti ...
; x  X; ^6 ~& F3 M7 k: @5 {. A3 L8 ^

, Z- \- k$ |5 `2 r! f1 O$ A我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
, p, b! w+ x' `1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??
0 T  L2 Q# h  R5 h& P: f; U6 f2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。/ H% z  N, v& ]6 w. _2 z; G3 `
个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表
* m2 Q4 d2 F+ M& Z0 P7 y3 r  c5 |7 i3 U# ~. N+ p$ r: `
- w" M6 i9 a5 V& Y
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
$ O) O' p- I$ G  n! F: f1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...
+ R' Y' n4 F+ R/ _9 O0 c
是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?. ~" N( L' d8 j8 ^" n/ B
感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好7 K! L$ G) ]# [* R6 c
: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
4 \9 g) V. ?4 k4 @. B, Y0 J- ~# 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
+ V6 l+ h) I4 T, }" p: F' r. k, xi : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q+ j6 y6 _5 g2 o8 p
obj : object;* n" B! F* Y3 Z) x
) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];
- }0 j& p' {% `9 c) j) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo
5 ?. j- i' t7 I3 n- J& _. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m
' v$ q: R  P& n0 Hfor i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T
1 J4 I7 ^( i3 S* {ta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F
3 k5 t: _( z9 @& zta[2,i] := buffer.mu(i).time;
2 r) }9 z0 I/ C/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;( V5 d2 H9 B  j" |3 J- N! 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
9 m9 g) e$ c1 ?7 N, K7 tobj := ta[1,1];
; C+ t7 T, F! W, |8 m6 Y7 b( v: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);, x* _  h! L. p& u- `. ^( W
4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J. [1 p+ d! s, q, K: I% H
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-5-8 08:37 , Processed in 0.014782 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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