You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdeedu/kstars/kstars/kstarsdatetime.cpp

167 lines
5.5 KiB

/***************************************************************************
kstarsdatetime.cpp - Trinity Desktop Planetarium
-------------------
begin : Tue 05 May 2004
copyright : (C) 2004 by Jason Harris
email : jharris@30doradus.org
***************************************************************************/
/***************************************************************************
* *
* This program 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 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#include <kdebug.h>
#include "kstarsdatetime.h"
#include "ksnumbers.h"
#include "dms.h"
KStarsDateTime::KStarsDateTime() : ExtDateTime() {
setDJD( J2000 );
}
KStarsDateTime::KStarsDateTime( long int _jd ) : ExtDateTime(){
setDJD( (long double)( _jd ) );
}
KStarsDateTime::KStarsDateTime( const KStarsDateTime &kdt ) : ExtDateTime() {
setDJD( kdt.djd() );
}
KStarsDateTime::KStarsDateTime( const ExtDateTime &edt ) : ExtDateTime( edt ) {
//don't call setDJD() because we don't need to compute the time; just set DJD directly
TQTime _t = edt.time();
ExtDate _d = edt.date();
long double jdFrac = ( _t.hour()-12 + ( _t.minute() + ( _t.second() + _t.msec()/1000.)/60.)/60.)/24.;
DJD = (long double)( _d.jd() ) + jdFrac;
}
KStarsDateTime::KStarsDateTime( const ExtDate &_d, const TQTime &_t ) : ExtDateTime( _d, _t ) {
//don't call setDJD() because we don't need to compute the time; just set DJD directly
long double jdFrac = ( _t.hour()-12 + ( _t.minute() + ( _t.second() + _t.msec()/1000.)/60.)/60.)/24.;
DJD = (long double)( _d.jd() ) + jdFrac;
}
KStarsDateTime::KStarsDateTime( double _jd ) : ExtDateTime() {
setDJD( (long double)_jd );
}
KStarsDateTime::KStarsDateTime( long double _jd ) : ExtDateTime() {
setDJD( _jd );
}
KStarsDateTime KStarsDateTime::currentDateTime() {
KStarsDateTime dt( ExtDate::currentDate(), TQTime::currentTime() );
if ( dt.time().hour()==0 && dt.time().minute()==0 ) // midnight or right after?
dt.setDate( ExtDate::currentDate() ); // fetch date again
return dt;
}
void KStarsDateTime::setDJD( long double _jd ) {
DJD = _jd;
ExtDate dd;
dd.setJD( (long int)( _jd + 0.5 ) );
ExtDateTime::setDate( dd );
double dayfrac = _jd - (double)( date().jd() ) + 0.5;
if ( dayfrac > 1.0 ) dayfrac -= 1.0;
double hour = 24.*dayfrac;
int h = int(hour);
int m = int( 60.*(hour - h) );
int s = int( 60.*(60.*(hour - h) - m) );
int ms = int( 1000.*(60.*(60.*(hour - h) - m) - s) );
ExtDateTime::setTime( TQTime( h, m, s, ms ) );
}
void KStarsDateTime::setDate( const ExtDate &_d ) {
//Save the JD fraction
long double jdFrac = djd() - (long double)( date().jd() );
//set the integer portion of the JD and add back the JD fraction:
setDJD( (long double)_d.jd() + jdFrac );
}
void KStarsDateTime::setTime( const TQTime &_t ) {
KStarsDateTime _dt( date(), _t );
setDJD( _dt.djd() );
}
dms KStarsDateTime::gst() const {
dms gst0 = GSTat0hUT();
double hr = double( time().hour() );
double mn = double( time().minute() );
double sc = double( time().second() ) + double ( 0.001 * time().msec() );
double st = (hr + ( mn + sc/60.0)/60.0)*SIDEREALSECOND;
dms gst = dms( gst0.Degrees() + st*15.0 ).reduce();
return gst;
}
dms KStarsDateTime::GSTat0hUT() const {
double sinOb, cosOb;
// Mean greenwich sidereal time
KStarsDateTime t0( date(), TQTime( 0, 0, 0 ) );
long double s = t0.djd() - J2000;
double t = s/36525.0;
double t1 = 6.697374558 + 2400.051336*t + 0.000025862*t*t +
0.000000002*t*t*t;
// To obtain the apparent sidereal time, we have to correct the
// mean greenwich sidereal time with nutation in longitude multiplied
// by the cosine of the obliquity of the ecliptic. This correction
// is called nutation in right ascention, and may amount to 0.3 secs.
KSNumbers num( t0.djd() );
num.obliquity()->SinCos( sinOb, cosOb );
// nutLong has to be in hours of time since t1 is hours of time.
double nutLong = num.dEcLong()*cosOb/15.0;
t1 += nutLong;
dms gst;
gst.setH( t1 );
return gst.reduce();
}
TQTime KStarsDateTime::GSTtoUT( dms GST ) const {
dms gst0 = GSTat0hUT();
//dt is the number of sidereal hours since UT 0h.
double dt = GST.Hours() - gst0.Hours();
while ( dt < 0.0 ) dt += 24.0;
while ( dt >= 24.0 ) dt -= 24.0;
//convert to solar time. dt is now the number of hours since 0h UT.
dt /= SIDEREALSECOND;
int hr = int( dt );
int mn = int( 60.0*( dt - double( hr ) ) );
int sc = int( 60.0*( 60.0*( dt - double( hr ) ) - double( mn ) ) );
int ms = int( 1000.0*( 60.0*( 60.0*( dt - double(hr) ) - double(mn) ) - double(sc) ) );
return( TQTime( hr, mn, sc, ms ) );
}
void KStarsDateTime::setFromEpoch( double epoch ) {
if (epoch == 1950.0) {
setDJD( 2433282.4235 );
} else if ( epoch == 2000.0 ) {
setDJD( J2000 );
} else {
int year = int( epoch );
KStarsDateTime dt( ExtDate( year, 1, 1 ), TQTime( 0, 0, 0 ) );
double days = (double)(dt.date().daysInYear())*( epoch - (double)year );
dt = dt.addSecs( days*86400. ); //set date and time based on the number of days into the year
setDJD( dt.djd() );
}
}