Commit Graph

1670 Commits

Author SHA1 Message Date
Don Cross
db24ae9332 C: Added comments. Error checking in SphereFromVector.
Astronomy_SphereFromVector was not checking its vector
argument for having a bad status. Now it does.

Added comments that clarify exactly what nutation and precession
functions do.
2022-12-03 16:30:55 -05:00
Don Cross
c29ec327f5 Measure the speed of EclipticGeoMoon.
Added a performance test to measure how fast
a call to EclipticGeoMoon is. Results:
Over 3 trials, mean time = 24.064 seconds.
Number of calls = 14,609,700.
Time per call = 1.647 microseconds.
That is faster than I thought!

Also replaced conditional compilation with a runtime flag
to indicate whether a test should be skipped by the "all"
command. This allows me to run performance tests without
hacking a #define in the code, plus it ensures that even
though I don't run the performance tests every time I change
Astronomy Engine, they at least compile without errors.
2022-12-03 13:38:22 -05:00
Don Cross
72634ea84b Removed test: C Ecliptic. No longer needed.
This was another test where I was trying to figure out
an apparent anomaly that was actually based on my
flawed assumption about why obliquity changes over time.
2022-12-01 13:51:42 -05:00
Don Cross
0ae8bf2bd3 C MoonEcliptic test: add error threshold checks. 2022-12-01 13:49:28 -05:00
Don Cross
a20f17bf8f Removed C MoonLatitudes test.
I don't need the MoonLatitudes test any more.
Its purpose was to investigate what I thought was an
ecliptic latitude discrepancy. Now I understand that
changes in obliquity are caused by changes in the ecliptic
plane, not the equatorial plane.
2022-12-01 13:34:09 -05:00
Don Cross
28a3505040 More C ecliptic latitude tests.
I'm still trying to understand a discrepancy
between ecliptic latitudes calculated in two
different equinoxes: mean equinox of date and
mean J2000 equinox. I keep thinking the two
latitude values should be the same, because they
are measured against an essentially unchanging
ecliptic plane. I understand that ecliptic longitudes
should change as the Earth's equator precesses
by 47 arcseconds per century.

Added new test MoonEcliptic(), that compares
JPL Horizons calculations of the Moon's ecliptic
coordinates relative to equator of date versus
Astronomy_EclipticGeoMoon():

C MoonEcliptic: PASS: count=73050, max lat=1.825 arcsec, max lon=23.462 arcsec.

It is so weird that the maximum latitude discrepancy is less than 2 arcseconds.

Updated MoonVector test to measure maximum errors in addition to RMS errors.
Display distance errors in kilometers instead of dimensionless units.

Defined constant JD_2000 so all my tests that
convert Julian Dates from JPL Horizons can share it.
2022-11-30 12:36:36 -05:00
Don Cross
f71e9d17a0 C: added test "Ecliptic" that confirms latitude discrepancy.
There is a discrepancy between ecliptic latitudes measured
using two different mean equinoxes: 1900 and 2000.
The discrepancy is very close to the change of obliquity
expected for a 100-year period: 47 arcseconds.
But ecliptic latitudes should remain constant as
the Earth's axis precesses!
2022-11-29 17:20:06 -05:00
Don Cross
119dfed824 C: define J2000 mean obliquity constants in one place. 2022-11-29 14:57:36 -05:00
Don Cross
1558f808e4 MoonLatitudes writes CSV file. MoonVector has larger time span.
MoonLatitudes now generates a CSV file for me to study the
ecliptic latitude discrepancy as a function of time.
I can see that it increases away from the year 2000,
and that it is periodic with the Moon's orbit.
This indicates an error in correcting for precession.

Generated new JPL Horizons test data for MoonVector that
covers the years 1900..2100 instead of 1980..2020.
Confirmed that its maximum error is still 1.16 arcsec.
That is error comparing EQJ vectors and ECL vectors.
2022-11-29 11:31:18 -05:00
Don Cross
6cdc6b9d9e ctest: moon_lat experiment, list test names.
The C unit test program ctest.c now includes a MoonLatitudes
function invoked by the name `moon_lat`.
This function demonstrates that there is a 47 arcsecond
discrepancy between ecliptic latitudes using the mean
equator of date and ecliptic latitudes using the mean
equator of J2000. This should not happen! I'm investigating.

Also, when running ctest without command-line arguments,
print a list of all available test names, so I don't have
to go open up the file ctest.c and read the code.
2022-11-29 09:41:38 -05:00
Don Cross
48a95c4ec4 C MoonNodes: print maximum node latitude. 2022-11-28 21:05:45 -05:00
Don Cross
704d412e16 C MoonVector: report errors in arcseconds. 2022-11-28 19:20:46 -05:00
Don Cross
298262e7a0 C MoonVector: test both ECL and EQJ coordinates. 2022-11-28 19:04:03 -05:00
Don Cross
9e48df6d91 Added C MoonVector test.
Extra verification of Astronomy_GeoMoon().
Confirmed accuracy as compared to JPL Horizons:
RMS angular error = 0.017988 arcmin.
RMS distance (relative) = 0.000028.
2022-11-28 18:30:46 -05:00
Don Cross
53b735a941 Fixed misspelled "ecliptic" in documentation. 2022-11-28 11:57:36 -05:00
Don Cross
5087e4df28 More documentation fixes for rise/set, altitude. 2022-11-27 13:56:51 -05:00
Don Cross
e12d2e88c6 Updated docs: SearchRiseSet, SearchAltitude.
The documentation for SearchRiseSet and SearchAltitude needed
clarification about refraction and the part of the body solved
for (center versus limb). The JavaScript version was especially
lacking compared to documentation for the other languages.

Also documented SearchAltitude's limitations; it does not
work at or near maximum/minimum altitude.

Mention that user-defined stars are allowed for
SearchRiseSet, SearchAltitude, and SearchHourAngle.

Fixed a couple places where the Kotlin documentation had
broken links to other functions.
2022-11-27 12:42:48 -05:00
Don Cross
1725c77c9f Fixed doc typos. JS HelioState user-defined stars.
I had a copy-n-paste typo in the `dec` parameters
for all of the DefineStar functions. Fixed it.

The TypeScript version of HelioState did not handle
user-defined stars. Added support there.
2022-11-23 12:01:34 -05:00
Don Cross
098eb3ac7a Optimized HelioDistance for user-defined stars.
Because we instantly know the heliocentric
distance of a user-defined star, there is no
need to convert it into a vector and then take
the length of the vector.
All of the HelioDistance functions now return
the distance directly, as an optimization.

Also, I decided it didn't make sense to have a
default definition for user-defined stars.
If the caller doesn't define a star, it should
be treated as an invalid body.
2022-11-23 11:16:56 -05:00
Don Cross
79f6eac8eb HelioState functions support user-defined stars. 2022-11-23 09:21:56 -05:00
Don Cross
7b7a306baf Python: Find rise/set/culm of user-defined stars.
Added Python support for user-defined stars.
Defined new StateVector methods: Position and Velocity.
Defined division operator: Vector / float.
Bumped version number to 2.1.12.
2022-11-22 21:42:02 -05:00
Don Cross
fe625c5956 Kotlin: added support for user-defined stars. 2022-11-22 19:29:15 -05:00
Don Cross
a6ddf1880a C#: implemented user-defined stars. 2022-11-22 15:06:04 -05:00
Don Cross
f6ad8b5b26 C: Find rise/set/culm of user-defined stars.
SearchRiseSet and SearchHourAngle now work with user-defined stars.

Fixed a bug in InternalSearchAltitude where I failed to return an error
code when its call to MaxAltitudeSlope failed.
2022-11-22 05:46:50 -05:00
Don Cross
6b4c6c67e2 C: Added Astronomy_DefineStar.
Beginning to add support in C for user-defined stars.
2022-11-21 22:16:30 -05:00
Don Cross
696efe8649 JS: Find rise/set/culm of user-defined stars.
DefineStar now requires passing in the heliocentric
distance of the star expressed in light-years.
That way, I can directly support returning vectors
to a star from HelioVector, GeoVector, etc.

SearchRiseSet and SearchHourAngle now work with user-defined stars.
2022-11-21 20:55:27 -05:00
Don Cross
84d6aff35a JS: Added function DefineStar.
I'm starting to implement the ability to define
up to 8 distinct points in the sky as "stars"
that will be allowed as a `body` parameter to
some Astronomy Engine functions, to be determined.
2022-11-21 12:53:45 -05:00
Don Cross
8fa81d0fbc Fixed botched commit: didn't update Kotlin docs. 2022-11-14 13:40:10 -05:00
Don Cross
351e997a2f Merge branch 'riseset_poles'
Fixed issues with finding rise/set events near the
Earth's poles. Avoid assumptions that rise/set is
tied to hour angles.
2022-11-14 12:05:20 -05:00
Don Cross
d9d955a651 Altitude search: better parameter checking.
Made sure all the altitude search functions
verify that the geographic latitude and target altitude
are valid numbers in the range [-90, +90].

Reworked the C version of the code to be clearer:
eliminated goofy ALTDIFF macro, split out max
altitude derivative into its own function MaxAltitudeSlope,
just like the other language implementations do.

Minor rewording of comments in MaxAltitudeSlope functions.

Python InvalidBodyError now includes the invalid body
in the diagnostic message.
2022-11-14 11:04:46 -05:00
Don Cross
5e074d05aa Bumped version number to 2.1.10.
Not ready to tag yet, because I need to merge into
master branch first, to pick up the npm package
configuration change.
2022-11-14 08:15:23 -05:00
Don Cross
1b52e91394 Python: overhauled altitude search 2022-11-13 22:17:06 -05:00
Don Cross
e85863acf5 JS: reworked rise/set to work in polar regions 2022-11-13 20:45:00 -05:00
Don Cross
e31be80497 Kotlin: reworked rise/set to work in polar regions 2022-11-13 19:25:44 -05:00
Don Cross
480e0c3ab5 C#: Overhauled altitude search for polar regions.
The C# version of the altitude searches now work correctly
near the Earth's poles. This is a port of the C version.
Cleaned up a little code in the C version.
2022-11-13 12:25:10 -05:00
Don Cross
a5995e2ee0 C RiseSet: improved efficiency.
Do not recurse deeper when any solution would
have a rise+set or a set+rise consecutively
within one second. This would risk confusing the
search, which has a 0.1 second tolerance for convergence.
For practical reasons, such events are dubious anyway,
being swamped by unpredictable atmospheric refraction.
Plus it's just faster to not have to recurse so deeply.

Add a safety valve that fails the search if recursion
gets deeper than the above tolerance would ever allow
to happen in the first place.

This change improves performance significantly:

C RiseSet: passed 5909 lines: time errors in minutes: rms=0.2904, max=1.1541, recur=15, altcount=156881

Added helper function AscentError for cleaner code in error cases.
2022-11-13 10:32:47 -05:00
Don Cross
8498d23c73 C RiseSet: print performance stats.
Track the maximum recursion depth in FindAscent.
Count the number of times the altitude_diff function is called.
These are important performance statistics that I want to
measure, so I can try a few optimization ideas.

Current results:

don@spearmint:~/github/astronomy/generate $ ./generate source && ./ctbuild && ./ctest -v riseset
./ctbuild: C compiler = gcc
./ctbuild: Built 'ctest' program.
C RiseSet: Moon    lat=-61.0 lon=103.0
C RiseSet: Moon    lat=-45.0 lon=150.0
C RiseSet: Moon    lat=29.0 lon=-81.0
C RiseSet: Moon    lat=80.0 lon=130.0
C RiseSet: Moon    lat=83.0 lon=105.0
C RiseSet: Moon    lat=84.0 lon=125.0
C RiseSet: Moon    lat=85.0 lon=135.0
C RiseSet: Moon    lat=85.0 lon=140.0
C RiseSet: Sun     lat=-90.0 lon=0.0
C RiseSet: Sun     lat=-88.0 lon=45.0
C RiseSet: Sun     lat=-60.0 lon=-150.0
C RiseSet: Sun     lat=15.0 lon=75.0
C RiseSet: Sun     lat=29.0 lon=-81.0
C RiseSet: Sun     lat=60.0 lon=0.0
C RiseSet: Sun     lat=89.0 lon=30.0
C RiseSet: Sun     lat=90.0 lon=0.0
C RiseSet: passed 5909 lines: time errors in minutes: rms=0.2904, max=1.1541, recur=19, altcount=171438
2022-11-13 09:36:48 -05:00
Don Cross
bfc7c80309 C: Cleanup of new function FindAscent(). 2022-11-12 21:52:38 -05:00
Don Cross
4602f619d3 C: Rise/set that works near the poles!
This is a whole new algorithm that efficiently finds
all rise/set events, even near the poles.
It uses a recursive bisection search that limits
recursion depth by knowing the maximum possible
|da/dt| = change in altitude with respect to time.
2022-11-12 21:40:20 -05:00
Don Cross
eede908314 Arcsine of (radius/dist) for more accuracy.
Finding apparent angular radius by dividing body radius
by distance is not quite as accurate as taking the
arcsine of the same ratio. Changed this for a slightly
more accurate answer.
2022-11-10 15:20:04 -05:00
Don Cross
bf20fb1c44 C: InternalSearchAltitude owns func + context.
Refactored so there is a single altitude function/context pair
instead of separate ones for SearchAltitude and SearchRiseSet.
This allows InternalSearchAltitude to fully understand the
problem to be solved, and also makes the code smaller.
InternalSearchAltitude will need to perform min/max altitude
calculations, which means it needs to know all the parameters
of the altitude search directly. They are no longer hidden
inside an opaque function pointer and context.

So now SearchAltitude and SearchRiseSet no longer create
contexts, nor pass in a function pointer. They just
pass the correct numeric parameters to the generic solver
InternalSearchAltitude, which packs the parameters into
the context for Search().

Unified the two context types into a single context type,
and the two callback functions into a single callback function.
2022-11-10 15:10:28 -05:00
Don Cross
3679966931 Version 2.1.9: attempt fix for Deno/Node type info.
Updated the version number so I can create a new
npm package to test the pull request from @matheo
that should allow TypeScript types to be exported correctly.
2022-11-08 20:59:17 -05:00
Don Cross
5eca7d7760 CodeQL tweaks and fixes.
Updated CodeQL config to ignore source templates,
because they are not syntactically valid source code.
Ignore other stuff that is irrelevant to published
code quality.

Made various fixes based on helpful CodeQL analysis.
2022-11-07 15:31:05 -05:00
Don Cross
0674d69237 C RiseSet: starting algorithm without hour angles.
The rise/set search based on hour angles is complicated,
and doesn't handle oddities that happen close to the poles.
I'm starting to rework rise/set as a more brute force solution
that iterates through finite time steps.

I also added a series of Moon data for the arctic circle,
which includes some of the more painful special cases.
For example:

Moon  130  80 2034-05-16T13:21Z s
Moon  130  80 2034-05-16T13:51Z r

Here the Moon sets, then rises 30 minutes later.
So now I'm trying to figure out how to discover
arbitrarily brief intervals like this.
I want the time increments to scale intelligently
so that we don't waste time during long periods
of inactivity (body above or below the horizon continuously),
but without missing examples like the one above.
2022-11-05 20:58:04 -04:00
Don Cross
1bc61f714e BROKEN BUILD: added failing data for rise/set.
Added sunrise/sunset test data for locations
at or near the poles. This causes rise/set tests to fail.
I need to fix these cases!

Observations:

1. Sunrise/sunset at the poles has nothing to do with
   the Earth's rotation. It is based only on the Sun's
   declination. Therefore, it makes no sense to look
   at hour angles there.

2. At the poles, there is no such thing as a meridian.
   For example, at the north pole, no matter which way
   you turn, you are facing south!
   So the very notion of hour angles is meaningless.

3. At the poles, there is a single sunrise and a single sunset
   per calendar year. The sun rises near the spring solstice
   for that hemisphere, and sets near the autumn solstice.

4. Near the poles, sunrise/sunset behavior gets more complicated.
   It is possible for there to be more than one sunset or sunrise
   per 24-hour period, because of changes of Sun declination.
2022-11-04 21:06:41 -04:00
Don Cross
244acd2cab Custom sort for rise/set data.
When parsing the rise/set data, the Linux
`sort` utility had weird behavior. Fixed it
by making parse_riseset.py do its own sorting
in an order that makes sense, before writing
to riseset.txt.
2022-11-04 20:58:50 -04:00
Don Cross
1caebb60cb Doxygen download bug fix. 2022-11-01 20:43:28 -04:00
Don Cross
7435134445 Scrape correct download link for Doxygen.
The Windows version of the GitHub Actions tests require
downloading Doxygen binaries. Every now and then this
step would break when Doxygen updates their version numbers.
Added a Python script to scrape the Doxygen website to
determine the correct URL to download.
commit_hook.bat calls the Python script to determine
the URL, so I don't have to keep manually updating it.
2022-11-01 20:33:42 -04:00
Don Cross
c8af73e1e7 Fixed #256 - added orbital period functions. 2022-11-01 19:40:30 -04:00
Don Cross
275e3a7c79 Kotlin: added function planetOrbitalPeriod. 2022-11-01 19:16:32 -04:00