Subversion Repositories Games.Chess Giants

Rev

Blame | Last modification | View Log | Download | RSS feed

  1. /*
  2.     Texel - A UCI chess engine.
  3.     Copyright (C) 2013-2014  Peter Ă–sterlund, peterosterlund2@gmail.com
  4.  
  5.     This program is free software: you can redistribute it and/or modify
  6.     it under the terms of the GNU General Public License as published by
  7.     the Free Software Foundation, either version 3 of the License, or
  8.     (at your option) any later version.
  9.  
  10.     This program is distributed in the hope that it will be useful,
  11.     but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  13.     GNU General Public License for more details.
  14.  
  15.     You should have received a copy of the GNU General Public License
  16.     along with this program.  If not, see <http://www.gnu.org/licenses/>.
  17. */
  18.  
  19. /*
  20.  * timeUtil.cpp
  21.  *
  22.  *  Created on: Sep 20, 2013
  23.  *      Author: petero
  24.  */
  25.  
  26. #include "timeUtil.hpp"
  27.  
  28. #include <chrono>
  29. #include <iostream>
  30.  
  31. #ifdef HAS_RT
  32. #include <time.h>
  33. #include <sys/time.h>
  34. #endif
  35.  
  36. S64 currentTimeMillis() {
  37. #ifdef HAS_RT
  38.     clockid_t c = CLOCK_MONOTONIC;
  39.     timespec sp;
  40.     clock_gettime(c, &sp);
  41.     return (S64)(sp.tv_sec * 1e3 + sp.tv_nsec * 1e-6);
  42. #else
  43.     auto t = std::chrono::high_resolution_clock::now();
  44.     auto t0 = t.time_since_epoch();
  45.     auto x = t0.count();
  46.     using T0Type = decltype(t0);
  47.     auto n = T0Type::period::num;
  48.     auto d = T0Type::period::den;
  49.     return (S64)(x * (1000.0 * n / d));
  50. #endif
  51. }
  52.  
  53. double currentTime() {
  54. #ifdef HAS_RT
  55.     clockid_t c = CLOCK_MONOTONIC;
  56.     timespec sp;
  57.     clock_gettime(c, &sp);
  58.     return sp.tv_sec + sp.tv_nsec * 1e-9;
  59. #else
  60.     auto t = std::chrono::high_resolution_clock::now();
  61.     auto t0 = t.time_since_epoch();
  62.     double x = (double)t0.count(); // Pierre-Marie Baty -- added type cast
  63.     using T0Type = decltype(t0);
  64.     double n = T0Type::period::num;
  65.     double d = T0Type::period::den;
  66.     return x * n / d;
  67. #endif
  68. }
  69.  
  70. SampleStatistics&
  71. SampleStatistics::operator+=(const SampleStatistics& other) {
  72.     nSamples += other.nSamples;
  73.     sum += other.sum;
  74.     sqSum += other.sqSum;
  75.     return *this;
  76. }
  77.