You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
73 lines
1.4 KiB
73 lines
1.4 KiB
3 years ago
|
#include <algorithm> // max, min
|
||
|
#include <chrono> // high_resolution_clock seconds, milliseconds, microseconds, nanoseconds
|
||
|
#include <cstdint> // uint64_t
|
||
|
|
||
|
#include "util/timer.h"
|
||
|
|
||
|
namespace Util {
|
||
|
|
||
|
Timer::Timer()
|
||
|
{
|
||
|
m_start = std::chrono::high_resolution_clock::now();
|
||
|
}
|
||
|
|
||
|
Timer Timer::operator-(const Timer& timer)
|
||
|
{
|
||
|
return Timer(TimePoint { m_start - timer.start() });
|
||
|
}
|
||
|
|
||
|
template<typename To, typename From>
|
||
|
To Timer::to(From from)
|
||
|
{
|
||
|
return std::chrono::duration_cast<To>(from);
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::toSeconds()
|
||
|
{
|
||
|
return to<std::chrono::seconds>(m_start.time_since_epoch()).count();
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::toMilliseconds()
|
||
|
{
|
||
|
return to<std::chrono::milliseconds>(m_start.time_since_epoch()).count();
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::toMicroseconds()
|
||
|
{
|
||
|
return to<std::chrono::microseconds>(m_start.time_since_epoch()).count();
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::toNaneseconds()
|
||
|
{
|
||
|
return to<std::chrono::nanoseconds>(m_start.time_since_epoch()).count();
|
||
|
}
|
||
|
|
||
|
template<typename T>
|
||
|
uint64_t Timer::elapsed()
|
||
|
{
|
||
|
auto now = std::chrono::high_resolution_clock::now();
|
||
|
return std::chrono::duration_cast<T>(now - m_start).count();
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::elapsedSeconds()
|
||
|
{
|
||
|
return elapsed<std::chrono::seconds>();
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::elapsedMilliseconds()
|
||
|
{
|
||
|
return elapsed<std::chrono::milliseconds>();
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::elapsedMicroseconds()
|
||
|
{
|
||
|
return elapsed<std::chrono::microseconds>();
|
||
|
}
|
||
|
|
||
|
uint64_t Timer::elapsedNanoseconds()
|
||
|
{
|
||
|
return elapsed<std::chrono::nanoseconds>();
|
||
|
}
|
||
|
|
||
|
} // namespace Util
|