Разница во времени возвращает отрицательное число - PullRequest
1 голос
/ 09 июля 2010

У меня есть этот код пробного таймера для решения euler в Ruby.

$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 ]

2 голосов
/ 09 июля 2010

usec возвращает микросекунды с того же времени, что и month возвращает месяц.Это не число микросекунд для данного времени с начала эпохи.

Так что, если start_t было 1049896564.259970 секунд, а end_t было 1049896592.123130 секунд, то вы бы получили 123130 - 259970, если вы вычли бы юсек.то есть отрицательное число.

Вместо этого вы можете использовать Time.now.to_f для преобразования в число с плавающей запятой с начала эпохи и вычитать их друг от друга.Вы также можете просто вычесть один Time объект из другого напрямую, например

start_t = Time.now
solve.call
end_t = Time.now
times << end_t - start_t
0 голосов
/ 09 июля 2010

Текущее время в секундах с начала эпохи:

Time.now.to_f
=> 1278631398.143

Это должно иметь микросекундное разрешение, несмотря на то, что здесь показаны только три десятичных знака.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...