[Kstars-devel] [kstars] kstars: Initializing the (ecliptic) longitude of perihelion of the earth.
Akarsh Simha
akarsh.simha at kdemail.net
Sun Mar 17 08:34:27 UTC 2013
Git commit 75515fa2b0a4cc4d8dc5e62261595350ac1f2311 by Akarsh Simha.
Committed on 17/03/2013 at 03:50.
Pushed by asimha into branch 'master'.
Initializing the (ecliptic) longitude of perihelion of the earth.
Data is from: http://nssdc.gsfc.nasa.gov/planetary/factsheet/earthfact.html
Hopefully, we can believe the GSFC :)
The aberration computation relies on this, because the aberration
ellipse (as I understand it) is a downscaled "copy" of the earth's
orbit. Seemingly, this was never initialized, so the orientation of
the ellipse was off by 103 degrees!
Currently, we set it to the constant value from J2000.0, but it does
change with time, mostly because of perturbations from the gravity of
other planets (most notably Jupiter) and slightly because of general
relativity.
According to Wikipedia:
https://en.wikipedia.org/wiki/Apsidal_precession#Long-term_climate
the perihelion completes one revolution in 112,000 years, which leads to a value of 11.6 arcseconds / year.
So the orientation of the aberration ellipse is off by about 11.6 arcseconds a year. This is 5.6e-5 radians.
Accordint to Wikipedia on aberration:
https://en.wikipedia.org/wiki/Aberration_of_light and according to
ksnumbers.cpp:157, the constant of aberration is about 20.5
arcseconds, and Wikipedia explains that this is the "radius" of the
approximate circle traced by the stars.
The annual correction to the coordinates of a star due to the
precession of earth's perihelion would be, in the worst case (assuming
linear term in a Taylor expansion of the trigonometry involved), about
(5.6e-5)*0.0167*20.5 arcseconds / year = 1.83e-5 arcseconds/year.
(The 0.0167 is the eccentricity of the earth. Any corrections should
be in the worst-case linear in the eccentricity.)
If we want to be accurate for 10,000 years, we may still get away
without accounting for this, but if our order of magnitude estimate
above is incorrect over those longer timescales, it may be comparable
to typical atmospheric seeing.
But this should be fine for now! Unless we can find the algorithm for
this... :D
Should be backported to 4.10 and cherry-picked into master.
CCMAIL: kstars-devel at kde.org
(cherry picked from commit 412f1fc462468c5cfa0661fddc1d958b564e5f66)
M +1 -0 kstars/ksnumbers.cpp
http://commits.kde.org/kstars/75515fa2b0a4cc4d8dc5e62261595350ac1f2311
diff --git a/kstars/ksnumbers.cpp b/kstars/ksnumbers.cpp
index da0e0db..4c98739 100644
--- a/kstars/ksnumbers.cpp
+++ b/kstars/ksnumbers.cpp
@@ -156,6 +156,7 @@ const int KSNumbers::amp[NUTTERMS][4] = {
KSNumbers::KSNumbers( long double jd ){
K.setD( 20.49552 / 3600. ); //set the constant of aberration
+ P.setD( 102.94719 ); // ecliptic longitude of earth's perihelion, source: http://nssdc.gsfc.nasa.gov/planetary/factsheet/earthfact.html; FIXME: We should correct this, as it changes with time. See the commit log for an order of magnitude estimate of the error.
updateValues( jd );
}
More information about the Kstars-devel
mailing list