设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 7160|回复: 6

[求助] 调度优先级

[复制链接]
发表于 2009-5-25 15:05:18 | 显示全部楼层 |阅读模式
5仿真币
对于PlaceBuffer中的工件,对其按交付日期排序,交付日期早的优先进入下一个SingleProc。请问怎么编程实现这个功能?可以的话麻烦给出一个范例程序,谢谢了!& A% G6 P0 h" y' |4 \4 S' E5 |
另外Control里有个Pull Control是怎么一回事啊?+ C! O$ a. k8 F% K: ^! {
还请各位帮忙啊,比较急用,谢谢!

最佳答案

查看完整内容

嗯,可以不用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比较好8 x$ ]' d6 ?: Z: C& z2 W2 H% A
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即$ }% R# J" Y% {0 s% R; X# e3 k
is
# ]  W7 |. V+ f/ k5 Q9 ui : integer;
1 w. Z8 ~+ l2 mobj : object;0 J$ n# `( O+ G( i0 i. C% c
ta : table[object,datetime];6 f9 ~* ~8 U' y; r2 }% K
do
7 z1 r- ?1 ?1 f) uta.create;* Q- u, [4 \( j6 Y
for i := 1 to buffer.nummu loop% `. {* V: Q2 K4 I" e) k5 a
ta[1,i] := buffer.mu(i);  u! ]* p# J4 n) s. F6 k1 v1 w4 ~  K* b
ta[2,i] := buffer.mu(i).time;& U. |- R0 g( [  x
next;0 Z5 K. K" K- F! s+ L! \6 h2 }
ta.sort(2,up);, u. Q9 X( T0 P: g  Y( B
obj := ta[1,1];
+ r* Y( p' O. P9 Bobj.move(machine);7 E! J9 `- L0 U# E& T6 b
end;
4 i" h3 K: `7 @: H& }# Y1 C& J5 P/ j上面所提及的buffer.mu(i).time就是指buffer中的零件的交付日期,这个需要在零件进入系统之前赋值给零件。
 楼主| 发表于 2009-5-27 14:11:20 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表 + t6 |+ l( t' d' e; D; k3 i& V' L
嗯,可以不用placebuffer,用buffer比较好! c) ?: @  V( r) C4 M
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即7 s* k. X& \8 `3 p+ D
is ) M) @; `0 W& y; h0 n
i : integer;7 F+ V* s7 E* u" |2 M/ o7 j
obj : object;# u4 B1 r6 l( u) e
ta : table[object,dateti ...
+ G9 E  G  s- T( \! U9 W4 {
非常感谢你的回答啊。
) |' ~9 B( x5 n" D4 s! |/ D; f这个思路好像确实可以,不过我还是碰到了一些问题,结果不对。可以加你QQ请教下吗?我QQ是516014959.
 楼主| 发表于 2009-5-27 17:46:54 | 显示全部楼层
原帖由 liysunny 于 2009-5-27 11:26 发表
4 V3 o, w. I/ r6 u" I! z- _嗯,可以不用placebuffer,用buffer比较好
2 J* d% g2 K3 F  W在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即
, l- E% `6 X3 m! H6 Sis 4 a; K4 q, ~: U* [3 n5 E8 u
i : integer;) n. @. q' N+ g% Z
obj : object;- I# d; y5 \9 z. y2 o5 M2 v2 v( u
ta : table[object,dateti ...

; r, @! N9 S- l2 w* y( X9 Y- m7 Z* pliysunny已经帮我解决了这个问题,在这里对liysunny表示感谢。, ?  x5 n! }+ p
请问怎么将仿真币给liysunny
发表于 2009-5-28 10:06:33 | 显示全部楼层

不同看法

原帖由 liysunny 于 2009-5-27 11:26 发表
, Y& \# J# Z( s- ]5 W9 D5 a嗯,可以不用placebuffer,用buffer比较好3 t; e# \7 ^* n
在实现的时候,可以在buffer的entrance处设置一个方法,实现零件进入buffer时,对buffer中的零件进行按交付日期进行排队,即- d$ j3 l4 @( l& U9 _6 Z
is . k* N1 L+ B2 H, q9 a
i : integer;
! `  z, J  w! W# |/ P$ Tobj : object;7 ^0 Q8 b1 l8 F5 B( g
ta : table[object,dateti ...

! q3 l- d7 _0 T' X9 l: a- g; i0 t! b8 o' V  o% q
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。1 ]( i! s9 ~  y9 p. I
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正有mu在加工呢??  v7 x7 v, @- l( q6 Z6 j- z0 L
2)当模拟快要结束的时候,也就是source不再产生mu了,但buffer还有堆积,buffer里面堆积的mu的优先级和它的位置并没有改变,还是按顺序(maybe FIF0)出来。. J" R' Q( M) M! N) N# @
个人拙见。
 楼主| 发表于 2009-5-28 10:15:14 | 显示全部楼层
原帖由 gc_jiangwust 于 2009-5-28 10:06 发表 / Z  a( U8 _8 R/ ~0 g& K, k3 J/ D
. d" \0 p; U3 p. J! O
. M2 m9 u6 A3 r2 V& H4 b/ ?
我怎么觉得这个方法逻辑上有问题,不知道楼主的模型的其它边界条件是啥样的。; q' v: q  U4 k
1)用buffer,就说明前面的工作节奏快,后面的工作节奏慢(有堆积),每当进入一个mu的时候就触发一次 method移动一个mu到machine。如果machine上正 ...

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

本版积分规则

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

GMT+8, 2025-9-17 08:18 , Processed in 0.023103 second(s), 13 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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