37double get_curr_time<double, CLOCK_REALTIME>( timespec &tsp )
39 clock_gettime( CLOCK_REALTIME, &tsp );
41 return ( (
double)tsp.tv_sec ) + ( (double)tsp.tv_nsec ) / 1e9;
45double get_curr_time<double, CLOCK_REALTIME>()
48 return get_curr_time<double, CLOCK_REALTIME>( tsp );
53 std::this_thread::sleep_for( std::chrono::seconds( sec ) );
58 std::this_thread::sleep_for( std::chrono::milliseconds( msec ) );
63 std::this_thread::sleep_for( std::chrono::microseconds( usec ) );
68 std::this_thread::sleep_for( std::chrono::nanoseconds( nsec ) );
73 ts.tv_nsec += nsec % 1000000000;
74 ts.tv_sec += nsec / 1000000000;
76 if( ts.tv_nsec > 999999999 )
78 ts.tv_nsec -= 1000000000;
83double Cal2mjd(
int yr,
int mon,
int day,
int hr,
int min,
double sec )
88 int rv = sofa::iauCal2jd( yr, mon, day, &djm0, &djm );
93 djm0 = djm + ( ( (double)hr ) / ( 24.0 ) + ( (
double)min ) / ( 60.0 * 24.0 ) + sec / ( 3600.0 * 24.0 ) );
98int ISO8601dateBreakdown(
int &yr,
int &mon,
int &day,
int &hr,
int &min,
double &sec,
const std::string &fdate )
100 if( fdate.length() < 19 )
103 yr = atoi( fdate.substr( 0, 4 ).c_str() );
104 mon = atoi( fdate.substr( 5, 2 ).c_str() );
105 day = atoi( fdate.substr( 8, 2 ).c_str() );
108 parse_hms( _hr, _min, sec, fdate.substr( 11 ) );
118 if( fdate.length() < 19 )
121 int yr, mon, day, hr, min;
127 return Cal2mjd( yr, mon, day, hr, min, sec );
134 gmtime_r( &timeIn, &bdt );
138 strftime( tstr, 25,
"%FT%H:%M:%S", &bdt );
140 std::string result = tstr;
157 snprintf( tstr, 20,
".%09ld", timeIn.tv_nsec );
179 sofa::iauJd2cal( DJM0, timeIn, &iy, &im, &
id, &fd );
183 hr = floor( fd * 24.0 );
184 fd = ( fd - hr / 24.0 ) * 24.0;
186 mn = floor( fd * 60. );
188 fd = ( fd - mn / 60.0 ) * 3600.0;
192 snprintf( tstr, 32,
"%04d-%02d-%02dT%02d:%02d:%012.9f", iy, im,
id, hr, mn, fd );
194 std::string result = tstr;
208 time_t t0 = ts.tv_sec;
210 if( gmtime_r( &t0, &uttime ) == 0 )
212 std::cerr <<
"Error getting UT time (gmtime_r returned 0). At: " << __FILE__ <<
" " << __LINE__ <<
"\n";
220 "%04i%02i%02i%02i%02i%02i%09i",
221 uttime.tm_year + 1900,
227 static_cast<int>( ts.tv_nsec ) );
241 tmrv = gmtime_r( &tsp.tv_sec, tm0 );
246 rv1 = sofa::iauDat( 1900 + tm0->tm_year, 1 + tm0->tm_mon, tm0->tm_mday, 0.0, &dat );
251 rv2 = sofa::iauCal2jd( 1900 + tm0->tm_year, 1 + tm0->tm_mon, tm0->tm_mday, &djm0, &djm );
256 djmf = ( (double)tm0->tm_hour ) / 24.0 + ( (double)tm0->tm_min ) / ( 24.0 * 60. ) +
257 ( ( (
double)tm0->tm_sec ) + ( (
double)tsp.tv_nsec / 1e9 ) + dat ) / ( 24.0 * 3600.0 );
272 double means = ( ts1.tv_sec + ts2.tv_sec ) / 2.0;
273 double meanns = ( ts1.tv_nsec + ts2.tv_nsec ) / 2.0;
275 ts1.tv_sec = floor( means );
276 ts1.tv_nsec = round( meanns );
278 if( means != floor( means ) )
282 if( ts1.tv_nsec >= 1e9 )
295bool operator<( timespec
const &tsL, timespec
const &tsR )
297 return ( ( ( tsL.tv_sec == tsR.tv_sec ) && ( tsL.tv_nsec < tsR.tv_nsec ) ) || ( tsL.tv_sec < tsR.tv_sec ) );
300bool operator>( timespec
const &tsL, timespec
const &tsR )
302 return ( ( ( tsL.tv_sec == tsR.tv_sec ) && ( tsL.tv_nsec > tsR.tv_nsec ) ) || ( tsL.tv_sec > tsR.tv_sec ) );
307 return ( ( tsL.tv_sec == tsR.tv_sec ) && ( tsL.tv_nsec == tsR.tv_nsec ) );
312 return ( tsL < tsR || tsL == tsR );
317 return ( tsL > tsR || tsL == tsR );
void nanoSleep(unsigned nsec)
Sleep for a specified period in nanoseconds.
void sleep(unsigned sec)
Sleep for a specified period in seconds.
void milliSleep(unsigned msec)
Sleep for a specified period in milliseconds.
void microSleep(unsigned usec)
Sleep for a specified period in microseconds.
bool operator<(timespec const &tsL, timespec const &tsR)
Timespec comparison operator < (see caveats)
bool operator==(timespec const &tsL, timespec const &tsR)
Timespec comparison operator == (see caveats)
bool operator>(timespec const &tsL, timespec const &tsR)
Timespec comparison operator > (see caveats)
bool operator>=(timespec const &tsL, timespec const &tsR)
Timespec comparison operator >= (see caveats)
bool operator<=(timespec const &tsL, timespec const &tsR)
Timespec comparison operator <= (see caveats)
int ISO8601dateBreakdown(int &yr, int &mon, int &day, int &hr, int &min, double &sec, const std::string &fdate)
Parse an ISO8601 date of the form "YYYY-MM-DDTHH:MM:SS.S" into the individual components.
std::string ISO8601DateTimeStr(const timeT &timeIn, int timeZone=0)
Get a date-time string in ISO 8601 format.
std::string ISO8601DateTimeStrMJD(const double &timeIn, int timeZone=0)
Get a date-time string in ISO 8601 format for an MJD.
int timespecUTC2TAIMJD(double &djm, double &djmf, const timespec &tsp, tm *tm0)
Convert a UTC timespec to TAI modified Julian date.
std::string ISO8601DateTimeStr< timespec >(const timespec &timeIn, int timeZone)
Get a date-time string in ISO 8601 format for timespec.
void timespecAddNsec(timespec &ts, unsigned nsec)
Adds a time offset to an existing timespec.
void parse_hms(floatT &h, floatT &m, floatT &s, const std::string &hmsstr)
int timeStamp(std::string &tstamp, timespec &ts)
Get a timestamp string in the form YYYYMMDDHHMMSS.SSSSSSSSS.
double Cal2mjd(int yr, int mon, int day, int hr, int min, double sec)
Converts a Gregorian calendar date into modified Julian date (MJD).
double ISO8601date2mjd(const std::string &fdate)
Parse an ISO8601 date of the form "YYYY-MM-DDTHH:MM:SS.S" and return the modified Julian date (MJD)
std::string ISO8601DateTimeStr< time_t >(const time_t &timeIn, int timeZone)
Get a date-time string in ISO 8601 format for time_t.
Utilities for working with time.
timespec meanTimespec(timespec ts1, timespec ts2)
Calculate the mean time of two times given by timespecs.