astrorigin / pyswisseph

Python extension to the Swiss Ephemeris
https://astrorigin.com/pyswisseph
GNU Affero General Public License v3.0
242 stars 66 forks source link
astrology astronomy ephemerides swisseph

========== Pyswisseph

This is the Python extension to the Swiss Ephemeris by AstroDienst.

The Swiss Ephemeris is the de-facto standard library for astrological calculations. It is a high-precision ephemeris, based upon the DE431 ephemerides from NASA's JPL, and covering the time range 13201 BC to AD 17191.

Usage Example

::

>>> import swisseph as swe
>>> # first set path to ephemeris files
>>> swe.set_ephe_path('/usr/share/sweph/ephe')
>>> # find time of next lunar eclipse
>>> jd = swe.julday(2007, 3, 3) # julian day
>>> res = swe.lun_eclipse_when(jd)
>>> ecltime = swe.revjul(res[1][0])
>>> print(ecltime)
(2007, 3, 3, 23.347926892340183)
>>> # get ecliptic position of asteroid 13681 "Monty Python"
>>> jd = swe.julday(2008, 3, 21)
>>> xx, rflags = swe.calc_ut(jd, swe.AST_OFFSET+13681)
>>> # print longitude
>>> print(xx[0])
0.09843983166646618

Links

:Pyswisseph docs: https://astrorigin.com/pyswisseph :Python Package Index: https://pypi.org/project/pyswisseph :AstroDienst: https://www.astro.com/swisseph

Source code

Clone the Github repository with command:

git clone --recurse-submodules https://github.com/astrorigin/pyswisseph

Licensing

The Pyswisseph package adopts the GNU Affero General Public License version 3. See the LICENSE.txt file.

The original swisseph library is distributed under a dual licensing system: GNU Affero General Public License, or Swiss Ephemeris Professional License. For more information, see file libswe/LICENSE.

Test Suite

For now, the tests can be run with the standard python3 setup.py test command. For them to pass successfully, you need a basic set of ephemerides files installed somewhere on your system:

All downloadable from https://www.astro.com/ftp/swisseph/ephe/

The path to the directory containing those files must be indicated in the environment variable SE_EPHE_PATH.

For example, on a system with the env command, you can do::

env SE_EPHE_PATH="/usr/share/sweph/ephe" python3 setup.py test

Credits

Author: Stanislas Marquis <stan(at)astrorigin.com>

PyPI/CI: Jonathan de Jong <jonathan(at)automatia.nl>

..