Skip to main content

KSP Trajectory Optimization

Project description

Trajectorize Logo PyPi Version License


KSP Trajectory Optimizer.

This project is a reduced-scope version of one of my other (currently incomplete) projects, as an intermediate stepping stone.

This tool computes trajectories between celestial bodies in KSP based on on-rails two-body patched conics, incorporating trajectory correction maneuvers for a variety of mission scenarios, such as:

  • Ballistic Hohmann transfers for other planets
  • Gravity assist flyby routes

Computationally-intensive code is implemented in C, with a Python wrapper made using cffi. C code follows mostly C89, with some C99 features used. It has been tested against the latest versions of GCC (on Linux) and MSVC (on Windows 10).

Installation

The simplest way to install is from PyPI:

pip install trajectorize

This will install the latest stable version of the package, and may include pre-compiled binaries for your platform.

The package is still in development, so you may want to install from the latest commit on the main branch instead:

Run pip install git+https://github.com/itchono/trajectorize to install the package from source.

You will need to have Python 3.8+, and a C compiler installed to compile the C code if installing from source. You will also need a C compiler installed if there are no pre-compiled binaries for your platform. If you're on Windows, you can find details about installing a C compiler here.

The following platforms/compilers have been tested:

Platform Compiler
Windows 10 MSVC 14.16 (Visual Studio 2017)
Ubuntu 20.04 LTS (Dev Machine) GCC 9.4.0

Demos

Right now, full functionality is incomplete. There are, however, some cool demos showing off the capabilities of the package.

Full Model of KSP Planetary System and Ephemerides

python -m trajectorize.demos.kerbol_system_anim

Kerbol System Animation

Calculation of Ballistic Interplanetary Transfers Using Lambert's Problem

python -m trajectorize.demos.kerbin_duna_transfer

Transfer

Propagation of Two-Body Trajectories Using Universal Keplerian Elements

python -m trajectorize.demos.orbit

Orbit Demo

Calculations of Optimal Transfers, Porkchop Plots

python -m trajectorize.demos.kerbin_duna_porkchop

Porkchop

Inspirations

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

trajectorize-0.0.7.tar.gz (46.8 kB view details)

Uploaded Source

File details

Details for the file trajectorize-0.0.7.tar.gz.

File metadata

  • Download URL: trajectorize-0.0.7.tar.gz
  • Upload date:
  • Size: 46.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.10

File hashes

Hashes for trajectorize-0.0.7.tar.gz
Algorithm Hash digest
SHA256 9fb1faa8eb70dc36d980dfda242f38a8eb740f7cb997fa3b037cda2999d497b9
MD5 c1a307e28ae1f6cf3e79041e43679c96
BLAKE2b-256 8bc452b7e9f0b5097d46e0ff08dd15a13bf7ed2eee897ec38438e279e712b936

See more details on using hashes here.

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