A Python library for precise Vedic astrological calculations using Swiss Ephemeris.
Project description
udit-astro
udit-astro is a Python library for Vedic astrology calculations powered by Swiss Ephemeris.
This first version focuses on planet data:
- sidereal longitude
- zodiac sign
- degree within sign
- includes Sun, Moon, Mercury, Venus, Mars, Jupiter, Saturn, Uranus, Neptune, Pluto, Ceres, Chiron, Rahu, Ketu, Upaketu, Gulika, and POF
Installation
For local development:
pip install -e .
After publication, this will become:
pip install udit-astro
Example
from datetime import datetime, timedelta, timezone
from udit_astro import (
BirthData,
ChartSettings,
Formula,
GulikaMode,
HouseSystem,
NodeType,
Place,
get_cusp_data,
get_d9_cusp_data,
get_d9_cusps_data,
get_d9_planet_data,
get_d9_planets_data,
get_cusps_data,
get_house_significator_data,
get_house_significators_data,
get_planet_data,
get_planet_significator_data,
get_planet_significators_data,
get_planets_data,
set_ephemeris_path,
)
set_ephemeris_path("C:/ephe")
place = Place(latitude=28.6139, longitude=77.2090)
dt = datetime(
1996,
6,
13,
5,
30,
tzinfo=timezone(timedelta(hours=5, minutes=30)),
)
birth_data = BirthData(dt=dt, place=place)
chart_settings = ChartSettings(
node_type=NodeType.TRUE,
gulika_mode=GulikaMode.START_OF_SATURN_SEGMENT,
part_of_fortune=Formula.DAY_FORMULA,
house_system=HouseSystem.PLACIDUS,
planet_house_system=HouseSystem.WHOLE_SIGN,
)
positions = get_planets_data(birth_data, chart_settings=chart_settings)
moon = get_planet_data(birth_data, "Moon", chart_settings=chart_settings)
d9_positions = get_d9_planets_data(birth_data, chart_settings=chart_settings)
d9_moon = get_d9_planet_data(birth_data, "Moon", chart_settings=chart_settings)
cusps = get_cusps_data(birth_data, chart_settings=chart_settings)
first_cusp = get_cusp_data(birth_data, 1, chart_settings=chart_settings)
d9_cusps = get_d9_cusps_data(birth_data, chart_settings=chart_settings)
d9_first_cusp = get_d9_cusp_data(birth_data, 1, chart_settings=chart_settings)
significators = get_house_significators_data(birth_data, chart_settings=chart_settings)
first_house_significator = get_house_significator_data(
birth_data,
1,
chart_settings=chart_settings,
)
planet_significators = get_planet_significators_data(
birth_data,
chart_settings=chart_settings,
)
moon_significator = get_planet_significator_data(
birth_data,
"Moon",
chart_settings=chart_settings,
)
for planet, data in positions.items():
print(
planet,
data.sign_as_name,
data.sign_as_number,
data.house_number,
data.nakshatra_name,
data.nakshatra_pada,
round(data.position, 4),
data.position_as_DMS,
data.is_retrograde,
data.sign_lord,
data.star_lord,
data.sub_lord,
data.sub_sub_lord,
data.sub_sub_sub_lord,
round(data.longitude, 4),
)
for planet, data in d9_positions.items():
print(planet, data.sign_as_name, data.position_as_DMS, data.house_number)
for house_number, cusp in cusps.items():
print(
house_number,
cusp.sign_as_name,
cusp.sign_as_number,
cusp.nakshatra_name,
cusp.nakshatra_pada,
cusp.position_as_DMS,
cusp.sign_lord,
cusp.star_lord,
cusp.sub_lord,
cusp.sub_sub_lord,
cusp.sub_sub_sub_lord,
)
for house_number, cusp in d9_cusps.items():
print(
house_number,
cusp.sign_as_name,
cusp.sign_as_number,
cusp.position_as_DMS,
)
print(moon.sign_as_name, moon.position_as_DMS)
print(d9_moon.sign_as_name, d9_moon.position_as_DMS)
print(first_cusp.sign_as_name, first_cusp.position_as_DMS)
print(d9_first_cusp.sign_as_name, d9_first_cusp.position_as_DMS)
for house_number, data in significators.items():
print(
house_number,
data.a,
data.b,
data.c,
data.d,
)
print(
first_house_significator.a,
first_house_significator.b,
first_house_significator.c,
first_house_significator.d,
)
for planet_name, data in planet_significators.items():
print(
planet_name,
data.a,
data.b,
data.c,
data.d,
)
print(
moon_significator.a,
moon_significator.b,
moon_significator.c,
moon_significator.d,
)
Notes
- Input datetimes must be timezone-aware.
BirthDatabundles the birth datetime and optional place into one object.ChartSettingsbundles chart-level options like ayanamsha, Rahu/Ketu node type, and Gulika mode.ChartSettingsalso controls house cusps throughhouse_system, which defaults toHouseSystem.PLACIDUS.- Planet house placement uses
planet_house_system, which defaults toHouseSystem.WHOLE_SIGN. - Use
get_planet_data(...),get_d9_planet_data(...),get_cusp_data(...), andget_d9_cusp_data(...)when you want one item directly instead of the full dictionary. - Use
get_house_significators_data(...)for KP-style house significator A/B/C/D lists, orget_house_significator_data(...)for one house. - House significators currently consider only the standard 9 planets: Sun, Moon, Mars, Mercury, Jupiter, Venus, Saturn, Rahu, and Ketu.
- Significator occupancy uses
chart_settings.house_system, so it defaults toHouseSystem.PLACIDUS. - Use
get_planet_significators_data(...)for the inverse planet-wise A/B/C/D house view, orget_planet_significator_data(...)for one planet. get_d9_cusps_data(...)returns a slimmer D9 cusp shape with sign and position fields only.ChartSettingscan also take a single enum-based Part of Fortune formula override.- Place coordinates should be passed in decimal degrees.
- Calculations are sidereal by default.
- The default ayanamsha is Lahiri.
- Rahu/Ketu use
truenode by default; setNodeType.MEANto use mean node. - Upaketu is currently computed as a solar upagraha derived from the Sun's sidereal longitude.
- Part of Fortune uses the standard day/night logic by default. If
chart_settings.part_of_fortuneis set, that formula is used directly. - Gulika is currently computed with the Parashara day/night eight-part method and uses the ascendant at the selected Saturn-segment boundary.
- Gulika requires
place, because sunrise, sunset, and ascendant depend on location. - Planet sign/degree output is geocentric for now; coordinates are accepted now because place will be required for upcoming features like ascendant and houses.
- If you have Swiss Ephemeris data files, set their directory with
set_ephemeris_path(...).
Run A Test Script
Use the included example script:
pip install -e .
python examples/show_planet_positions.py
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file udit_astro-0.1.0.tar.gz.
File metadata
- Download URL: udit_astro-0.1.0.tar.gz
- Upload date:
- Size: 13.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8659cab7554ca1ba7f0df48c4d125640de1fa0303408c6cc6ced433b55e95682
|
|
| MD5 |
d60f9c1600c8928089dbc394c72a13f3
|
|
| BLAKE2b-256 |
69adccbccad016b881e3b47f75686bc660ac8380d5b9a4b31eaae14a7ae9da43
|
File details
Details for the file udit_astro-0.1.0-py3-none-any.whl.
File metadata
- Download URL: udit_astro-0.1.0-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ffd386625f0cbe82d06121e0db16b82b9a211d34bcbbf8fc650c6f183f841ad4
|
|
| MD5 |
382069048dfc533e2382e9541be7604f
|
|
| BLAKE2b-256 |
edaec673de6f701005b59581a09ee0a37967b46640c214fd94a4e56f7d5f399e
|