Skip to main content

An intuitive MAVLink library for ArduPilot via pymavlink

Project description

PSU UAS MAVez

The Pennsylvania State University

Description

Library for controlling ArduPilot from an external computer via pymavlink.

For detailed documentation on pymavlink, visit mavlink.io. "Standard Messages/Commands" > "common.xml" is a particularly useful resource.

Table of Contents

Installation

  1. In a terminal window, run git clone git@github.com:UnmannedAerialSystems/MAVez.git
  2. Switch into the newly cloned directory by running cd MAVez
  3. Install the package locally in editable mode pip install -e .

While not required, it is highly recommended that you utilize ArduPilot's Software in the Loop (SITL) simulator to make testing significantly easier. Install instructions are provided for Windows and MacOS in the appendix. For Linux or WSL instructions, refer to the ArduPilot setup page

Example Usage

Below is a simple script designed to work with SITL. This example is provided at /examples/basic.py/

from MAVez import flight_controller
from MAVez.safe_logger import configure_logging
import asyncio


logger = configure_logging()
async def main():
    controller = flight_controller.FlightController(connection_string='tcp:127.0.0.1:5762', baud=57600, logger=logger)

    await controller.set_geofence("./examples/sample_missions/sample_fence.txt")

    await controller.arm()

    await controller.takeoff("./examples/sample_missions/sample1.txt")
    controller.append_mission("./examples/sample_missions/sample2.txt")
    controller.append_mission("./examples/sample_missions/sample3.txt")

    await controller.auto_send_next_mission()
    await controller.auto_send_next_mission()

    await controller.wait_for_landing()

    await controller.disarm()

if __name__ == "__main__":
    asyncio.run(main())

License:

This project is licensed under the GNU General Public License v3.0.

Authors:

Ted Tasman Declan Emery Vlad Roiban

Appendix:

SITL Installation

Windows

SITL comes precompiled for Windows as part of Mission Planner. Installing Mission Planner is the most painless method for using SITL on Windows.

MacOS

  1. Install prerequisites:
brew install python3 gcc
pip install future pymavlink MAVProxy opencv-python
  1. Clone ArduPilot repository
git clone https://github.com/ArduPilot/ardupilot.git
cd ardupilot
git submodule update --init --recursive
  1. Install environment
cd Tools/environment_install
./install-prereqs-mac.sh  # decline all prompts
  1. Compile the binaries

Return to ./ardupilot

./waf configure --board sitl
./waf copter
./waf plane
  1. Run SITL
./Tools/autotest/sim_vehicle.py -v ArduCopter --console --map

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

mavez-3.8.1.tar.gz (36.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mavez-3.8.1-py3-none-any.whl (38.9 kB view details)

Uploaded Python 3

File details

Details for the file mavez-3.8.1.tar.gz.

File metadata

  • Download URL: mavez-3.8.1.tar.gz
  • Upload date:
  • Size: 36.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for mavez-3.8.1.tar.gz
Algorithm Hash digest
SHA256 12854cf1a14ac5410353169f36ed5e48c6f782613df0c35f273ecf5298d9d56f
MD5 097189f9b0a8c1ff9657b900684d3522
BLAKE2b-256 f9004616911e7f10803bec0b8deb554484335b82266cf5bda0632d3c0704d895

See more details on using hashes here.

File details

Details for the file mavez-3.8.1-py3-none-any.whl.

File metadata

  • Download URL: mavez-3.8.1-py3-none-any.whl
  • Upload date:
  • Size: 38.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for mavez-3.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e9f6a09f717808a7b0245b00b5027d01c41733d078c397b90a4716b2f4dd4c22
MD5 98a85caec771eef7dae0e51fe62f5acd
BLAKE2b-256 78cc1d95eeb698f3fab91c1d83e55471f9985001ea38b71f9fa83f22730e1ad6

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