Orbit determination routines for Python
This is orbdetpy, a Python and Java library for orbit determination. It is a thin Python wrapper for our Java estimation tools and Orekit.
The force model for orbit propagation can be configured to include:
- EGM96 gravity field up to degree and order 360.
- Earth solid tides due to the influence of the Sun and Moon.
- FES 2004 ocean tide model up to degree and order 100.
- The NRL MSISE-00 and simple exponential models for atmospheric drag.
- Solar radiation pressure.
- Third body perturbations from the Sun and Moon.
The measurement model supports range, range-rate, angles, and inertial Cartesian coordinates. Filtering is done with our Unscented Kalman Filter or Orekit's Extended Kalman Filter. Dynamic Model Compensation (DMC) can be used with either filter to estimate additional perturbing acclerations that result from unmodeled dynamics, maneuvers etc.
Install the Java Development Kit 8 (1.8) from http://openjdk.java.net/install/index.html. Set the
JAVA_HOMEenvironment variable to the JDK installation folder. The
javaexecutable must be added to the system path.
Install Python 3.7.0 or higher and run
pip install orbdetpyto install orbdetpy and other package dependencies.
Update the astrodynamics data under
orbdetpy/orekit-dataperiodically by running the following. You might need to be the
rootuser on some systems.
python -c "from orbdetpy.astro_data import update_data; update_data();"
fit_radec.py: Run OD with real angles measurements. Also demonstrates the Laplace IOD method for estimating an initial state vector.
predict_passes.py: Predict satellite passes for ground stations or geographic regions using TLEs. Current elements may be obtained from sites such as http://www.celestrak.com.
propagate_tle.py: Propagate TLEs given by command-line arguments.
test_conversion.py: Test reference frame and other conversion functions.
test_estimation.py: Demonstrates measurement simulation and orbit determination functions.
test_interpolation.py: Interpolate state vectors.
Developers will need Apache Maven 3+ to build the Java library. Build using the following from the
osx-x86_32depending on your CPU and OS:
mvn -e -Dos.detected.classifier=os_cpu_type package
The command-line is simpler on Intel/AMD 64-bit Linux:
mvn -e package
Download and extract https://github.com/ut-astria/orbdetpy/releases/download/2.0.3/orekit-data.tar.gz under the
You might receive warnings from the Windows Defender Firewall on Microsoft Windows. Grant
orbdetpynetwork access permissions.
If you use the
multiprocessingPython package, imports and calls into
orbdetpymust not span
multiprocessingfunction calls. That is,
orbdetpycan be used in the parent process or the spawned child processes, but not both. A workaround is to run the
orbdetpyRPC server using
orbdetpy/start_rpc_server.shin a separate terminal window before running your Python code.
Release history Release notifications | RSS feed
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size orbdetpy-2.0.3-py3-none-any.whl (27.8 MB)||File type Wheel||Python version py3||Upload date||Hashes View|
|Filename, size orbdetpy-2.0.3.tar.gz (27.7 MB)||File type Source||Python version None||Upload date||Hashes View|