Python package for the crazyKhoreia project.
Project description
crazyKhoreia
Brief description.
crazyKhoreia is a robotic perception system intended for UAVs (aka drones), which takes a digital image and converts it into a waypoint matrix using X, Y and Z coordinates in meters for UAVs choreography design.
A preprint paper of this project is available here.
If this work is useful to you, please cite us:
@article{Restrepo2023, author = "Santiago Restrepo and Victor Romero Cano", title = "{CrazyKhoreia, a robotic perception system for UAV path planning from digital images}", year = "2023", month = "1", url = "https://www.techrxiv.org/articles/preprint/CrazyKhoreia_a_robotic_perception_system_for_UAV_path_planning_from_digital_images/21836868", doi = "10.36227/techrxiv.21836868.v1" }
How does it work?
crazyKhoreia takes a digital image and uses a vectorizing technic based on openCV findContours algorithm to obtain contours, then, it gets waypoints from those contours, after that, depending on the usage mode (either lightPainting or multi-UAV formation), it optimizes the waypoints and finds a feasible 2D path for travelling through all of them, or it computes safe trajectories for multi-UAV formation.
Light painting mode (class lightPainting)
Light painting is a photography technic consisting on capturing a long exposure photograph using a moving light source, the light source's movement creates an effect on the camera sensor which captures its trail, therefore, it "paints" all over the camera's frame, creating a painting optical effect.
Source: Rafael Rodrigo Perurena
Multi UAV formation mode (class multiDroneFormation)
A multi UAV formation is made by several UAVs grouped together in patterns to construct a figure visible with a naked eye. It's been used by companies such as Intel or DSS to create terrific light shows performed by UAVs like the Super Bowl's half-time shows. Source: Intel
Installation instructions.
Prerequisites.
Before using crazyKhoreia, please install the following dependencies.
$ pip3 install opencv-python
$ pip3 install numpy
$ pip3 install matplotlib
$ pip3 install scipy
$ pip3 install scikit-learn
Installing from Pypi with Python 3.
To install crazyKhoreia you'll need Python 3 and pip:
pip3 install crazyKhoreia
Installing from source.
If you'd like to develop, edit or have full access into the crazyKhoreia system, then you may install it from source.
git clone https://github.com/santiagorg2401/crazyKhoreia.git
Usage.
crazyKhoreia's usage it's pretty straightforward, you'll only need a digital image and a few parameters:
Parameter | Usage mode | Class | Description | Data type |
---|---|---|---|---|
dims | all | lightPainting multiDroneFormation | 2x3 float array containing flight space constraints in the x, y, and z axis [[MIN_X, MIN_Y, MIN_Z],[MAX_X, MAX_Y, MAX_Z]] | array |
in_path | all | lightPainting multiDroneFormation | Image file path. | str |
out_path | all | lightPainting multiDroneFormation | Files output path. | str |
led | light painting | lightPainting | Set led to True if you want to add led control within the waypoints output file, else, set False . |
bool |
detail | light painting | lightPainting | Used in clean_waypoints method to delete the points that their euclidian distance is minor than detail. | float |
speed | light painting | lightPainting | Used in calculate_stats to estimate flight duration, assuming constant speed. Side note: It doesn't affect the waypoints dataset. | float |
sleepTime | light painting | lightPainting | Used in calculate_stats to estimate flight duration, assuming that the UAV stops at each reached waypoint for the flew time duration plus a sleepTime percentage from it. Side note: It doesn't affect the waypoints dataset. | float |
video | light painting | lightPainting | Set video to True if you want to render an animation of the light painting generation, else set False . |
bool |
boxShape | multiDroneFormation | multiDroneFormation | Refers to the bounding box for each UAV, contains an 1x3 array, containing the box's: (length (X axis), wide (Y axis), height (Z axis)) in meters. | array |
Take into account that lightPainting and multiDroneFormation classes creates an instance of the crazyKhoreia class in its constructor method.
To run the program, create an instance of the lightPainting class.
from crazyKhoreia.lightPainting import lightPainting
lp = lightPainting(dims, in_path, out_path, detail=0.05, speed=1.0, sleepTime=1.5, video=False, led=False)
Or if you want to execute multiDroneFormation.
from crazyKhoreia.multiDroneFormation import multiDroneFormation
mdf = multiDroneFormation(dims, boxShape, in_path, out_path, nmbr_drones)
After its execution you'll notice the output files within the set output path.
Trouble?
Start a new discussion if you have any question related to the project, but, if you have a technical issue or a bug to report, then please create an issue.
Authors.
Tutor.
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
Built Distribution
File details
Details for the file crazyKhoreia-0.0.4.tar.gz
.
File metadata
- Download URL: crazyKhoreia-0.0.4.tar.gz
- Upload date:
- Size: 27.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d11649b328c3b78a474b78aaa674e17e60f5aa3f564a56fe2cf16a0526146b12 |
|
MD5 | c26a3fc5dd1b3f55de85244dc46b78e7 |
|
BLAKE2b-256 | 36cf20172be8ced9335e7808db80b0ec61ed813484300248db46a17c4c1e766d |
File details
Details for the file crazyKhoreia-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: crazyKhoreia-0.0.4-py3-none-any.whl
- Upload date:
- Size: 27.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 98bfd9ae4fb30fb5c5ed7e7182723a1632b10468b8fdb3a3ff0174d2f325a711 |
|
MD5 | 2fd225692a75a93453337577490902a0 |
|
BLAKE2b-256 | f28bc657d189d19fc62257148508c8007c7e9ce1e8cd7c3ea206e1cb647ae665 |