Optical Flow
Optical Flow uses a downward facing camera and a downward facing distance sensor for velocity estimation. It can be used to determine speed when navigating without GNSS — in buildings, underground, or in any other GNSS-denied environment.
The video below shows PX4 holding position using the Ark Flow sensor for velocity estimation in Position Mode:
The image below shows an optical flow setup with a separate flow sensor (PX4Flow) and distance sensor (Lidar-Lite):
Setup
An Optical Flow setup requires a downward facing camera and a downward facing distance sensor (preferably a LiDAR). These can be combined in a single product, such as the Ark Flow and Holybro H-Flow, or they may be separate sensors.
The sensor(s) can be connected via MAVLink, I2C or any other bus that supports the peripheral.
INFO
If connected to PX4 via MAVLink the Optical Flow camera sensor must publish the OPTICAL_FLOW_RAD message, and the distance sensor must publish the DISTANCE_SENSOR message. The information is written to the corresponding uORB topics: DistanceSensor and ObstacleDistance.
The output of the flow when moving in different directions must be as follows:
Vehicle movement | Integrated flow |
---|---|
Forwards | + Y |
Backwards | - Y |
Right | - X |
Left | + X |
Sensor data from the optical flow device is fused with other velocity data sources. The approach used for fusing sensor data and any offsets from the center of the vehicle must be configured in the estimator.
Scale Factor
For pure rotations the OPTICAL_FLOW_RAD.integrated_xgyro
and OPTICAL_FLOW_RAD.integrated_x
(respectively integrated_ygyro
and integrated_y
) have to be the same. If this is not the case, the optical flow scale factor can be adjusted using SENS_FLOW_SCALE.
TIP
The low resolution of common optical flow sensors can cause slow oscillations when hovering at a high altitude above ground (> 20m). Reducing the optical flow scale factor can improve the situation.
Flow Sensors/Cameras
ARK Flow
ARK Flow is a DroneCAN optical flow sensor, distance sensor, and IMU. It has a PAW3902 optical flow sensor, Broadcom AFBR-S50LV85D 30 meter distance sensor, and BMI088 IMU.
Holybro H-Flow
The Holybro H-Flow is a compact DroneCAN optical flow and distance sensor module. It combines a PixArt PAA3905 optical flow sensor, a Broadcom AFBR-S50LV85D distance sensor, and an InvenSense ICM-42688-P 6-axis IMU. An all-in-one design that simplifies installation, with an onboard infrared LED enhances visibility in low-light conditions.
PMW3901-Based Sensors
PMW3901 is an optical flow tracking sensor similar to what you would find in a computer mouse, but adapted to work between 80 mm and infinity. It is used in a number of products, including some from: Bitcraze, Tindie, Hex, Thone and Alientek.
Other Cameras/Sensors
It is also possible to use a board/quad that has an integrated camera. For this the Optical Flow repo can be used (see also snap_cam).
Range Finders
You can use any supported distance sensor. However we recommend using LIDAR rather than sonar sensors, because of their robustness and accuracy.
Estimators
Estimators fuse data from the optical flow sensor and other sources. The settings for how fusing is done, and relative offsets to vehicle center must be specified for the estimator used.
The offsets are calculated relative to the vehicle orientation and center as shown below:
Optical Flow based navigation is enabled by both EKF2 and LPE (deprecated).
Extended Kalman Filter (EKF2)
For optical flow fusion using EKF2, set EKF2_OF_CTRL.
If your optical flow sensor is offset from the vehicle centre, you can set this using the following parameters.
Parameter | Description |
---|---|
EKF2_OF_POS_X | X position of optical flow focal point in body frame (default is 0.0m). |
EKF2_OF_POS_Y | Y position of optical flow focal point in body frame (default is 0.0m). |
EKF2_OF_POS_Z | Z position of optical flow focal point in body frame (default is 0.0m). |
See Using the ECL EKF > Optical flow for more information.