设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 8787|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!
$ ^0 W3 \, ^" A  A! e另外Control里有个Pull Control是怎么一回事啊?+ y$ w1 @* C( R- E& k. H2 j; g
还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好
& B) S8 {6 [7 b1 N9 ^+ V在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即' V6 a: k5 v7 K$ \8 Q
is
; @5 N5 o/ `, y; Ji : integer;
* `) ?5 Y, E6 q1 W! m, `: yobj : object;
1 A& {2 \+ R8 |/ e. s1 x3 v+ Pta : table[object,datetime];
2 G9 D' I( ]/ f. a, U) ado& ^: n- ~" W/ s6 ]0 C3 j- R
ta.create;# [, |% f$ R: T
for i := 1 to buffer.nummu loop! U" N, _6 I# h, w7 b
ta[1,i] := buffer.mu(i);' h4 V+ y! A8 }! R) ^4 X, B3 n
ta[2,i] := buffer.mu(i).time;" L" |4 m7 w8 ~- Y
next;- w2 G  ?  ]  Q1 X5 I9 t: A3 @
ta.sort(2,up);
: O8 S% n4 ^; @* gobj := ta[1,1];7 P% d$ ]: g1 s8 ^
obj.move(machine);
  O8 z3 H* d4 d- _  p2 r0 uend;
# o5 L% f0 j# n3 m  g. g/ h上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 ! e$ ?% m) N8 h9 b' b' z
嗯,可以不用placebuffer,用buffer比较好
) {2 S8 @- a! R8 L在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
, i% v5 ^5 F! Q* F( [3 ~0 his
( {. F" b& I) _- K1 v6 @" X+ ji : integer;- @- |+ V+ J8 p
obj : object;
2 y3 l7 Y- u, Wta : table[object,dateti ...
9 J4 a6 \( _8 D# v2 ]8 {7 c
非常感谢你的回答啊。$ t0 n  o$ `+ T! w
这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
% K- i# ^8 f# |嗯,可以不用placebuffer,用buffer比较好
* E4 x7 i4 N& ]5 Y; |在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
  g7 \; k: q# U% f8 [$ J% ?is
7 |; P/ T) s3 j% ki : integer;
$ k5 h) _' }& e: b" C, q3 v6 X6 G. Zobj : object;
2 E; s2 u1 y5 K* `" ~: Zta : table[object,dateti ...
, t8 |$ i# U  ~
liysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。/ x" T' l) a" o: q
请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表
8 X1 F! P  @  C# i# `2 n$ f嗯,可以不用placebuffer,用buffer比较好
0 U* d3 J  _1 f' r在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
5 x/ b0 U6 a8 Q' \is
2 \9 \+ q+ K8 }  q, Q3 pi : integer;
/ x2 x* E* Q0 s) _; wobj : object;
) \3 [( {1 ^7 Ata : table[object,dateti ...
+ t, f( o/ z, z2 S
$ q  H! `1 P$ ]5 m# _" g) }
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。% Z2 Y9 W: J, ^
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??
$ t) W: Y8 o6 G' J2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。
" Y: }8 m3 s: J  W- V; L% R5 N个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表 8 ?/ s6 D! ~' `! }9 R6 I% i" _- n& u
+ `( z3 V# N. J6 o2 [6 Y

$ d/ r' o0 x5 O! [& g" C  a我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。
# i1 \% ]- R2 \9 A$ E& l1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

+ w6 F3 @# }7 g! y4 [是这样的,后面做了一点改动我忘了写上,这个Method是关联到下一个Machine的Exit。即当后续设备上的工件离开后,调用一次程序,对Buffer中的工件重新按优先级排序,再取工件。这样就应该没有了楼上所提出的问题了吧?
* t" Z/ F  t6 M9 o& j感谢gc_jiangwust 所提出的看法~
发表于 2009-6-26 09:09:47 | 显示全部楼层
嗯,可以不用placebuffer,用buffer比较好+ I& C5 v4 Q  @
: M4 Y' k  B( W7 ^最大的系统仿真与系统优化交流社区在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即3 D* R6 L# y  |, a
# 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; ~! I0 Y% Z1 k( }) g3 g& H. N, e
i : integer;最大的系统仿真与系统优化交流社区  `& ^! b3 @+ _% l0 h0 C2 Q
1 M* c3 r- ?+ Z: ]: H$ w" hobj : object;
# r" D  e6 S# r) r/ [4 P; B/ d: b; K/ b0 Q) y最大的系统仿真与系统优化交流社区ta : table[object,datetime];
, k" m7 N0 A6 u8 F+ i. l) k; U+ @8 u3 {5 G4 F  l( U仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastdo
  m3 z8 Q) ^& e. f/ |5 N  E, S( Q. Q1 A( r0 @+ o. h+ n7 q. N( e8 [ta.create;最大的系统仿真与系统优化交流社区2 ?/ j0 W% ~: B3 j8 W% m
  p! @9 E2 O" u4 E$ Tfor i := 1 to buffer.nummu loopwww.simulway.com: o1 s4 }4 t$ A/ Y- F; T+ g/ s3 _3 w; l2 j# _" l
ta[1,i] := buffer.mu(i);仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repast0 c; I! k7 f1 x+ F" J" G: R/ k3 R' C; F, M$ T
ta[2,i] := buffer.mu(i).time;
5 }' J9 L8 }* R; c" ~/ e9 \& n5 w6 j仿真,仿真论坛,仿真软件,物流仿真,供应链仿真,生产仿真,系统仿真,流程仿真,arena,anylogic,automod,extend,em-plant,flexsim,promodel,witness,乐龙,swarm,netlogo,repastnext;1 p5 a8 n- J. l( Z( L
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! i$ w$ P( d$ V6 d
obj := ta[1,1];
+ V7 y$ t$ ^3 y. P- x( b! z: C: k6 N# U1 E: t% r5 p/ \0 b最大的系统仿真与系统优化交流社区obj.move(machine);
- B/ [; d( g2 l; ], Q) h- F4 v" r8 O3 l0 g$ s" ]- lwww.simulway.comend;www.simulway.com: D- u% L* ]# t( p* G) J8 N$ Q0 k' |  C8 z6 H
上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-17 16:35 , Processed in 0.013317 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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