astro-rust

License Build Status

Contents

API Docs

This project is currently a work in progress. Some APIs may be updated occasionally.

About

astro-rust is an MIT licensed library of astronomical algorithms for the Rust programming language.

Implemented algorithms include planetary, solar, lunar and planetary satellite positioning, corrections for precession, nutation, parallax, and aberration, calculation of the physical ephemeris of Mars, Jupiter, and the ring system of Saturn, finding position angles, illuminated fractions, visual magnitudes, and times of rise, set and transit of celestial bodies, and much more.

The main reference taken as the source of algorithms is the famous book Astronomical Algorithms by Jean Meeus, whose almost every chapter has been addressed here; although in some cases, such as approximating ΔT and planetary heliocentric positioning, the library uses far more accurate methods taken from sources mentioned in the references section.

The end goal (of this project) is to build a modern, well-tested, well-documented library of algorithms for future use in astronomy. And doing it all in Rust is very much a part of that.

Usage

Algorithms

For information on the modules and functions available, see the Rust API Documentation.

The following is a categorical high level listing of all the physical quantities you can calculate or actions you can perform, using the algorithms that have been implemented so far:

The 8 Solar System Planets

The Solar System Planets excluding Earth

The Sun

The Moon

The Earth

Pluto

Mars

Jupiter

Saturn

Transit

Ecliptic

Nutation in

Atmospheric refraction

Aberration

Transform

Elliptic orbits

Parabolic orbits

Near-parabolic orbits

Time

Stars

Binary stars

Asteroids

Contributing

Anyone interested to contribute in any way possible is encouraged to do so. Not all the algorithms in Meeus's book have been implemented yet. Documentation and tests need to be written for them as well. Refactored code and minor optimizations for the existing code are also welcome.

A fun suggestion is the addition of the recent IAU 2000/2006 precession-nutation model. This method improves upon the existing model implemented here "by taking into account the effect of mantle anelasticity, ocean tides, electromagnetic couplings produced between the fluid outer core and the mantle as well as between the solid inner core and fluid outer core".

References

  1. Most algorithms: Astronomical Algorithms, 2nd edition (Meeus)
  2. Planetary heliocentric positioning: VSOP87-D
  3. Approximating ΔT: Five Millennium Canon of Solar Eclipses (Espenak and Meeus)
  4. Some physical constants: World Geodetic System 1984