1 #ifndef SimTK_SimTKCOMMON_TIMING_H_
2 #define SimTK_SimTKCOMMON_TIMING_H_
64 #ifndef HAVE_STRUCT_TIMESPEC
65 #define HAVE_STRUCT_TIMESPEC 1
87 typedef unsigned int useconds_t;
88 inline int usleep(useconds_t us) {
90 req.tv_sec = (long) (us / 1000000U);
91 req.tv_nsec = (long)((us % 1000000U)*1000U);
92 int status = nanosleep(&req,0);
93 return status ? -1 : 0;
97 #if defined(_MSC_VER) || defined(__APPLE__)
99 typedef long clockid_t;
110 #define CLOCK_REALTIME 1 // time of day clock, from 1/1/1970
111 #define CLOCK_MONOTONIC 2 // counter from last boot time
112 #define CLOCK_MONOTONIC_HR 3 // "high resolution" (same)
113 #define CLOCK_MONOTONIC_RAW 4 // "not subject to NTP adjustments" (same)
114 #define CLOCK_THREAD_CPUTIME_ID 5 // current thread's cpu time (kernel+user)
115 #define CLOCK_PROCESS_CPUTIME_ID 6 // cumulative cpu time of all threads of
122 struct timespec *tp);
156 {
return (
long long)ts.tv_sec*1000000000LL + (
long long)ts.tv_nsec; }
161 { ts.tv_sec = (long)(ns / 1000000000LL);
162 if (ns >= 0) ts.tv_nsec = (long)( ns % 1000000000LL);
163 else ts.tv_nsec = -(long)((-ns) % 1000000000LL); }
199 clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &ts);
210 clock_gettime(CLOCK_THREAD_CPUTIME_ID, &ts);
244 #ifdef CLOCK_MONOTONIC_RAW
245 clock_gettime(CLOCK_MONOTONIC_RAW, &ts);
247 clock_gettime(CLOCK_MONOTONIC, &ts);
285 #endif // SimTK_SimTKCOMMON_TIMING_H_
#define SimTK_SimTKCOMMON_EXPORT
Definition: SimTKcommon/include/SimTKcommon/internal/common.h:202
long long secToNs(const double &s)
Given a signed time interval as a double precision floating point number of seconds, return the same time interval as a count of nanosecond ticks in a signed 64 bit integer.
Definition: Timing.h:174
This is the top-level SimTK namespace into which all SimTK names are placed to avoid collision with o...
Definition: Assembler.h:37
double cpuTime()
Return the cumulative CPU time in seconds (both kernel and user time) that has been used so far by an...
Definition: Timing.h:197
void nsToTimespec(const long long &ns, timespec &ts)
Given a signed number of nanoseconds, convert that into seconds and leftover nanoseconds in a timespe...
Definition: Timing.h:160
double realTime()
Return current time on the high-resolution interval timer in seconds.
Definition: Timing.h:259
void sleepInNs(const long long &ns)
Sleep for the indicated number of nanoseconds, with the actual precision system dependent but intende...
Definition: Timing.h:268
long long timespecToNs(const timespec &ts)
Convert a time stored in a timespec struct to the equivalent number of nanoseconds (as a signed quant...
Definition: Timing.h:155
High precision mathematical and physical constants.
void sleepInSec(const double &seconds)
Sleep for the indicated number of seconds, with the actual precision system dependent but intended to...
Definition: Timing.h:280
double nsToSec(const long long &ns)
Given a count of nanosecond ticks as a signed 64 bit integer, return the same time interval as a doub...
Definition: Timing.h:168
Mandatory first inclusion for any Simbody source or header file.
#define SimTK_NS_TO_S
Convert nanoseconds to seconds.
Definition: Constants.h:527
#define SimTK_S_TO_NS
Convert seconds to nanoseconds.
Definition: Constants.h:535
double threadCpuTime()
Return the total CPU time in seconds (both kernel and user time) that has been used so far by the cur...
Definition: Timing.h:208
long long realTimeInNs()
Return current time on the high-resolution interval timer in nanoseconds, as a 64-bit integer count...
Definition: Timing.h:242