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.7.0.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.7.0-py3-none-any.whl (38.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for mavez-3.7.0.tar.gz
Algorithm Hash digest
SHA256 16698a9c5af67fea1411670a1413b669df109c5408d17a1600e48dd0689aad33
MD5 6ac7981bdaca58d19d37b6b666f5877e
BLAKE2b-256 71ec988cea48df8b1074174051d80bc31af25a9d8b613c953bc7f3f19826bc42

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for mavez-3.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9ec3a45a57eb9ca882fe02ebd1f34fc76682c86aa48d00184093e0194dafc01c
MD5 5da3626d4e095ec54f7d55d01413fe9d
BLAKE2b-256 17d4846a7842d9149145c3db32df15c5da5cb7edae3461eb0d3c8f2478ac2278

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