Skip to main content

Python library used to communicate with multiple UAS simultaneously using MAVLink

Project description

PyPI Version Contribution Frequency License: GPLv3 Open Issues Documentation Status

What is pymavswarm?

pymavswarm is a Python library implemented to enable interaction with drone swarms using the MAVLink protocol. This library supports reading MAVLink messages sent from multiple agents in a swarm and sending MAVLink messages to agents within the swarm. Such functionality ultimately enables development of new swarm applications such as ground control stations.

Main features

Here are some of the main features of pymavswarm:

  • Easily send MAVLink commands to multiple drones, simultaneously

  • Monitor the state of swarm drone agents

  • Implement custom commands and swarm algorithms

  • Develop applications for on-board companion computers

  • Implement custom swarm ground control stations

  • Log incoming MAVLink messages for future evaluation and debugging

  • Construct pre-planned missions

  • Multi-agent collision avoidance using reachability analysis

Installation

pymavswarm may be installed from PyPI by running:

$ python3 -m pip install pymavswarm

To build pymavswarm from source, first ensure that at least Python 3.10 is installed. Once this dependency has been met, refer to the steps below:

  1. Clone the project repository

  2. Navigate to the pymavswarm/ base directory

$ cd path/to/pymavswarm/
  1. Install the pymavswarm Python package

$ python3 -m pip install .

Quick start

pymavswarm has been implemented to enable easy interfacing with drone swarms. Refer to the following code snippet for a simple example to get started with the library. Additional examples may be found in the project examples.

import time

from pymavswarm import MavSwarm

# Create a new pymavswarm interface
mavswarm = MavSwarm()

# Establish a connection with a USB telemetry device
mavswarm.connect('/dev/ttyUSB0', 115200, 255, 0)

# Wait for the swarm to be populated
while not mavswarm.agents:
    pass

# Arm each agent in the swarm
mavswarm.arm()

# Briefly delay to allow all agents to arm
time.sleep(5.0)

# Disarm each agent in the swarm
mavswarm.disarm()

# Close the pymavswarm connection
mavswarm.disconnect()

Getting help

If you have questions regarding pymavswarm usage or contribution please ask a question on our Discussions board!

Contributing

All contributions and ideas are welcome! Detailed guidelines regarding how to contribute can be found in the contribution guidelines.

License

pymavswarm is released under the GNU General Public License v3 or later

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

pymavswarm-1.2.0.tar.gz (67.7 kB view details)

Uploaded Source

Built Distribution

pymavswarm-1.2.0-py3-none-any.whl (93.8 kB view details)

Uploaded Python 3

File details

Details for the file pymavswarm-1.2.0.tar.gz.

File metadata

  • Download URL: pymavswarm-1.2.0.tar.gz
  • Upload date:
  • Size: 67.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.14

File hashes

Hashes for pymavswarm-1.2.0.tar.gz
Algorithm Hash digest
SHA256 5b253a285d8279dcac074ab64967d2383f78a7ec09e5e5c11f04f908045fb018
MD5 99c9f739c9cd08096aeda3973a2c9108
BLAKE2b-256 6faef128dea6eae5e46115ac2814faa589421bff0d2a9db82441719f12b19826

See more details on using hashes here.

File details

Details for the file pymavswarm-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: pymavswarm-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 93.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.14

File hashes

Hashes for pymavswarm-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 52e8837f5947c4b55b20d9ae7627e51f31d128dd9004f3ed87791eb4c732ccad
MD5 3f2e9db10c82775e4192c8bb23707d71
BLAKE2b-256 b6195c1578698316cc1f097567525f125a8f43f01769566ec46a22e83033bfe8

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