Crates.io | rastro |
lib.rs | rastro |
version | 0.1.8 |
source | src |
created_at | 2021-03-21 18:42:33.838747 |
updated_at | 2021-12-29 04:54:11.305138 |
description | A modern space dynamics library for research and engineering applications. Designed to be high performance, easy to learn, and fast to code, and ready for flight. |
homepage | https://https://duncaneddy.github.io/rastro/ |
repository | https://github.com/duncaneddy/rastro/ |
max_upload_size | |
id | 371811 |
size | 17,404,213 |
FastAPI framework, high performance, easy to learn, fast to code, ready for production
Documentation: https://duncaneddy.github.io/rastro
Rust Library Reference: https://docs.rs/crate/rastro/latest
Source Code: https://github.com/duncaneddy/rastro
rastro is a modern space dynamics library for research and engineering applications. It is designed to be high performance, easy to learn, and fast to code, and ready for flight.
The key features are:
RAstro gets its name from the combination of Rust and astrodynamics (Rust + astro = RAstro). Space dynamics is an expansive field that covers multiple domains of mathematics, astrodynamics, attitude dynamics, and systems engineering. While the underlying concepts have been studied and known since Kepler wrote down his three laws, there are few modern software libraries that make these concepts easily accessible. Space dynamics software generally runs into the following pitfalls:
Due to these challenges, students, researchers, and engineers frequently end up reimplementing common astrodynamics functions with an unfortunately frequent regularity. While reimplementation of common code can be a good learning mechanisms, in most cases it is both error-prone and costs time better spent on other endeavours. This project seeks to address this challenge by providing an easy-to-use, well-tested library, built in Rust for performance with bindings to Python for ease of use.
This project builds on experience from past projects in building space dynamics software:
You can find the package documentation here. This documentation is meant to provide a human-friendly walkthrough of the software and package. RAstro is currently in the early stages of development so the documentation will likely not be complete. Sections marked [WIP] will have some software functionality implemented but not be considered documented.
The most complete API reference guide will always be the Rust crate API reference, found [TODO]. This is always up-to-date with the latest release since it is autogenerated at build time during the release process.
The RAstro package is licensed and distributed under an MIT License to encourage adoption and to make it easy to integrate with other tools.
The only thing asked is that if you do use the package in your work, or appreciate the project, either send a message or star the project. Knowing that the project is being actively used is a large motivator for continued development.
RAstro is currently being developed primarily for my own enjoyment and because I find having these tools helpful in professional work. I plan to continue developing it for the time being regardless of greater adoption, time permitting.
That being said, it's incredibly encouraging and useful to know if the software is being adopted or found useful in wider practice. If you're using RAstro for school, research, or a commercial endeavour, I'd love to know about it! Tweet me @duncaneddy or email me at duncan.eddy (at) gmail.com.
I'd love to hear your feedback or thoughts!