Skip to main content

Clean-room astrological ephemeris engine: planetary and lunar positions, houses, aspects, and events from published sources. The Python reference for the Caelus engine.

Project description

caelus-engine

The Python reference implementation of the Caelus astrological ephemeris engine. Clean-room, MIT-licensed, written from published sources (VSOP87D, ELP/Meeus, IAU models, JPL Horizons fits). No Swiss Ephemeris code, no bundled third-party ephemeris files.

The engine reads pre-built Chebyshev and series packs shipped with the package and runs on the Python standard library alone. It is also the reference that the TypeScript engine (caelus on npm) is pinned to by a golden conformance suite.

Install

pip install caelus-engine

The import package is astroengine:

from astroengine import Engine, BODIES

eng = Engine("full")
jd = 2451545.0  # 2000-01-01 12:00 UT
for body in BODIES:
    print(f"{body:10s} {eng.longitude(body, jd):10.5f}")

What it computes

  • Planetary and lunar apparent geocentric ecliptic longitudes (VSOP87D for the planets, Meeus Ch. 47 for the Moon, Meeus Ch. 37 series for Pluto), with light-time, annual aberration, FK5 frame correction, and IAU 1980 nutation.
  • 12 house systems; tropical and sidereal (7 ayanamsas).
  • Aspects with configurable orbs.
  • Events: rise/set/transit, longitude crossings, lunar phases, stations, Gauquelin sectors, solar and lunar eclipses.
  • Fixed stars and topocentric positions.
  • Derived charts: returns, secondary progressions, solar arc, composite and Davison, harmonics, antiscia, declination aspects and parallels, out-of-bounds, dignities, sect.
  • Electional primitives: applying/separating aspects, solar phase (cazimi/combust/under-the-beams), planetary hours, void-of-course Moon, house placement.
  • A declarative when() query engine over celestial predicates.
  • A turbo tier (Turbo): segmented Chebyshev longitude packs fit to the engine for bulk scans.
  • 3D aspects (angular_separation_3d): the great-circle angle between two bodies, accounting for ecliptic latitude.
  • Astrocartography (astrocartography): the planetary angle lines (MC/IC meridians, ASC/DSC rising and setting tracks) across the globe.

Accuracy

Accuracy is calibrated against Swiss Ephemeris and validated against JPL Horizons, stated per body rather than as a blanket figure. See the validation tables at https://ephemengine.com.

Optional: the fitting toolchain

The engine runs without any third-party dependency. The data-fitting tools that regenerate the coefficient packs need numpy:

pip install "caelus-engine[fit]"

License

MIT. See LICENSE. Project home: https://ephemengine.com. Source: https://github.com/heavyblotto/caelus.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

caelus_engine-0.20.1.tar.gz (3.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

caelus_engine-0.20.1-py3-none-any.whl (3.4 MB view details)

Uploaded Python 3

File details

Details for the file caelus_engine-0.20.1.tar.gz.

File metadata

  • Download URL: caelus_engine-0.20.1.tar.gz
  • Upload date:
  • Size: 3.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for caelus_engine-0.20.1.tar.gz
Algorithm Hash digest
SHA256 5601a66bec4f5ee34554e68b1fdca06b59b1899072ff32c2d4e48e1fd6228e8a
MD5 358bef42ed27ae4976c62ee72f56f3ec
BLAKE2b-256 821a4919f46188efb0a709f639403a9b4b1dae12c783bd6ad2e1f3f379784237

See more details on using hashes here.

Provenance

The following attestation bundles were made for caelus_engine-0.20.1.tar.gz:

Publisher: release.yml on heavyblotto/caelus

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file caelus_engine-0.20.1-py3-none-any.whl.

File metadata

  • Download URL: caelus_engine-0.20.1-py3-none-any.whl
  • Upload date:
  • Size: 3.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for caelus_engine-0.20.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b9c6e536beb8dd86cd86b83d61996f7d6a25b147d8bae8492afd9f935e44f649
MD5 3a118a83fc7326d91f2a4b2cf74d5a6a
BLAKE2b-256 5d368f1c2263d05abd26af3e69505a0f97566c1392cd20b1088fc43d045655f1

See more details on using hashes here.

Provenance

The following attestation bundles were made for caelus_engine-0.20.1-py3-none-any.whl:

Publisher: release.yml on heavyblotto/caelus

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page