MAVROS examples
Project description
Welcome to MAVROS_Python_Examples
Author: Masoud Iranmehr
Github Page: https://github.com/masoudir/mavros_python_examples
Web Page: https://masoudir.github.io/mavros_tutorial/
Introduction
This is a python implementation of the MAVROS examples.
Install Requirements
Install some requirements
Just follow this command:
sudo apt-get install python-dev python-pip python3-dev python3-pip python3-rospkg
- Installs python3 and pip3.
Install Ardupilot-SITL
reference : https://ardupilot.org/dev/docs/building-setup-linux.html
Install MAVProxy (Auxiliary)
I prefer to use external proxy if I needed for MAVlink protocol. MAVProxy can forward any MAVLink messages from input to other TCP/UDP/Serial ports. It would be helpful if you are using one vehicle for two or more GCS or controller nodes. To install just use this command:
pip install MAVProxy
- Install MAVProxy with pip in python2
Install ROS
ROS is semi-Operating System for robots. ROS is generally available for many programming languages such as C++, Python, Javascript and etc. It's free and easy to use. Until now there are three supported versions of ROS (kinetic, melodic and neotic) and I prefer to use melodic in this document. To install ROS-melodic, there are two ways of installing from ready-built binary files or installing from source. I prefer to install the full-version of ros-melodic. If you are not using ubuntu, it's likely to face some problems in installing ROS from binary files mentioned in ROS tutorials from source, because its procedure is common for any kinds of linux platforms.
For install ROS-melodic from source you can refer to this link.
For install ROS-melodic from binary files you can refer to this link.
Install MAVROS
If you want to have installed ROS from binary files, this is recommended to install MAVROS from binary files too.
Install MAVROS from binary files
For this, you can refer to this link.
For case of ease, the commands to be executed for installing MAVROS from binary files are as below:
sudo apt-get install ros-melodic-mavros ros-melodic-mavros-extras
wget https://raw.githubusercontent.com/mavlink/mavros/master/mavros/scripts/install_geographiclib_datasets.sh
chmod a+x install_geographiclib_datasets.sh
./install_geographiclib_datasets.sh
Install MAVROS from source
If you are not using ubuntu, this is strongly recommended to install MAVROS from source due to the similarity between various Linux distributions. You can refer to this link for full documentation. But here is the abstract commands:
-
source <ROS_INSTALL_PATH>/devel/setup.bash
- Defines the installed folder of ROS (You can insert this command at the bottom of ~/.bashrc file to automatically run this command while opening a new shell. For this, you can use this command:sudo nano ~/.bashrc
) -
roscore
- Brings up ros core for accessing its functions and built packages -
sudo apt-get install python-catkin-tools python-rosinstall-generator -y
- Installs python packages related to ros -
cd ~/my_catkin_ws/src
- Jump to catkin src folder -
git clone https://github.com/ros-geographic-info/unique_identifier.git
- clone unique_identifier package -
git clone https://github.com/ros-geographic-info/geographic_info.git
- clone geographic_info package -
cd ~/my_catkin_ws
- Jump to catkin folder -
catkin init
- Initialize catkin workspace -
wstool init src
- Initialize ros package installer -
rosinstall_generator --rosdistro melodic mavlink | tee /tmp/mavros.rosinstall
- Install MAVLink (we use the melodic reference for all ROS distros as it's not distro-specific and up to date) -
rosinstall_generator --upstream mavros | tee -a /tmp/mavros.rosinstall
- Install MAVROS: get source (upstream - released) -
wstool merge -t src /tmp/mavros.rosinstall
- Create workspace & deps -
wstool update -t src -j4
- Builds the ros workspace -
rosdep install --from-paths src --ignore-src -y
- Install packages for ros -
./src/mavros/mavros/scripts/install_geographiclib_datasets.sh
- Install GeographicLib datasets -
catkin build
- Build source -
source devel/setup.bash
- Uses setup.bash or setup.zsh from workspace so that rosrun can find nodes from this workspace
For installing MAVROS from binary packages please refer to https://ardupilot.org/dev/docs/ros-install.html#installing-mavros.
Ignite Rover robot
Bringing up Ardupilot-SITL for Rover
-
cd <Your_Ardupilot_Instalation_Folder>/ardupilot/Tools/autotest/
- Jump to ardupilot folder -
python sim_vehicle.py -v Rover
- Start Rover vehicle
Becareful to do not use python3 to run or build MAVProxy due to some mismatches found in this package with MAVProxy modules such as "map" and "console".
Note that if you want to show other SITL modules such as map or console, you can use these commands:
python sim_vehicle.py -v Rover --map --console
Or alternatively you can mention them inside SITL terminal:
module load map
module load console
Note: Please be patient when ardupilot is compiling robots at first time. This takes 2-3 minutes to complete.
You can see that ardupilot-sitl created some outputs such as "127.0.0.1:14550" "127.0.0.1:14551". These are auxiliary UDP ports for communicating this vehicle to another MAVProxy console. We use these ports in examples.
Connect Rover to MAVROS
At first you have to source ROS and MAVROS. If you have installed them from binary files, follow these commands:
source /opt/ros/melodic/setup.bash
- Defines the installed folder of ROS and MAVROS
Or if you have installed them from source, follow these commands:
-
source <ROS_INSTALL_PATH>/devel/setup.bash
- Defines the installed folder of ROS (You can insert this command at the bottom of ~/.bashrc file to automatically run this command while opening a new shell. For this, you can use this command:sudo nano ~/.bashrc
) -
source <MAVROS_INSTALL_PATH>/devel/setup.bash
- Defines the installed folder of MAVROS (You can insert this command at the bottom of ~/.bashrc file to automatically run this command while opening a new shell. For this, you can use this command:sudo nano ~/.bashrc
)
Then it is the time for bringing up the core of ros:
roscore
- Brings up ros core for accessing its functions and built packages
Afterwards, you have to tell the MAVROS how to find the vehicle you are using it:
roslaunch mavros apm.launch fcu_url:=udp://:14550@
- Connects vehicle from UDP:14550 port to MAVROS
Or if you want to connect to your robot via TCP port remotely, you can use this command
roslaunch mavros apm.launch fcu_url:=tcp://<REMOTE_HOST>:<TCP_PORT>@
- Connects vehicle from REMOTE_HOST:TCP_PORT port to MAVROS
Install MAVROS_Python_Examples
Mavros_python_examples supports python3. For downloading it via git, just use these commands:
git clone https://www.github.com/masoudir/mavros_python_examples
cd mavros_python_examples
Or you can easily install this package via pip:
pip3 install -U mavros_python_examples
The -U parameter allow to update simple_udp_proxy version if it is already installed.
How to use
Run the test file
If you download this project with git, you can run the example via this command:
python3 test/rover.py
This will create a node with the name of "node1" and then it will connect to the ArduRover vehicle you brought up via the former step, then it will set the value of "CRUISE_SPEED" parameter to 2 and then it will change the vehicle mode to "GUIDED". Then it will ARM the vehicle and then force the vehicle to move to the destination of {"lat":50.15189, "lon":10.484885}.
Implement on your project
If you have installed this package via pip3, you can just write a sample code like this:
from mavros_python_examples.roverHandler import *
import threading
import time
class MyRoverHandler(RoverHandler):
def __init__(self):
super().__init__()
self.user_thread = threading.Timer(0, self.user)
self.user_thread.daemon = True
self.user_thread.start()
def user(self):
while True:
time.sleep(1)
print("arm:", self.armed, "mode:", self.mode)
print("set param:", self.set_param("CRUISE_SPEED", 2, 0))
if self.connected:
print("get param:", self.get_param("CRUISE_SPEED"))
self.change_mode(MODE_GUIDED)
self.arm(True)
self.move(50.15189, 10.484885, 0)
if __name__ == "__main__":
v = MyRoverHandler()
v.enable_topics_for_read()
v.connect("node1", rate=10)
This will create a node with the name of "node1" and then it will connect to the ArduRover vehicle you brought up via the former step, then it will set the value of "CRUISE_SPEED" parameter to 2 and then it will change the vehicle mode to "GUIDED". Then it will ARM the vehicle and then force the vehicle to move to the destination of {"lat":50.15189, "lon":10.484885}.
License
The source code generated by Masoud Iranmehr (@masoudir) is available under the permissive MIT License.
Project details
Release history Release notifications | RSS feed
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 mavros_python_examples-0.0.3.tar.gz
.
File metadata
- Download URL: mavros_python_examples-0.0.3.tar.gz
- Upload date:
- Size: 6.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.6.0 requests/2.24.0 setuptools/44.1.1 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/2.7.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6e1ee6f75c2379dd14a690484f41253b6150baf2baab036f559406ae2f8d79b4 |
|
MD5 | 27af0305e68128f4e16e5911f9fc992d |
|
BLAKE2b-256 | f8acf4c9a23eff12d91a3e266b80e7a8f4b0e9bb6edefebb53cea256f7cabe19 |
File details
Details for the file mavros_python_examples-0.0.3-py2-none-any.whl
.
File metadata
- Download URL: mavros_python_examples-0.0.3-py2-none-any.whl
- Upload date:
- Size: 7.8 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.6.0 requests/2.24.0 setuptools/44.1.1 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/2.7.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e63a9a04baab80f3e68c19359faf4fae1cb5d38889a9783eda251a7e9baf895c |
|
MD5 | 35a40046e3758be2f27b1d18eb6b0111 |
|
BLAKE2b-256 | dbd435a5b9dc6271c622dc841563d6781d616d0f155503161b1264be5d22b293 |