2010-07-08 60 views
1

我有这个试用计时器代码在Ruby的时间euler解决方案。在时间上的差异是返回一个负数

$RUNS = 12 
def run(solve) 
    times = [] 
    $RUNS.times do 
    start_t = Time.now.usec 
    solve.call 
    end_t = Time.now.usec 
    times << (end_t - start_t)/1000.0 
    end 
    #times = times.delete_if {|i| i < 0} 
    puts times.inspect 
    times.sort 

    mean = times.inject{|a,c| a+c}/$RUNS 
    puts("Mean:\t#{mean}"); 
    if (times.length % 2 == 0) then 
    median = (times[times.length/2 - 1] + times[times.length/2])/2.0 
    else 
    median = times[times.length/2]; 
    end 
    puts("Median: #{median}"); 

end 

不幸的是,我一直得到的答案是这样的:

[409.805, 418.16, -582.23, 402.223, -581.94, 413.196, 426.816, -584.732, 519.457, -569.557, 558.918, -579.176] 

我能做些什么来避免这些奇怪的负数?

回答

2

usec返回的时间与微秒相同为month返回的月份。它不是自纪元以来的特定时间的微秒数。

因此,如果start_t为1049896564.259970秒,end_t为1049896592.123130秒,那么如果您扣除了usecs,则将得到123130 - 259970。即负数。

相反,您可以使用Time.now.to_f转换为自时代以来的浮点数秒,并将它们相减。您也可以直接减去另一个Time对象。

start_t = Time.now 
solve.call 
end_t = Time.now 
times << end_t - start_t 
+0

那么我该如何在Ruby中进行高粒度时序? – 2010-07-08 23:19:18

+0

@Jbrristow答案更新了如何做你想要的建议。 – mikej 2010-07-08 23:25:16

+0

这似乎是要求浮点错误,但我乘以1000以获得毫秒粒度。 – 2010-07-09 00:00:40

0

在自纪元秒当前时间:

Time.now.to_f 
=> 1278631398.143 

这应该有微秒的分辨率,虽然只有三位小数正在这里显示。