Enable selectively disabling sensors in the Gazebo bridge. (#25484)
Build all targets / Scan for Board Targets (push) Has been cancelled
Build all targets / Build Group [${{ matrix.group }}][${{ matrix.arch == 'nuttx' && 'x86' || 'arm64' }}] (push) Has been cancelled
Build all targets / Upload Artifacts to S3 (push) Has been cancelled
Build all targets / Create Release and Upload Artifacts (push) Has been cancelled
Checks / build (NO_NINJA_BUILD=1 px4_fmu-v5_default) (push) Has been cancelled
Checks / build (NO_NINJA_BUILD=1 px4_sitl_default) (push) Has been cancelled
Checks / build (check_format) (push) Has been cancelled
Checks / build (check_newlines) (push) Has been cancelled
Checks / build (module_documentation) (push) Has been cancelled
Checks / build (px4_fmu-v2_default stack_check) (push) Has been cancelled
Checks / build (px4_sitl_allyes) (push) Has been cancelled
Checks / build (shellcheck_all) (push) Has been cancelled
Checks / build (tests) (push) Has been cancelled
Checks / build (tests_coverage) (push) Has been cancelled
Checks / build (validate_module_configs) (push) Has been cancelled
Clang Tidy / build (push) Has been cancelled
MacOS build / build (px4_fmu-v5_default) (push) Has been cancelled
MacOS build / build (px4_sitl) (push) Has been cancelled
Ubuntu environment build / Build and Test (ubuntu:22.04) (push) Has been cancelled
Ubuntu environment build / Build and Test (ubuntu:24.04) (push) Has been cancelled
Container build / Set Tags and Variables (push) Has been cancelled
Container build / Build Container (amd64) (push) Has been cancelled
Container build / Build Container (arm64) (push) Has been cancelled
Container build / Deploy To Registry (push) Has been cancelled
EKF Update Change Indicator / unit_tests (push) Has been cancelled
Failsafe Simulator Build / build (failsafe_web) (push) Has been cancelled
FLASH usage analysis / Analyzing px4_fmu-v5x (push) Has been cancelled
FLASH usage analysis / Analyzing px4_fmu-v6x (push) Has been cancelled
FLASH usage analysis / Publish Results (push) Has been cancelled
ITCM check / Checking nxp_tropic-community (push) Has been cancelled
ITCM check / Checking px4_fmu-v5x (push) Has been cancelled
ITCM check / Checking px4_fmu-v6xrt (push) Has been cancelled
MAVROS Mission Tests / build (map[mission:MC_mission_box vehicle:iris]) (push) Has been cancelled
MAVROS Offboard Tests / build (map[test_file:mavros_posix_tests_offboard_posctl.test vehicle:iris]) (push) Has been cancelled
Nuttx Target with extra env config / build (px4_fmu-v5_default) (push) Has been cancelled
Python CI Checks / build (push) Has been cancelled
ROS Integration Tests / build (push) Has been cancelled
ROS Translation Node Tests / Build and test (map[ros_version:humble ubuntu:jammy]) (push) Has been cancelled
ROS Translation Node Tests / Build and test (map[ros_version:jazzy ubuntu:noble]) (push) Has been cancelled
SITL Tests / Testing PX4 tailsitter (push) Has been cancelled
SITL Tests / Testing PX4 iris (push) Has been cancelled
SITL Tests / Testing PX4 standard_vtol (push) Has been cancelled
Handle stale issues and PRs / stale (push) Has been cancelled
Fuzzing / Fuzzing (push) Has been cancelled

* Initial plan

* Add configurable sensor subscription parameters

Co-authored-by: Tuxliri <3532595+Tuxliri@users.noreply.github.com>

---------

Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: Tuxliri <3532595+Tuxliri@users.noreply.github.com>
This commit is contained in:
Davide Iafrate
2025-08-26 20:00:47 +02:00
committed by GitHub
parent 6ec8dec63a
commit ec436d3be3
3 changed files with 101 additions and 15 deletions
+28 -14
View File
@@ -90,32 +90,46 @@ int GZBridge::init()
}
// OPTIONAL:
if (!subscribeNavsat(false)) {
return PX4_ERROR;
if (_sim_gz_en_gps.get()) {
if (!subscribeNavsat(false)) {
return PX4_ERROR;
}
}
if (!subscribeAirPressure(false)) {
return PX4_ERROR;
if (_sim_gz_en_baro.get()) {
if (!subscribeAirPressure(false)) {
return PX4_ERROR;
}
}
if (!subscribeDistanceSensor(false)) {
return PX4_ERROR;
if (_sim_gz_en_lidar.get()) {
if (!subscribeDistanceSensor(false)) {
return PX4_ERROR;
}
}
if (!subscribeAirspeed(false)) {
return PX4_ERROR;
if (_sim_gz_en_aspd.get()) {
if (!subscribeAirspeed(false)) {
return PX4_ERROR;
}
}
if (!subscribeOpticalFlow(false)) {
return PX4_ERROR;
if (_sim_gz_en_flow.get()) {
if (!subscribeOpticalFlow(false)) {
return PX4_ERROR;
}
}
if (!subscribeOdometry(false)) {
return PX4_ERROR;
if (_sim_gz_en_odom.get()) {
if (!subscribeOdometry(false)) {
return PX4_ERROR;
}
}
if (!subscribeLaserScan(false)) {
return PX4_ERROR;
if (_sim_gz_en_lidar.get()) {
if (!subscribeLaserScan(false)) {
return PX4_ERROR;
}
}
// ESC mixing interface
@@ -194,6 +194,12 @@ private:
const float _vel_markov_time = 0.85f; // Velocity Markov process coefficient
DEFINE_PARAMETERS(
(ParamInt<px4::params::SIM_GPS_USED>) _sim_gps_used
(ParamInt<px4::params::SIM_GPS_USED>) _sim_gps_used,
(ParamInt<px4::params::SIM_GZ_EN_LIDAR>) _sim_gz_en_lidar,
(ParamInt<px4::params::SIM_GZ_EN_FLOW>) _sim_gz_en_flow,
(ParamInt<px4::params::SIM_GZ_EN_ASPD>) _sim_gz_en_aspd,
(ParamInt<px4::params::SIM_GZ_EN_BARO>) _sim_gz_en_baro,
(ParamInt<px4::params::SIM_GZ_EN_ODOM>) _sim_gz_en_odom,
(ParamInt<px4::params::SIM_GZ_EN_GPS>) _sim_gz_en_gps
)
};
@@ -39,3 +39,69 @@
* @group UAVCAN
*/
PARAM_DEFINE_INT32(SIM_GZ_EN, 0);
/**
* Enable laser/lidar sensors in Gazebo bridge
*
* @boolean
* @reboot_required true
* @group Simulation
* @value 0 Disabled
* @value 1 Enabled
*/
PARAM_DEFINE_INT32(SIM_GZ_EN_LIDAR, 1);
/**
* Enable optical flow sensor in Gazebo bridge
*
* @boolean
* @reboot_required true
* @group Simulation
* @value 0 Disabled
* @value 1 Enabled
*/
PARAM_DEFINE_INT32(SIM_GZ_EN_FLOW, 1);
/**
* Enable airspeed sensor in Gazebo bridge
*
* @boolean
* @reboot_required true
* @group Simulation
* @value 0 Disabled
* @value 1 Enabled
*/
PARAM_DEFINE_INT32(SIM_GZ_EN_ASPD, 1);
/**
* Enable barometer/air pressure sensor in Gazebo bridge
*
* @boolean
* @reboot_required true
* @group Simulation
* @value 0 Disabled
* @value 1 Enabled
*/
PARAM_DEFINE_INT32(SIM_GZ_EN_BARO, 1);
/**
* Enable odometry in Gazebo bridge
*
* @boolean
* @reboot_required true
* @group Simulation
* @value 0 Disabled
* @value 1 Enabled
*/
PARAM_DEFINE_INT32(SIM_GZ_EN_ODOM, 1);
/**
* Enable GPS/NavSat sensor in Gazebo bridge
*
* @boolean
* @reboot_required true
* @group Simulation
* @value 0 Disabled
* @value 1 Enabled
*/
PARAM_DEFINE_INT32(SIM_GZ_EN_GPS, 1);