PX4 FLOW (COM16) Driver Download For Windows



PX4 is the Professional Autopilot. Developed by world-class developers from industry and academia, and supported by an active world wide community, it powers all kinds of vehicles from racing and cargo drones through to ground vehicles and submersibles. OPTICALFLOW.flowcompmx etc. In both telemetry and dataflash logs didn't look right. In both cases, the values reported by the Copter didn't look right (values were too small, biased towards one direction only, less frequently updated, etc.). Although they look OK if you connect to PX4FLOW and look at the mavlink data directly. NVIDIA Optical Flow SDK Turing hardware generated optical flow map sample - source footage Optical Flow SDK exposes the latest hardware capability of Turing GPUs dedicated to computing the relative motion of pixels between images. The hardware uses sophisticated algorithms to yield highly accurate flow vectors, which are robust to frame-to-frame intensity variations, and track the true. Drivers Installer for PX4 FLOW (COM16) If you don’t want to waste time on hunting after the needed driver for your PC, feel free to use a dedicated self-acting installer. It will select only qualified and updated drivers for all hardware parts all alone. To download SCI Drivers Installer, follow this link.

The camera trigger driver allows the use of the AUX ports to send out pulses in order to trigger a camera. This can be used for multiple applications including timestamping photos for aerial surveying and reconstruction, synchronising a multi-camera system or visual-inertial navigation.

In addition to a pulse being sent out, a MAVLink message is published containing a sequence number (thus the current session's image sequence number) and the corresponding timestamp.

Trigger Modes/Configuration

Trigger Modes

Four different modes are supported, controlled by the TRIG_MODE parameter:

ValueDescription
0Camera triggering is disabled.
1Camera triggered on time interval ('intervalometer'). Triggering can be enabled and disabled by using the MAV_CMD_DO_TRIGGER_CONTROL MAVLink command. See command interface for more details.
2Camera triggered on time interval. Triggering always enabled.
3Camera triggered based on distance. A shot is taken every time the set horizontal distance is exceeded. The minimum time interval between two shots is however limited by the set triggering interval.
4Triggers automatically when flying a survey in Mission mode.

If it is your first time enabling the camera trigger app, remember to reboot after changing the TRIG_MODE parameter.

Trigger Hardware Configuration

You can choose which AUX pins to use for triggering using the TRIG_PINS parameter. The default is 56, which means that trigger is enabled on AUX 5 and AUX 6.

DO NOT CHANGE THE DEFAULT VALUE OF TRIG_PINS IF YOU NEED ACTUATOR OUTPUTS.With TRIG_PINS set to its default value of 56, you can use the AUX pins 1, 2, 3 and 4 as actuator outputs (for servos/ESCs). Due to the way the hardware timers are handled (1234 and 56 are 2 different groups handled by 2 timers), this is the ONLY combination which allows the simultaneous usage of camera trigger and FMU actuator outputs.

Trigger Interface Backends

Px4 Flow (com16) Driver Download For Windows 8.1

The camera trigger driver supports several backends for triggering different types of camera interfaces. The type of camera can be specified using the TRIG_INTERFACE parameter:

ValueInterfaceDescription
1GPIO interfaceThe AUX outputs are pulsed high or low (depending on the TRIG_POLARITY parameter) every TRIG_INTERVAL duration. This can be used to trigger most standard machine vision cameras directly. Note that on PX4FMU series hardware (Pixhawk, Pixracer, etc.), the signal level on the AUX pins is 3.3v.
2Seagull MAP2 interfaceThis allows the use of the Seagull MAP2 to interface to a multitude of supported cameras. Pin 1 of the MAP2 should be connected to the lower AUX pin of TRIG_PINS (therefore, pin 1 to AUX 5 and pin 2 to AUX 6 by default). In this mode, PX4 also supports automatic power control and keep-alive functionalities of Sony Multiport cameras like the QX-1.
3MAVLink interfaceIn this mode, no actual hardware output is used - the driver only sends the CAMERA_TRIGGER MAVLink message (by default, if the MAVLink application is in onboard mode. Otherwise, a custom stream will need to be enabled). PX4 must separately forward all MAVLink camera messages from a GCS to a connected MAVLink camera.
4Generic PWM interfaceAllows the use of infrared triggers or servos to trigger your camera.

Other Parameters

  • TRIG_POLARITY - Relevant only while using the GPIO interface. Sets the polarity of the trigger pin. Active high means that the pin is pulled low normally and pulled high on a trigger event. Active low is vice-versa.
  • TRIG_INTERVAL - Defines the time between two consecutive trigger events in milliseconds.
  • TRIG_ACTIVATION_TIME - Defines the time in milliseconds the trigger pin is held in the 'active' state before returning to neutral. In PWM modes, the minimum is limited to 40 ms to make sure we always fit an activate pulse into the 50Hz PWM signal.

The full list of parameters pertaining to the camera trigger module can be found on the parameter reference page.

Trigger Command Interface

The camera trigger driver supports the following commands.

MAV_CMD_DO_TRIGGER_CONTROL

MAV_CMD_DO_TRIGGER_CONTROL - Accepted in TRIG_MODE 1 ('command controlled' mode).

Command ParameterDescription
Param #1Trigger enable/disable (set to 0 for enable, 1 for start)
Param #2Sequence reset (set to 1 to reset image sequence number, 0 to keep current sequence number)
Param #3Trigger pause/restart (set to 0 for pause, 1 for restart). Pausing does not switch off/retract the camera.

MAV_CMD_DO_DIGICAM_CONTROL

MAV_CMD_DO_DIGICAM_CONTROL - Accepted in all modes. This is used by the GCS to test-shoot the camera from the user interface. The trigger driver does not yet support all camera control parameters defined by the MAVLink spec.

Command ParameterDescription
Param #5Trigger one-shot command (set to 1 to trigger a single image frame)
Param #7Trigger test shot - not logged or forwarded to GCS for geotagging (set to 1 to trigger a test shot)

MAV_CMD_DO_SET_CAM_TRIGG_DIST

MAV_CMD_DO_SET_CAM_TRIGG_DIST - Accepted in 'mission controlled' mode (TRIG_MODE 4)

This command is auto-generated during missions to trigger the camera based on survey missions from the GCS.

Command ParameterDescription
Param #1Trigger distance between shots (if >0). 0: triggering paused. -1: triggering disabled.
Param #2Trigger activation time in ms - for GPIO mode only (TRIG_INTERFACE 1)
Param #2Trigger single shot immediately (if >0)

MAV_CMD_DO_SET_CAM_TRIGG_INTERVAL

MAV_CMD_DO_SET_CAM_TRIGG_INTERVAL - Accepted in 'mission controlled' mode (TRIG_MODE 4)

This command is auto-generated during missions to trigger the camera based on survey missions from the GCS.

Command ParameterDescription
Param #1Trigger interval time.
Param #2Shutter activation time in ms - for GPIO mode only (TRIG_INTERFACE 1)
Param #2Trigger single shot immediately (if >0)

Testing Trigger Functionality

Px4flow Windows 10 Driver

  • On the PX4 console:

  • From QGroundControl:

    Click on Trigger Camera in the main instrument panel. These shots are not logged or counted for geotagging.

Examples

Sony QX-1 example (Photogrammetry)

In this example, we will use a Seagull MAP2 trigger cable to interface to a Sony QX-1 and use the setup to create orthomosaics after flying a fully autonomous survey mission.

Trigger Settings

The camera trigger can be configured from the QGroundControlSettings tab > Camera page

  • TRIG_INTERFACE: 2, Seagull MAP2.
  • TRIG_MODE: 4, Mission controlled.

Px4 Flow (com16) Driver Download For Windows 10

Leave the rest of the parameters at their defaults.

You will need to connect the Seagull MAP2 to the auxiliary/FMU pins on your autopilot. Pin 1 goes to AUX 5, and Pin 2 to AUX 6. The other end of the MAP2 cable will go into the QX-1's 'MULTI' port.

Camera Configuration

We use a Sony QX-1 with a 16-50mm f3.5-5.6 lens for this example.

To avoid autofocus and metering lag when the camera is triggered, the following guidelines should be followed :

  • Manual focus to infinity
  • Set camera to continuous shooting mode
  • Manually set exposure and aperture
  • ISO should be set as low as possible
  • Manual white balance suitable for scene

Mission Planning

Geotagging

Download/copy the logfile and images from the flight and point QGroundControl to them. Then click Start Tagging.

You can verify the geotagging using a free online service like Pic2Map. Note that Pic2Map is limited to only 40 images.

Reconstruction

(com16)

We use Pix4D for 3D reconstruction.

Camera-IMU Sync Example (VIO)

PX4 FLOW (COM16) Driver Download For Windows

In this example, we will go over the basics of synchronising IMU measurements with visual data to build a stereo Visual-Inertial Navigation System (VINS). To be clear, the idea here isn't to take an IMU measurement exactly at the same time as we take a picture but rather to correctly time stamp our images so as to provide accurate data to our VIO algorithm.

The autopilot and companion have different clock bases (boot-time for the autopilot and UNIX epoch for companion), so instead of skewing either clock, we directly observe the time offset between the clocks. This offset is added or subtracted from the timestamps in the MAVLink messages (e.g HIGHRES_IMU) in the cross-middleware translator component (e.g Mavros on the companion and mavlink_receiver in PX4). The actual synchronisation algorithm is a modified version of the Network Time Protocol (NTP) algorithm and uses an exponential moving average to smooth the tracked time offset. This synchronisation is done automatically if Mavros is used with a high-bandwidth onboard link (MAVLink mode onboard).

For acquiring synchronised image frames and inertial measurements, we connect the trigger inputs of the two cameras to a GPIO pin on the autopilot. The timestamp of the inertial measurement from start of exposure and a image sequence number is recorded and sent to the companion computer (CAMERA_TRIGGER message), which buffers these packets and the image frames acquired from the camera. They are matched based on the sequence number (first image frame is sequence 0), the images timestamped (with the timestamp from the CAMERA_TRIGGER message) and then published.

The following diagram illustrates the sequence of events which must happen in order to correctly timestamp our images.

Step 1

First, set the TRIG_MODE to 1 to make the driver wait for the start command andreboot your FCU to obtain the remaining parameters.

Step 2

For the purposes of this example we will be configuring the trigger to operatein conjunction with a Point Grey Firefly MV camera running at 30 FPS.

  • TRIG_INTERVAL: 33.33 ms
  • TRIG_POLARITY: 0 (active low)
  • TRIG_ACT_TIME: 0.5 ms. The manual specifies it only has to be a minimum of 1 microsecond.
  • TRIG_MODE: 1, because we want our camera driver to be ready to receive images before starting to trigger. This is essential to properly process sequence numbers.
  • TRIG_PINS: 56, Leave default.

Step 3

Wire up your cameras to your AUX port by connecting the ground and signal pins to the appropriate place.

Step 4

You will have to modify your driver to follow the sequence diagram above. Public reference implementations for IDS Imaging UEye cameras and for IEEE1394 compliant cameras are available.