#ifndef CAFFE2_CORE_TIMER_H_ #define CAFFE2_CORE_TIMER_H_ #include #include "caffe2/core/common.h" namespace caffe2 { /** * @brief A simple timer object for measuring time. * * This is a minimal class around a std::chrono::high_resolution_clock that * serves as a utility class for testing code. */ class Timer { public: typedef std::chrono::high_resolution_clock clock; typedef std::chrono::nanoseconds ns; Timer() { Start(); } /** * @brief Starts a timer. */ inline void Start() { start_time_ = clock::now(); } inline float NanoSeconds() { return static_cast( std::chrono::duration_cast(clock::now() - start_time_).count()); } /** * @brief Returns the elapsed time in milliseconds. */ inline float MilliSeconds() { return NanoSeconds() / 1000000.f; } /** * @brief Returns the elapsed time in microseconds. */ inline float MicroSeconds() { return NanoSeconds() / 1000.f; } /** * @brief Returns the elapsed time in seconds. */ inline float Seconds() { return NanoSeconds() / 1000000000.f; } protected: std::chrono::time_point start_time_; C10_DISABLE_COPY_AND_ASSIGN(Timer); }; } #endif // CAFFE2_CORE_TIMER_H_