Skip to main content

Easily convert your OpenRocket files into RocketPy simulations.

Project description

RocketPy Logo

Documentation Status Chat on Discord Sponsor RocketPy Instagram LinkedIn


Rocket Serializer

rocketserializer is a Python library that provides serialization capabilities for OpenRocket files. It allows you to read OpenRocket files (.ork) using a simple and intuitive command line interface. After serializing the file, you can use the data to create your RocketPy simulation.

Example

Installation

You can install rocketserializer using pip:

pip install rocketserializer

Requirements

Java

You need Java to be installed on your system to use rocketserializer. We recommend downloading Java 17, which is required to run OpenRocket-23.09.

https://www.oracle.com/java/technologies/downloads/

OpenRocket

You also need to download the OpenRocket JAR file. You can download it from the following link:

https://openrocket.info/downloads.html?vers=23.09#content-JAR

Each version of OpenRocket has its own jar file, and it is important to use the correct java version to run the jar file.

Python Packages

Once you download the rocketserializer package, the following dependencies will be automatically installed:

  • bs4
  • click>=8.0.0
  • lxml
  • numpy
  • orhelper==0.1.3
  • pyyaml
  • rocketpy>=1.1.0
  • nbformat>=5.2.0

Usage - command line interface

The rocketserializer package will automatically install 2 command-line-interface (cli) options, here's an example:

Serialization

To create a parameters.json file from an OpenRocket file, use the following command:

ork2json --filepath your_rocket.ork

Or, for a more verbose output, you can use the following command:

ork2json --filepath your_rocket.ork --verbose True

The options are the following:

  • --filepath: The .ork file to be serialized.
  • --output : Path to the output folder. If not set, the output will be saved in the same folder as the filepath.
  • --ork_jar : Specify the path to the OpenRocket jar file. If not set, the library will try to find the jar file in the current directory.
  • --encoding : The encoding of the .ork file. By default, it is set to utf-8.
  • --verbose : If you want to see the progress of the serialization, set this option to True. By default, it is set to False.

Only the --filepath option is mandatory.

Creating a simulation notebook

ork2notebook --filepath your_rocket.ork

The options are pretty much the same as the serialization command!

Limitations

This code won't work for your rocket if it has any of the following features:

  • Your .ork file must be saved in English
  • Your .ork file must be saved with at least 1 simulation data
  • Only one single stage is supported
  • Only a single motor is supported
  • Only a single nose cone is supported

Roadmap

  • 2024 June : First public release, start receiving feedback from the community.

Before the first public release, we will listen to the community's feedback before defining the roadmap for the next releases.

Contact

If you find any bug or if you want to request new features, please open an issue on GitHub. In case you don't have a GitHub account, you can reach out to us on RocketPy's Discord server.

How to Contribute

The 3 main ways of contributing to this project are:

  1. Reporting bugs and suggesting new features.
    • Use GitHub, preferably, to report bugs and suggest new features.
    • In case you don't have a GitHub account, you can reach out to us on RocketPy's Discord server
  2. Sharing .ork files that can be used to test the library.
    • If you have a .ork file that is not working with the library, please share it with us.
    • If you have a .ork file that is working with the library, please share it with us.
    • If you allow us to use and share your .ork file, we can add it to the test suite.
  3. Developing new features and fixing bugs thorough pull requests on GitHub.
    • If you want to develop new features, you are more than welcome to do so.
    • Please reach out to the maintainers to discuss the new feature before starting the development.

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

rocketserializer-0.2.0.tar.gz (28.5 kB view details)

Uploaded Source

Built Distribution

rocketserializer-0.2.0-py3-none-any.whl (33.8 kB view details)

Uploaded Python 3

File details

Details for the file rocketserializer-0.2.0.tar.gz.

File metadata

  • Download URL: rocketserializer-0.2.0.tar.gz
  • Upload date:
  • Size: 28.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.9.19

File hashes

Hashes for rocketserializer-0.2.0.tar.gz
Algorithm Hash digest
SHA256 2783d2c171b588ef8fa9865811362d6e56f12c6764cb485640bac8c486ae2f46
MD5 1682a02a8a36a06d3632bb7ccbd1f2fe
BLAKE2b-256 1dc8113d5a4d96e98d3961e223651dbf107d376518a4a9b163b2ff8b36dd6065

See more details on using hashes here.

File details

Details for the file rocketserializer-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for rocketserializer-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e8520f546f2b8c5bf7901882cfec48099798626f7ef6306577ae69d3a1aa08f2
MD5 63f1701731535ab131d5300a4764ed7a
BLAKE2b-256 5cbf474b59ae6a0444514efe6d87f402b883fb073e8591d5f0e3d476ae779a5a

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