Multi-Vehicle Simulation with FlightGear
WARNING
This simulator is community supported and maintained. It may or may not work with current versions of PX4.
See Toolchain Installation for information about the environments and tools supported by the core development team.
This topic explains how to simulate multiple vehicles using FlightGear in SITL. All vehicle instances have parameters defined by their startup scripts.
This is the most environmentally realistic way to simulate multiple vehicles running PX4, and allows easy testing of multiple different types of vehicles. It is suitable for testing multi-vehicle support in QGroundControl, MAVSDK, etc.
Multi-Vehicle Simulation with Gazebo Classic should be used instead for: swarm simulations with many vehicles, and testing features like computer vision that are only supported by Gazebo Classic.
How to Start Multiple Instances
To start multiple instances (on separate ports and IDs):
Checkout the PX4 branch that supports multiple vehicles (at ThunderFly-aerospace):
shgit clone https://github.com/ThunderFly-aerospace/PX4Firmware.git cd PX4Firmware git checkout flightgear-multi
Build the PX4 Firmware using the standard toolchain (with FlightGear installed).
Start the first instance using the predefined scripts:
shcd ./Tools/flightgear_bridge/scripts ./vehicle1.sh
Start subsequent instances using another script:
sh./vehicle2.sh
Each instance should have its own startup script, which can represent a completely different vehicle type. For prepared scripts you should get the following view.
Ground stations such as QGroundControl connect to all instances using the normal UDP port 14550 (all traffic goes to the same port).
The number of simultaneously running instances is limited mainly by computer resources. FlightGear is a single-thread application, but aerodynamics solvers consume a lot of memory. Therefore splitting to multiple computers and using a multiplayer server is probably required to run many vehicle instances.
Additional Resources
- See Simulation for more information about the port configuration.