PX4 Vision Kit
Last updated
Last updated
The PX4 Vision Autonomy Development Kit is a robust and inexpensive kit for enabling computer vision development on autonomous vehicles.
The kit contains a near-ready-to-fly carbon-fiber quadcopter equipped with a Pixhawk 4 or Pixhawk 6C (on V1.5) flight controller, a UP Core companion computer (4GB memory & 64GB eMMC), and a Occipital Structure Core depth camera sensor.
:::note This vehicle comes with no pre-installed software. A USB stick is included in the kit with an example of an obstacle avoidance feature implementation, based on the PX4 Avoidance project. This example is intended as a reference only and serves to demonstrate the capabilities of the platform. The software is not compatible with the latest version of PX4, nor is it actively maintained or supported. :::
The guide explains the minimal additional setup required to get the vehicle ready to fly (installing an RC system and battery). It also covers the first flight, and how to get started with modifying the computer vision code.
The kit is intended for computer vision projects that use a forward-facing camera (it does not have downward or rear-facing depth cameras). Consequently it can’t be used (without modification) for testing Safe Landing, or other features that require a downward-facing camera.
Obstacle avoidance in missions can only be tested when GPS is available (missions use GPS coordinates). Collision prevention can be tested in position mode provided there is a good position lock from either GPS or optical flow.
The port labeled USB1
may jam the GPS if used with a USB3 peripheral (disable GPS-dependent functionality including missions). This is why the boot image is supplied on a USB2.0 memory stick.
PX4 Vision v1 with ECN 010 or above (carrier board RC05 and up), the UP Core can be powered by either the DC plug or with battery.
All PX4 Vision v1.5 UP Core can be powered by either the DC plug or with battery.
:::warning For PX4 Vision v1 with ECN below 010/carrier board below RC04, the UP Core should only be powered using the battery (do not remove the UP Core power socket safety cover). This does not apply to PX4 Vision v1.5
:::note Difference between the PX4 Vision V1 and V1.5 can be found here :::
What's inside the PX4 Vision V1 can be found here in the PX4 v1.13 Docs here.
The PX4 Vision DevKit contains following components:
Core Components:
1x Pixhawk 4 or Pixhawk 6C (for v1.5) flight controller
1x PMW3901 optical flow sensor
1x TOF Infrared distance sensor (PSK‐CM8JL65‐CC5)
1x Structure Core depth camera
160 deg wide vision camera
Stereo infrared cameras
Onboard IMU
Powerful NU3000 Multi-core depth Processor
1x UP Core computer (4GB memory & 64GB eMMC with Ubuntu and PX4 avoidance)
Intel® Atom™ x5-z8350 (up to 1.92 GHz)
Compatible OS: Microsoft Windows 10 full version, Linux (ubilinux, Ubuntu, Yocto), Android
FTDI UART connected to flight controller
USB1
: USB3.0 A port used for booting PX4 avoidance environment from a USB2.0 stick (connecting a USB3.0 peripheral may jam GPS).
USB2
: USB2.0 port on a JST-GH connector. Can be used for second camera, LTE, etc. (or keyboard/mouse during development).
USB3
: USB2.0 JST-GH port connected to depth camera
HDMI
: HDMI out
SD card slot
WiFi 802.11 b/g/n @ 2.4 GHz (attached to external antenna #1). Allows computer to access home WiFi network for Internet access/updates.
Mechanical Specification:
Frame: Full 5mm 3k carbon fiber twill
Motors: T-MOTOR KV1750
ESC: BEHEli-S 20A ESC
GPS: M8N GPS module
Power module: Holybro PM07
Wheelbase: 286mm
Weight: 854 grams without battery or props
Telemetry: ESP8266 connected to flight controller (attached to external antenna #2). Enables wireless connection to the ground station.
A USB2.0 stick with pre-flashed software that bundles:
Ubuntu 18.04 LTS
ROS Melodic
Occipital Structure Core ROS driver
MAVROS
Assorted cables, 8x propellers, 2x battery straps (installed) and other accessories (these can be used to attach additional peripherals).
The kit contains all the essential drone hardware except a battery and a radio control system, which must be purchased separately:
Battery:
4S LiPo with XT60 female connector
Less than 115mm long (to fit between power connector and GPS mast)
Radio control system
Any PX4-compatible RC System can be used.
An FrSky Taranis transmitter with R-XSR receiver is one of the more popular setups.
An H2.0 Hex Key (to unscrew the top plate so that an RC receiver can be connected)
In addition, users will need ground station hardware/software:
Laptop or tablet running QGroundControl (QGC).
Attach a compatible RC receiver to the vehicle (not supplied with kit):
Remove/unscrew the top plate (where the battery goes) using an H2.0 hex key tool.
Re-attach the top plate.
Mount the RC receiver on the UP Core carrier board plate at the back of the vehicle (use zipties or double-sided tape).
Ensure the antennas are clear of any obstructions and electrically isolated from the frame (e.g. secure them under the carrier board or to the vehicle arms or legs).
Bind the RC ground and air units (if not already done). The binding procedure depends on the specific radio system used (read the receiver manual).
Raise the GPS mast to the vertical position and screw the cover onto the holder on the base plate. (Not required for v1.5)
Insert the pre-imaged USB2.0 stick from the kit into the UP Core port labeled USB1
(highlighted below).
Power the vehicle with a fully charged battery. :::note Ensure propellers are removed before connecting the battery. :::
Connect the ground station to the vehicle WiFi network (after a few seconds) using the following default credentials:
SSID: pixhawk4
Password: pixhawk4
:::tip WiFi network SSID, password, and other credentials may be changed after connecting (if desired), by using a web browser to open the URL: http://192.168.4.1
. The baud rate must not be changed from 921600. :::
Start QGroundControl on the ground station.
Configure/calibrate the vehicle:
:::note The vehicle should arrive pre-calibrated (e.g. with firmware, airframe, battery, and sensors all setup). You will however need to calibrate the radio system (that you just connected) and it is often worth re-doing the compass calibration. :::
(Optional) Configure a Flight Mode selector switch on the remote controller.
:::note Modes can also be changed using QGroundControl :::
We recommend RC controller switches are define for:
Position Mode - a safe manual flight mode that can be used to test collision prevention.
Mission Mode - run missions and test obstacle avoidance.
Return Mode - return vehicle safely to its launch point and land.
Attach the propellers with the rotations as shown:
The propellers directions can be determined from the labels: 6045 (normal, counter-clockwise) and 6045R (reversed, clockwise).
Screw down firmly using the provided propellor nuts:
When the vehicle setup described above is complete:
Connect the battery to power the vehicle.
Wait until the boot sequence completes and the avoidance system has started (the vehicle will reject arming commands during boot).
:::tip The boot/startup process takes around 1 minute from the supplied USB stick (or 30 seconds from internal memory). :::
Check that the avoidance system has started properly:
The QGroundControl notification log displays the message: Avoidance system connected.
A red laser is visible on the front of the Structure Core camera.
Wait for the GPS LED to turn green. This means that the vehicle has a GPS fix and is ready to fly!
Connect the ground station to the vehicle WiFi network.
Find a safe outdoor location for flying, ideally with a tree or some other convenient obstacle for testing PX4 Vision.
To test collision prevention, enable Position Mode and fly manually towards an obstacle. The vehicle should slow down and then stop within 6m of the obstacle (the distance can be changed using the CP_DIST parameter).
To test obstacle avoidance, create a mission where the path is blocked by an obstacle. Then switch to Mission Mode to run the mission, and observe the vehicle moving around the obstacle and then returning to the planned course.
The following sections explain how to use the kit as an environment for developing computer vision software.
The PX4 Avoidance system consists of computer vision software running on a companion computer (with attached depth camera) that provides obstacle and/or route information to the PX4 flight stack running on a flight controller.
Documentation about the companion computer vision/planning software can be found on github here: PX4/PX4-Avoidance. The project provides a number of different planner implementations (packaged as ROS nodes):
The PX4 Vision Kit runs the localplanner by default and this is the recommended starting point for your own software.
The globalplanner has not been tested with this kit.
The landing planner requires a downward facing camera, and cannot used without first modifying the camera mounting.
PX4 and the companion computer exchange data over MAVLink using these interfaces:
Path Planning Interface - API for implementing avoidance features in automatic modes.
Collision Prevention Interface - API for vehicle based avoidance in manual position mode based on an obstacle map (currently used for collision prevention).
You can install the image on the UP Core and boot from internal memory (instead of the USB stick).
This is recommended because booting from internal memory is much faster, frees up a USB port, and may well provide more memory than your USB stick.
:::note Booting from internal memory takes around 30 seconds while booting from the supplied USB2 stick boots in about a minute (other cards may take several times longer). :::
To flash the USB image to the UP Core:
Insert the pre-flashed USB drive into the UP Core port labeled USB1
.
Login to the companion computer (as described above).
Open a terminal and run the following command to copy the image onto internal memory (eMMC). The terminal will prompt for a number of responses during the flashing process.
:::note All information saved in the UP Core computer will be removed when executing this script. :::
Pull out the USB stick.
Restart the vehicle. The UP Core computer will now boot from internal memory (eMMC).
First insert the provided USB2.0 stick into the UP Core port labeled USB1
, and then power the vehicle using a 4S battery. The avoidance system should start within about 1 minute (though this does depend on the USB stick supplied).
:::tip Fly the Drone with Avoidance additionally explains how to verify that the avoidance system is active. :::
If you've already installed the image on the companion computer you can just power the vehicle (i.e. no USB stick is needed). The avoidance system should be up and running within around 30 seconds.
Once started the companion computer can be used both as a computer vision development environment and for running the software.
To login to the companion computer:
Connect a keyboard and mouse to the UP Core via port USB2
:
Use the USB-JST cable from the kit to get a USB A connector
A USB hub can be attached to the cable if the keyboard and mouse have separate connectors.
Connect a monitor to the UP Core HDMI port.
The Ubuntu login screen should then appear on the monitor.
Login to the UP Core using the credentials:
Username: px4vision
Password: px4vision
The PX4 Vision’s UP Core computer provides a complete and fully configured environment for extending PX4 Avoidance software (and more generally, for developing new computer vision algorithms using ROS 2). You should develop and test your software on the vehicle, sync it to your own git repository, and share any fixes and improvements with the wider PX4 community on the github PX4/PX4-Avoidance repo.
The catkin workspace is at ~/catkin_ws
, and is preconfigured for running the PX4 avoidance local planner. The launch-from-boot file (avoidance.launch
) is in the px4vision_ros
package (modify this file to change what planner is launched).
The avoidance package is started on boot. To integrate a different planner, this needs to be disabled.
Disable the avoidance process using the following command:
You can simply reboot the machine to restart the service.
Other useful commands are:
The source code of the obstacle avoidance package can be found in https://github.com/PX4/PX4-Avoidance which is located in ~/catkin_ws/src/avoidance
.
Make changes to the code! To get the latest code of avoidance pull the code from the avoidance repo:
Build the package
The ROS workspace is placed in ~/catkin_ws
. For reference on developing in ROS and using the catkin workspace, see the ROS catkin tutorials.
The kit is designed for creating computer vision software that runs on the companion computer, and which integrates with PX4’s flexible path planning and collision prevention interfaces.
You can also modify PX4 itself, and install it as custom firmware:
You will need to connect QGroundControl to the kit's Pixhawk via USB in order to update firmware.
:::note Modification of PX4 code is not needed to meet most computer vision use cases. To discuss the interfaces or how to integrate other features join the PX4 support channels. :::
Information for the PX4 Vision 1.15 can be found at https://docs.holybro.com. The carrier board pinouts and other information are in the downloads section.
UP Core Wiki - Up Core companion computer technical information
Occipital Developer Forum - Structure Core camera information
For hardware issues, please contact Holybro at: productservice@holybro.com.
For software issues, use the following community support channels:
:::
Select the PX4 Vision DevKit airframe after loading new firmware: