Simulators allow PX4 flight code to control a computer modeled vehicle in a simulated "world". You can interact with this vehicle just as you might with a real vehicle, using QGroundControl, an offboard API, or a radio controller/gamepad.
Tip Simulation is a quick, easy, and most importantly, safe way to test changes to PX4 code before attempting to fly in the real world. It is also a good way to start flying with PX4 when you haven't yet got a vehicle to experiment with.
PX4 supports both Software In the Loop (SITL) simulation, where the flight stack runs on computer (either the same computer or another computer on the same network) and Hardware In the Loop (HITL) simulation using a simulation firmware on a real flight controller board.
Information about available simulators and how to set them up are provided in the next section. The other sections provide general information about how the simulator works, and are not required to use the simulators.
The following simulators work with PX4 for HITL and/or SITL simulation.
Simulator | Description |
---|---|
Gazebo | This simulator is highly recommended. A powerful 3D simulation environment that is particularly suitable for testing object-avoidance and computer vision. It can also be used for multi-vehicle simulation and is commonly used with ROS, a collection of tools for automating vehicle control. Supported Vehicles: Quad (Iris and Solo), Hex (Typhoon H480), Generic quad delta VTOL, Tailsitter, Plane, Rover, Submarine (coming soon!) |
jMAVSim | A simple multirotor simulator that allows you to fly copter type vehicles around a simulated world. It is easy to set up and can be used to test that your vehicle can take off, fly, land, and responds appropriately to various fail conditions (e.g. GPS failure). It can also be used for multi-vehicle simulation. Supported Vehicles: Quad |
AirSim | A cross platform simulator that provides physically and visually realistic simulations. This simulator is resource intensive, and requires a very significantly more powerful computer than the other simulators described here. Supported Vehicles: Iris (MultiRotor model and a configuration for PX4 QuadRotor in the X configuration). |
XPlane (HITL only) | A comprehensive and powerful fixed-wing flight simulator that offers very realistic flight models. Supported Vehicles: Plane |
Instructions for how to setup and use the simulators are in the topics linked above.
The remainder of this topic is a "somewhat generic" description of how the simulation infrastructure works. It is not required to use the simulators.
All simulators communicate with PX4 using the Simulator MAVLink API. This API defines a set of MAVLink messages that supply sensor data from the simulated world to PX4 and return motor and actuator values from the flight code that will be applied to the simulated vehicle. The image below shows the message flow.
Note A SITL build of PX4 uses simulator_mavlink.cpp to handle these messages while a hardware build in HIL mode uses mavlink_receiver.cpp. Sensor data from the simulator is written to PX4 uORB topics. All motors / actuators are blocked, but internal software is fully operational.
The messages are described below (see links for specific detail).
Message | Direction | Description |
---|---|---|
MAV_MODE:MAV_MODE_FLAG_HIL_ENABLED | NA | Mode flag when using simulation. All motors/actuators are blocked, but internal software is fully operational. |
HIL_ACTUATOR_CONTROLS | PX4 to Sim | PX4 control outputs (to motors, actuators). |
HIL_SENSOR | Sim to PX4 | Simulated IMU readings in SI units in NED body frame. |
HIL_GPS | Sim to PX4 | The simulated GPS RAW sensor value. |
HIL_OPTICAL_FLOW | Sim to PX4 | Simulated optical flow from a flow sensor (e.g. PX4FLOW or optical mouse sensor) |
HIL_STATE_QUATERNION | Sim to PX4 | Contains the actual "simulated" vehicle position, attitude, speed etc. This can be logged and compared to PX4's estimates for analysis and debugging (for example, checking how well an estimator works for noisy (simulated) sensor inputs). |
HIL_RC_INPUTS_RAW | Sim to PX4 | The RAW values of the RC channels received. |
By default, PX4 uses commonly established UDP ports for MAVLink communication with ground control stations (e.g. QGroundControl), Offboard APIs (e.g. DroneCore, MAVROS) and simulator APIs (e.g. Gazebo). These ports are:
- Port 14540 is used for communication with offboard APIs. Offboard APIs are expected to listen for connections on this port.
- Port 14550 is used for communication with ground control stations. GCS are expected to listen for connections on this port. QGroundControl listens to this port by default.
- Port 14560 is used for communication with simulators. PX4 listens to this port, and simulators are expected to initiate the communication by broadcasting data to this port.
Note The ports for the GCS and offboard APIs are set in configuration files, while the simulator broadcast port is hard-coded in the simulation MAVLink module.
The diagram below shows a typical SITL simulation environment for any of the supported simulators. The different parts of the system connect via UDP, and can be run on either the same computer or another computer on the same network.
- PX4 uses a simulation-specific module to listen on UDP port 14560. Simulators connect to this port, then exchange information using the Simulator MAVLink API described above. PX4 on SITL and the simulator can run on either the same computer or different computers on the same network.
- PX4 uses the normal MAVLink module to connect to GroundStations (which listen on port 14550) and external developer APIs like DroneCore or ROS (which listen on port 14540).
- A serial connection is used to connect Joystick/Gamepad hardware via QGroundControl.
If you use the normal build system SITL make
configuration targets (see next section) then both SITL and the Simulator will be launched on the same computer and the ports above will automatically be configured. You can configure additional MAVLink UDP connections and otherwise modify the simulation environment in the build configuration and initialisation files.
The build system makes it very easy to build and start PX4 on SITL, launch a simulator, and connect them. For example, you can launch a SITL version of PX4 that uses the EKF2 estimator and simulate a plane in Gazebo with just the following command (provided all the build and gazebo dependencies are present!):
make posix_sitl_default gazebo_plane
Tip It is also possible to separately build and start SITL and the various simulators, but this is nowhere near as "turnkey".
The syntax to call make
with a particular configuration and initialisation file is:
make [CONFIGURATION_TARGET] [VIEWER_MODEL_DEBUGGER]
where:
-
CONFIGURATION_TARGET: has the format
[OS_][PLATFORM][_FEATURE]
- OS: posix, nuttx, qurt
- PLATFORM: sitl (or in principle any platform supported among the different OS: bebop, eagle, excelsior, etc.)
- FEATURE: A particular high level feature - for example to cross-compile or to run tests. In most cases this is
default
.
Tip You can get a list of all available configuration targets using the command:
make list_config_targets
-
VIEWER_MODEL_DEBUGGER: has the format
[SIMULATOR]_[MODEL][_DEBUGGER]
- SIMULATOR: This is the simulator ("viewer") to launch and connect:
gazebo
,jmavsim
- MODEL: The vehicle model to use (e.g.
iris
,rover
,tailsitter
, etc). The environment variablePX4_SIM_MODEL
will be set to the selected model, which is then used in the startup script to select appropriate parameters. It also ensures that the simulator (gazebo) loads the correct model (we explain how to find available options in the next section). - DEBUGGER: Debugger to (optionally) use:
none
,ide
,gdb
,lldb
,ddd
,valgrind
,callgrind
. For more information see Simulation Debugging.
Tip You can get a list of all available
VIEWER_MODEL_DEBUGGER
options using the command:make posix list_vmd_make_targets
- SIMULATOR: This is the simulator ("viewer") to launch and connect:
Notes:
- Most of the values in the
CONFIGURATION_TARGET
andVIEWER_MODEL_DEBUGGER
have defaults, and are hence optional. For example,gazebo
is equivalent togazebo_iris
orgazebo_iris_none
. - You can use three underscores if you want to specify a default value between two other settings.
For example,
gazebo___gdb
is equivalent togazebo_iris_gdb
. - You can use a
none
value forVIEWER_MODEL_DEBUGGER
to start PX4 and wait for a simulator. For example start PX4 usingmake posix_sitl_default none
and jMAVSim using./Tools/jmavsim_run.sh
.
The simulation can be further configured via environment variables:
PX4_ESTIMATOR
: This variable configures which estimator to use. Possible options are:ekf2
(default),lpe
,inav
. It can be set viaexport PX4_ESTIMATOR=lpe
before running the simulation.
Scripts are used to control which parameter settings to use or which modules to start.
They are located in the ROMFS/px4fmu_common/init.d-posix directory, the rcS
file is the main entry point. See System Startup for more information.
With Hardware-in-the-Loop (HITL) simulation the normal PX4 firmware is run on real hardware. The HITL Simulation Environment in documented in: HITL Simulation.
QGroundControl desktop versions can connect to a USB Joystick/Gamepad and send its movement commands and button presses to PX4 over MAVLink. This works on both SITL and HITL simulations, and allows you to directly control the simulated vehicle. If you don't have a joystick you can alternatively control the vehicle using QGroundControl's onscreen virtual thumbsticks.
For setup information see the QGroundControl User Guide:
PX4 supports capture of both still images and video from within the Gazebo simulated environment. This can be enabled/set up as described in Gazebo > Video Streaming.
The simulated camera is a gazebo plugin that implements the MAVLink Camera Protocol. PX4 connects/integrates with this camera in exactly the same way as it would with any other MAVLink camera:
- TRIG_INTERFACE must be set to
3
to configure the camera trigger driver for use with a MAVLink cameraTip In this mode the driver just sends a CAMERA_TRIGGER message whenever an image capture is requested. For more information see Camera.
- PX4 must forward all camera commands between the GCS and the (simulator) MAVLink Camera. You can do this by starting mavlink with the
-f
flag as shown, specifying the UDP ports for the new connection.mavlink start -u 14558 -o 14530 -r 4000 -f -m camera
Note More than just the camera MAVLink messages will be forwarded, but the camera will ignore those that it doesn't consider relevant.
The same approach can be used by other simulators to implement camera support.