设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 18013|回复: 16

[求助] 请问那位高手知道时间同步怎么解决

[复制链接]
发表于 2008-7-29 17:52:22 | 显示全部楼层 |阅读模式
5仿真币
通过singleProc里的控制输入和输出,我调用了时间采集程序,就是说,当物件要进入singleproc时,就把时钟上的时间赋给变量n, 当从singleproc输出时把时钟时间赋给变量m, 用m-n这样就可得出物件在singleproc里的时间,即singleprocd的工作时间。但从机器上采集的生产时间总是比时钟控制器的时间慢,所以计算的数值不准确,那位高手帮帮忙。我需要用Trigger没隔一个小时计算一次Singleproc的效率,可当trigger 在14:00(时钟时间)调用程序时,我的m和n都还是13:54 和13:45,m-n的结果是属于13到14点的一个小时,而由于mn比时钟慢,m-n的结果就被归入到14点到15点里了。如何才能让采集的singleproc的时间和控制器的时间同步。
2 [6 F8 c. Y+ `请那位高手帮帮忙,0 }- l3 c  p+ A$ f+ I6 j

# D/ |% K  c6 r[ 本帖最后由 eriven 于 2008-7-29 18:19 编辑 ]

发表于 2008-7-29 23:23:16 | 显示全部楼层
你的问题没有你描述的那么复杂吧。。。/ G5 @% }+ r6 K+ S$ ~7 U
你说了半天其实就是想说,因为整点时刻没有触发统计,所以导致singleproc效率统计不准确嘛。。。。。3 ]* L7 ]4 K( ]/ j2 m
你自己不是已经知道解决方法了么,在整点时刻加入一个统计点: [8 e# ?9 b, }- `0 e( {
在模型启动时触发一个method:6 @* e) q. J$ o
for 1 = 1 loop) \  {' K0 _- d3 ^  i% d
wait 3600;- M: v9 `& {  |  e' s
m:=ac;
7 ~) `0 }( ~! w, g5 q$ Q! ctable[,]:=table[,]:+m-n;(table记录数据)" l( G7 K- h* e, A& q
n:=ac;
# v; w! M, O) e$ O, \2 z8 p/ S具体格式自己调试一下就行了。/ q( |5 b3 X( B, q2 V
# U# C* D, H+ p, J
[ 本帖最后由 kaly 于 2008-7-30 09:15 编辑 ]
 楼主| 发表于 2008-7-30 04:48:07 | 显示全部楼层
多谢,我程序! b8 T& o" x# _" V6 ?5 ?. W5 ]" ]
Methode1 Trigger调用 Trigger定义1小时出发一次
' y7 ]/ o2 U' Y, D$ F(old, new : boolean )' _% Z4 Q% ~+ M4 ]" z
is* [/ x8 _6 }, ~0 N: s
do
3 h, V. H  V/ x) Z7 N! D if new = true then       
5 E: E1 A) Y, X9 @1 L                Tabelle1[1,1]:= time_to_num(y)/3600;
6 S4 ^1 ?& B; P+ `                m:= 0;
8 ^. u  T% R  G" @                n:=0;
4 T2 o$ W4 q! O1 G( r. ]5 \8 N                y:=0;
7 o1 O' T" A( _         end;
# Z# t1 i, n* e4 W- e- }         end;   
1 [. J( N& D7 M0 E. wmethode2 Singleproc 输入控制调用5 d9 m; ?, Y6 `2 G# S
is
; A: b" k, J8 U3 Tdo
5 Y7 K! n/ ~8 e+ y. C        n:=Ereignisverwalter.zeit;
- C; M: ?5 u; [7 R9 Wend;
  g6 z% l/ z3 P$ W, \methode3 singleproc输出控制调用! `6 j+ m% U: S8 c
is
6 J% `3 f# B' Wdo9 o- o; w0 W% ]! S4 h! i
        m:= Ereignisverwalter.zeit;8 z. }# W( N% f8 }+ N7 F1 u. p
        if m/=0 then . K0 m% ]" w' I7 a* S. K: U' u
                y:=y+(m-n);
' [/ L# X/ c) `  y! G+ R* [! F        end;
  V8 Q* |2 I* h3 _: `       
/ D# _% c8 `+ O; m& Lend;0 o" P& W9 `: E: P' ?
m为物件从singleproc输出时的时钟试点,n为物件输入到singleproc是的时钟试点。m-n为singleproc的工作时间,$ K6 T/ h7 r& w3 t
m-n的值赋给y一直累加知道trigger调用将y除以3600秒得出效率,之后y赋0值,这是我的思路。
& b" y& _% Z2 X7 Z可是有时m-n超出3600秒,我查了一下,程序好像先记录m后记录n,当机器休息完m记录的是机器休息后的时点,而n还停留在休息前,这样计算y:=y+(m-n)之后结果就比正常的大,会超出3600,出现效率108%。
/ x7 K1 T8 U9 Z: F7 \请问如何解决这个问题
发表于 2008-7-30 12:33:45 | 显示全部楼层
这种原因我感觉应该是由于emplant系统在处理时间时是跳跃性的,按照事件发生与否来判断时间是否推进有关系。你试试把eventcontroller的real time勾选,让仿真控制器按照真实时间流逝方式运行再试试?
 楼主| 发表于 2008-7-30 20:08:37 | 显示全部楼层
我勾了,可是系统运行的很慢,要等很长时间。
发表于 2008-8-13 10:00:16 | 显示全部楼层
程序好像先记录m后记录n,当机器休息完m记录的是机器休息后的时点?????
1 u- I. u8 @% l' w是不是你的整点记录时把m,n都化为0了,可这个时候工位上还有零件在加工?当零件流出时记录m了,然后才记录n??那你就要修改一下Trigger调用的程序
 楼主| 发表于 2008-8-14 16:42:56 | 显示全部楼层
是的就是这个问题,可是怎么解决呢?我要求每小时的工作效率,所以trigger每隔1个小时调用一次,我应该怎么改呢?3 T1 ~) y2 A$ k0 u
还有请教,伽马分布 z_gamma(s, alpha,Beta)里的s 怎么确定是什么,我的机器每个部件工作时间是由gamma分布确定的,已知 σ 和μ,通过σ*σ=αβ*β 和  μ=αβ 我求出α和β,但把求出的αβ代入伽玛分布的公式总感觉不太对,比如,μ=8:30 σ=4:00 算出的α=4,515625  β= 112.94117647055...代入后运行得出的工作时间有的相差很远,有时1分多种,又是25分。这是怎么回事,是不是s定的不对。
发表于 2008-8-14 18:15:13 | 显示全部楼层
s指stream;关于m和n的问题这个就要看你是怎么定的。既然没有加工完,那么剩下的时间计算为下一个小时的?还是等加工完计算到这个小时?那就不要把m、n归为0而是判断工位上是否有零件(if singproc.nummu=0 then),根据你的需要定义m、n的值。
发表于 2008-8-14 21:46:55 | 显示全部楼层
 楼主| 发表于 2008-8-17 14:25:58 | 显示全部楼层
我试试看,谢谢,我想问问s如何定值,这个值的大小,对我用gamma分布所计算出来的结果有什么影响?
 楼主| 发表于 2008-8-17 14:35:53 | 显示全部楼层
还有如果mn归0是为了确定一个小时内的加工时间,不归0的话程序怎么实现计算一个小时内的加工时间呢? 如果等加工完计算到这个小时或剩下的时间计算为下一个小时的,会不会影响我计算出的工作效率的精确度,因为工作效率是3600秒一计的。
发表于 2008-8-19 12:47:37 | 显示全部楼层
The integer s identifies the random number stream. alpha (real) and beta (real) are the arguments of the gamma distribution. mn的取值是你运行的原则,这个要你自己定义,要是在做plant前原则都没有就没有办法建立数学模型。
 楼主| 发表于 2008-8-19 18:19:23 | 显示全部楼层
什么是随机数流,能详细解释一下吗,对我用gamma分布所计算出来的结果有什么影响?我是个初学者,谢谢
发表于 2008-8-20 02:08:05 | 显示全部楼层
S为用来计算伽玛分布的数值,Alpha是γ分布参数,Betaγ分布的一个参数。如果beta=1,gamma distribution函数返回标准伽玛分布,希望好好学习数学,这种问题属于数学基础。
 楼主| 发表于 2008-8-26 03:37:06 | 显示全部楼层
我只是s不理解,为什么gamma(2,1000,27)和gamma(64,1000,27)的结果不一样?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-11-23 06:23 , Processed in 0.018927 second(s), 11 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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