1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
#include "zfpTimer.h"
#include <stdlib.h>
struct zfp_timer {
#if defined(__unix__) || defined(_WIN32)
clock_t timeStart, timeEnd;
#elif defined(__MACH__)
uint64_t timeStart, timeEnd;
#endif
};
zfp_timer*
zfp_timer_alloc()
{
return malloc(sizeof(zfp_timer));
}
void
zfp_timer_free(zfp_timer* timer) {
free(timer);
}
int
zfp_timer_start(zfp_timer* timer)
{
#if defined(__unix__) || defined(_WIN32)
timer->timeStart = clock();
#elif defined(__MACH__)
timer->timeStart = mach_absolute_time();
#else
return 1;
#endif
return 0;
}
double
zfp_timer_stop(zfp_timer* timer)
{
double time;
// stop timer, compute elapsed time
#if defined(__unix__) || defined(_WIN32)
timer->timeEnd = clock();
time = (double)((timer->timeEnd) - (timer->timeStart)) / CLOCKS_PER_SEC;
#elif defined(__MACH__)
timer->timeEnd = mach_absolute_time();
mach_timebase_info_data_t tb = {0};
mach_timebase_info(&tb);
double timebase = tb.numer / tb.denom;
time = ((timer->timeEnd) - (timer->timeStart)) * timebase * (1E-9);
#endif
return time;
}
|