/Pyalmanac

Creates the daily pages of the Nautical almanac

Primary LanguagePythonGNU General Public License v2.0GPL-2.0

Pyalmanac (Python 3 version)

'End of Life' ANNOUNCEMENT

Pyalmanac is nearing the end of its useful days. Almanacs generated after the next few years should not be used for navigational purposes. SFalmanac (or Skyalmanac with some restrictions regarding the accuracy of sunset/twilight/sunrise and moonrise/moonset) are the new norm as these are based on the more accurate algorithms currently employed in the NASA JPL HORIZONS System (the same algorithms are implemented in Skyfield).

Pyalmanac is implemented using PyEphem, which in turn uses XEphem that is based on the VSOP87D algorithms. XEphem is also 'end of life' as no further updates are planned, however the major discrepancies are related to the projected speed of Earth's rotation. The discrepancies in GHA between PyEphem and Skyfield can be summarized thus:

  • in 2020:   00.1 to 00.3 arcMINUTES GHA too high
  • in 2030:   02.3 to 02.9 arcMINUTES GHA too high
  • in 2050:   12.7 to 13.3 arcMINUTES GHA too high
  • in 2100:   38.9 to 39.5 arcMINUTES GHA too high
  • in 2200:   93.2 to 93.8 arcMINUTES GHA too high

The GHA discrepancy applies to the sun, moon, the First Point of Aries and all planets.

Description

Pyalmanac is a Python 3 script that creates the daily pages of the Nautical Almanac. These are tables that are needed for celestial navigation with a sextant. Although you are strongly advised to purchase the official Nautical Almanac, this program will reproduce the tables with no warranty or guarantee of accuracy.

This version of Pyalmanac was developed by Andrew Bauer based on the original Pyalmanac by Enno Rodegerdts. Various improvements, enhancements and bugfixes have been included. Pyalmanac contains its own star database (similar to the database in PyEphem 3.7.6), however the accuracy was poor. It is updated with data from the Hipparcos Catalogue and the GHA/Dec data now matches a sample page from a Nautical Almanac typically within 0°0.1'.

NOTE: two scripts are included (both can be run): 'pyalmanac.py' and 'increments.py'
NOTE: Pyalmanac contains its own star database - it does not use the version supplied with PyEphem, hence updating from 3.7.6 to 3.7.7 is harmless. Star names are chosen to comply with Nautical Almanacs.
NOTE: if required, a Python 2.7 script with identical functionality can be found at: https://github.com/aendie/Pyalmanac-Py2

ACKNOWLEDGEMENTS

I, Andrew Bauer, wish to thank Enno Rodegerdts for permission to update his GitHub site. Without Enno's pioneering work on the original Pyalmanac I would never have started (or known how to start) on this journey. I also thank the experts who have helped me... especially Brandon Rhodes, author of PyEphem and Skyfield, for fixing minor issues I identified.

AVAILABLE VERSIONS

Two versions (other than Pyalmanac) are available here: https://github.com/aendie

  • Pyalmanac is the fastest with "somewhat limited" accuracy that is sufficient for nautical navigation.
  • SFalmanac is the slowest and most accurate; almost entirely based on Skyfield. PyEphem is only used for planet magnitudes (because these are not in Skyfield).
  • Skyalmanac is a hybrid version that is significantly faster than SFalmanac. PyEphem is used for planet magnitudes and for all planet transits, sunrise, twilight and sunset calculations as well as moonrise and moonset.

PyEphem website: https://rhodesmill.org/pyephem/
Skyfield website: https://rhodesmill.org/skyfield/

UPDATE: Mar 2020

A new parameter in config.py enables one to choose between A4 and Letter-sized pages. A new approach to string formatting has been implemented: the old style Python string formatting syntax has been replaced by the new style string formatting syntax.

UPDATE: Jun 2020

The Equation Of Time is shaded whenever EoT is negative indicating that apparent solar time is slow compared to mean solar time (mean solar time > apparent solar time).

Requirements

    Most of the computation is done by the free Pyephem library.
    Typesetting is done by MiKTeX or TeX Live so you first need to install:

  • Python v3.4 or higher (the latest version is recommended)
  • PyEphem
  • TeX/LaTeX  or  MiKTeX  or  TeX Live

Files required in the execution folder:

  • *.py
  • Ra.jpg
  • A4chartNorth_P.pdf

INSTALLATION GUIDELINES on Windows 10:

    Install Python 3.8 (add python.exe to path)
    Install MiKTeX 2.9 from https://miktex.org/
    When MiKTeX first runs it will require installation of additional packages.
    Run Command Prompt as Administrator, go to your Python folder and execute, e.g.:

    cd C:\Python38-32
    pip install --upgrade pip
    ... for a first install:
    pip install pyephem
    ... if already installed, check for upgrade explicitly:
    pip install --upgrade pyephem

    Put the Pyalmanac files in a new folder, run Command Prompt and start with:
    py -3 pyalmanac.py

INSTALLATION GUIDELINES on Ubuntu 19.10 or 20.04:

    Ubuntu 19 and higher come with Python 3 preinstalled,
    however pip may need to be installed:
    sudo apt install python3-pip

    Install the following TeX Live package:
    sudo apt install texlive-latex-extra

    Install the required astronomical library:
    pip3 install pyephem

    Put the Pyalmanac files in a folder and start with:
    python3 pyalmanac.py

INSTALLATION GUIDELINES on MAC:

    Every Mac comes with python preinstalled.
    (Please choose this version of Pyalmanac if Python 3.* is installed.)
    You need to install the PyEphem library to use Pyalmanac.
    Type the following commands at the commandline (terminal app):

    sudo easy_install pip
    pip install pyephem

    If this command fails, your Mac asks you if you would like to install the header files.
    Do so - you do not need to install the full IDE - and try again.

    Install TeX/LaTeX from http://www.tug.org/mactex/

    Now you are almost ready. Put the Pyalmanac files in any directory and start with:
    python pyalmanac
    or
    ./pyalmanac