GenSVM
|
Header file for gensvm_timer.c. More...
#include "gensvm_globals.h"
Go to the source code of this file.
Macros | |
#define | Timer(spec) clock_gettime(CLOCK_MONOTONIC_RAW, &spec) |
Timer macro for easily recording time. More... | |
Functions | |
double | gensvm_elapsed_time (struct timespec *start, struct timespec *stop) |
Calculate the time between two time recordings. More... | |
Header file for gensvm_timer.c.
Function declaration for timer function used to measure computation time.
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.h.
#define Timer | ( | spec | ) | clock_gettime(CLOCK_MONOTONIC_RAW, &spec) |
Timer macro for easily recording time.
Definition at line 37 of file gensvm_timer.h.
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:
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.
[in] | start | starting time |
[in] | stop | end time |
Definition at line 58 of file gensvm_timer.c.