13 #include "DeviceUtils.h"
14 #include "../../FaissAssert.h"
16 namespace faiss {
namespace gpu {
23 CUDA_VERIFY(cudaEventCreate(&startEvent_));
24 CUDA_VERIFY(cudaEventCreate(&stopEvent_));
26 CUDA_VERIFY(cudaEventRecord(startEvent_, stream_));
30 CUDA_VERIFY(cudaEventDestroy(startEvent_));
31 CUDA_VERIFY(cudaEventDestroy(stopEvent_));
38 CUDA_VERIFY(cudaEventRecord(stopEvent_, stream_));
39 CUDA_VERIFY(cudaEventSynchronize(stopEvent_));
42 CUDA_VERIFY(cudaEventElapsedTime(&time, startEvent_, stopEvent_));
49 clock_gettime(CLOCK_REALTIME, &start_);
55 clock_gettime(CLOCK_REALTIME, &end);
57 auto diffS = end.tv_sec - start_.tv_sec;
58 auto diffNs = end.tv_nsec - start_.tv_nsec;
60 return 1000.0f * (float) diffS + ((
float) diffNs) / 1000000.0f;
float elapsedMilliseconds()
Returns elapsed time in milliseconds.
KernelTimer(cudaStream_t stream=0)
CpuTimer()
Creates and starts a new timer.
float elapsedMilliseconds()
~KernelTimer()
Destructor releases event resources.