设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 20693|回复: 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的时间和控制器的时间同步。
  I1 T, u7 V9 y) @* o" v请那位高手帮帮忙,) R7 t# V! F- C5 c7 t0 D. c, s

$ N( a* {, a1 q4 a0 ][ 本帖最后由 eriven 于 2008-7-29 18:19 编辑 ]

发表于 2008-7-29 23:23:16 | 显示全部楼层
你的问题没有你描述的那么复杂吧。。。* \) m% U4 j; [- k8 I" Z! t
你说了半天其实就是想说,因为整点时刻没有触发统计,所以导致singleproc效率统计不准确嘛。。。。。
& c* u8 M4 c* F4 r你自己不是已经知道解决方法了么,在整点时刻加入一个统计点% X6 p' ]$ s. [. L2 p5 F8 v( \
在模型启动时触发一个method:
/ d, |; P/ M5 V5 [) ~* Wfor 1 = 1 loop
+ s. N: \$ y! F4 o% Ywait 3600;
! M/ Y7 [* k2 R. h: Tm:=ac;
' u' z  T) _" x5 c( Ntable[,]:=table[,]:+m-n;(table记录数据)9 w+ m- @# ?# @! X3 `4 @
n:=ac;
* V" a% j+ K. a  z4 k# e具体格式自己调试一下就行了。
+ V3 p* B$ x0 K) I# T0 ?. q# P: `7 ?0 q
[ 本帖最后由 kaly 于 2008-7-30 09:15 编辑 ]
 楼主| 发表于 2008-7-30 04:48:07 | 显示全部楼层
多谢,我程序; N7 P1 Q! k( }
Methode1 Trigger调用 Trigger定义1小时出发一次
: V) c3 ]8 V7 x% c(old, new : boolean )
1 G  P- I& S. \, ~4 Iis. v  K- }& p7 `# U
do
3 J* J4 L( G0 t) V% ~ if new = true then        & z8 \+ Q1 O, A+ ?( s* k
                Tabelle1[1,1]:= time_to_num(y)/3600;
0 l& z, ?8 b' K  r8 G- ?, r  h                m:= 0;% I2 n! i( L. o4 U3 ?
                n:=0;& q6 b; F1 p) j: g3 f9 u) K
                y:=0;
0 A' e# Y/ c4 G5 i         end;* z3 E% a% E9 g' |( `* x
         end;   
8 p, T2 v, g2 b) a% z) j& r3 Q) \methode2 Singleproc 输入控制调用. d* H! u, k/ k/ I! U1 p2 ]
is/ ~) f( w2 H3 j4 E7 v
do3 x5 b1 n  M* Y
        n:=Ereignisverwalter.zeit;
& V+ [1 Z8 Y; Kend;& f3 J5 X, e/ v. Z, [: @  d
methode3 singleproc输出控制调用
2 O- V( B2 E2 |7 S6 `% w* X& wis
0 d. z8 c8 I# ndo+ m0 Z# l! s1 e
        m:= Ereignisverwalter.zeit;
! h9 g* Y4 c) X3 i# M, N        if m/=0 then
) z6 d* ~' E6 I+ x. Z  ]                y:=y+(m-n);* @2 z0 Q5 o* j# ~# v0 p
        end;- q; G/ K; I4 ?- |1 C  y" a3 o
       
# B4 l4 p7 X4 u" V) gend;
$ [# x/ H; [" ym为物件从singleproc输出时的时钟试点,n为物件输入到singleproc是的时钟试点。m-n为singleproc的工作时间,4 z; A: }5 K7 r0 S& C
m-n的值赋给y一直累加知道trigger调用将y除以3600秒得出效率,之后y赋0值,这是我的思路。
2 c% z: n' r  N可是有时m-n超出3600秒,我查了一下,程序好像先记录m后记录n,当机器休息完m记录的是机器休息后的时点,而n还停留在休息前,这样计算y:=y+(m-n)之后结果就比正常的大,会超出3600,出现效率108%。
, j, k" s* {& z5 v# m请问如何解决这个问题
发表于 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记录的是机器休息后的时点?????
. ?9 ~6 x3 Z! V是不是你的整点记录时把m,n都化为0了,可这个时候工位上还有零件在加工?当零件流出时记录m了,然后才记录n??那你就要修改一下Trigger调用的程序
 楼主| 发表于 2008-8-14 16:42:56 | 显示全部楼层
是的就是这个问题,可是怎么解决呢?我要求每小时的工作效率,所以trigger每隔1个小时调用一次,我应该怎么改呢?
# F' ?$ I; ^1 D还有请教,伽马分布 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, 2026-5-5 13:39 , Processed in 0.015085 second(s), 11 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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