#include #include #include #include "caffe2/core/timer.h" #include namespace caffe2 { namespace { TEST(TimerTest, Test) { Timer timer; // A timer auto-starts when it is constructed. std::this_thread::sleep_for(std::chrono::microseconds(1)); EXPECT_GT(timer.NanoSeconds(), 0); // Sleep for a while, and get the time. timer.Start(); std::this_thread::sleep_for(std::chrono::milliseconds(100)); float ns = timer.NanoSeconds(); float us = timer.MicroSeconds(); float ms = timer.MilliSeconds(); // Time should be at least accurate +- 10%. (30% on Windows) #ifndef _WIN32 EXPECT_NEAR(ns, 100000000, 10000000); EXPECT_NEAR(us, 100000, 10000); EXPECT_NEAR(ms, 100, 10); #else EXPECT_NEAR(ns, 100000000, 30000000); EXPECT_NEAR(us, 100000, 30000); EXPECT_NEAR(ms, 100, 30); #endif // Test restarting the clock. timer.Start(); EXPECT_LT(timer.MicroSeconds(), 1000); } TEST(TimerTest, TestLatency) { constexpr int iter = 1000; float latency = 0; Timer timer; for (int i = 0; i < iter; ++i) { timer.Start(); latency += timer.NanoSeconds(); } std::cout << "Average nanosecond latency is: " << latency / iter << std::endl; latency = 0; for (int i = 0; i < iter; ++i) { timer.Start(); latency += timer.MicroSeconds(); } std::cout << "Average microsecond latency is: " << latency / iter << std::endl; latency = 0; for (int i = 0; i < iter; ++i) { timer.Start(); latency += timer.MilliSeconds(); } std::cout << "Average millisecond latency is: " << latency / iter << std::endl; } } // namespace } // namespace caffe2