GenSVM
Functions
gensvm_timer.c File Reference

Utility functions relating to time. More...

#include "gensvm_timer.h"
Include dependency graph for gensvm_timer.c:

Go to the source code of this file.

Functions

double gensvm_elapsed_time (struct timespec *start, struct timespec *stop)
 Calculate the time between two time recordings. More...
 

Detailed Description

Utility functions relating to time.

Author
G.J.J. van den Burg
Date
2014-01-07

This file contains a simple function for calculating the time in seconds elapsed between two Timer() calls.

This file is part of GenSVM.

GenSVM is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

GenSVM is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with GenSVM. If not, see http://www.gnu.org/licenses/.

Definition in file gensvm_timer.c.

Function Documentation

◆ gensvm_elapsed_time()

double gensvm_elapsed_time ( struct timespec *  start,
struct timespec *  stop 
)

Calculate the time between two time recordings.

This function should be used with time recordings done by clock_gettime() using CLOCK_MONOTONIC_RAW. For this, the Timer() macro has been defined in the header file. Example usage:

struct timespec start, stop;
Timer(start);
// do some work //
Timer(stop);
double duration = gensvm_elapsed_time(&start, &stop);

This approach to measuring time has been chosen since CLOCK_MONOTONIC_RAW is guaranteed to be monotonically increasing, and is not affected by leap seconds or other changes to the system clock. It is therefore thread-safe and can be used to accurately measure time intervals.

Parameters
[in]startstarting time
[in]stopend time
Returns
time elapsed in seconds

Definition at line 58 of file gensvm_timer.c.