Skip to main content

Retrieve, represent and manipulate JPL Horizons ephemerides.

Project description

https://travis-ci.org/bluephlavio/eph.svg?branch=master https://coveralls.io/repos/github/bluephlavio/eph/badge.svg?branch=master

Readme

The eph package provides some useful functions, classes and tools to retrieve, parse and manipulate ephemerides in an astropy-compatible way.

See eph-howto (jupyter notebook) for more info.

Basic Usage

import eph

req = eph.JplReq() # create the request
req.read('eph.ini', section='jplparams') # read parameters from 'jplparams' section in 'eph.ini'
req.set({
    'COMMAND': 'venus',
    'START_TIME': '2007-11-17',
    'STOP_TIME': '2017-4-22'
    'STEP_SIZE': '10d'
    }) # set parameters from dictionary
req['OBJ_DATA'] = False # set parameter dict-like
req.csv = True # set parameter as attributes
req.set(
    TABLE_TYPE='V',
    VEC_LABELS=False,
    VEC_TABLE=1
) # set position vectors output

res = req.query() # perform the request obtaining a response from Jpl Horizons service
e = res.parse() # parse the ephemeris in an astropy QTable

from astropy.io import ascii

ascii.write(e, format='csv') # write output data

The content of eph.ini can be something like this (see ftp://ssd.jpl_process.nasa.gov/pub/ssd/horizons_batch_example.long for a complete description of JPL parameters)

[jplparams]
MAKE_EPHEM=YES
REFERENCE_PLANE=ECLIPTIC
REF_SYSTEM=J2000
OUT_UNITS=AU-D

Shortcuts

eph package defines also some useful shortcut functions to easily access Jpl Horizons data. Instead of building a JplReq and get back a JplRes to parse, you can get an astropy QTable with

from eph import *
from datetime import datetime

e = get('venus', dates=['2000-1-1', datetime.now()])

Shortcut functions accept also one-date queries (non-interval) and multiple target objects. Behind the scenes eph makes multiple calls to JPL Horizons system and merge the results in one table. In this case non-key (used to join) columns are renamed with a prefix referring to the object (e.g. column X for object venus becomes venus_X). Meta info are listified and collapsed in a single value only if they take the same value for all objects.

from eph import *

e = get(['venus', 'mars'], dates='2017-04-22')

Dates has datetime.now() as default value so it can be omitted if you want present data.

from eph import *

e = get(['venus', 'mars'], table_type='V', vec_table=1) # present vector positional data for Venus and Mars

There are other shortcut functions like vec, pos, vel, elem, obs, radec, altaz, etc.. to simplify parameter settings.

For example, if you want vectors, type

e = vec('venus', dates=['2018-1-1', '2020-1-1']).

Command line tool

eph package also provides a command line tool:

$ eph venus --dates 2007-11-07 2017-04-22

This command gives you an ephemeris table of Venus starting from 2007-11-17 to 2017-4-22. You can also change the reference frame, the time-step size, the output etc.. through the options provided or setting up a config file. Check available options typing

$ eph --help

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

eph-1.1.4.tar.gz (62.5 kB view details)

Uploaded Source

Built Distribution

eph-1.1.4-py3-none-any.whl (69.7 kB view details)

Uploaded Python 3

File details

Details for the file eph-1.1.4.tar.gz.

File metadata

  • Download URL: eph-1.1.4.tar.gz
  • Upload date:
  • Size: 62.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for eph-1.1.4.tar.gz
Algorithm Hash digest
SHA256 904bc79dc624d211daee0f86261e998f0e82592120f4238b0f2b469df9f066c9
MD5 c32b69eb6b62658bb1994ab7a5de4d5c
BLAKE2b-256 605e564a984758a503f03697bbab4878531efc1a115a3c7b759f3dbcfec61db2

See more details on using hashes here.

File details

Details for the file eph-1.1.4-py3-none-any.whl.

File metadata

  • Download URL: eph-1.1.4-py3-none-any.whl
  • Upload date:
  • Size: 69.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3

File hashes

Hashes for eph-1.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 6ed6202efcfd6ebdf3c0a137866d35a69658d83f7dcc665c19bf9d8cfad1680e
MD5 555cdb117a8da6ebc6c39e032bf19483
BLAKE2b-256 d1d4b7ae81840e0bd1dad425b94167c211901f59a23b2773bd21b1dda007b06c

See more details on using hashes here.

Supported by

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