From fcc7cde9185b89ac31ff2b6dc9880e22057b3cde Mon Sep 17 00:00:00 2001 From: Ismet Atabay <56237550+ismetatabay@users.noreply.github.com> Date: Tue, 3 Sep 2024 18:33:17 +0300 Subject: [PATCH] feat: add robosense Bpearl and Helios Lidar launch files for users (#102) Signed-off-by: ismetatabay --- .../launch/nebula_node_container.launch.py | 25 ++++++++----- .../launch/robosense_Bpearl.launch.xml | 37 +++++++++++++++++++ .../launch/robosense_Helios.launch.xml | 37 +++++++++++++++++++ 3 files changed, 90 insertions(+), 9 deletions(-) create mode 100644 common_sensor_launch/launch/robosense_Bpearl.launch.xml create mode 100644 common_sensor_launch/launch/robosense_Helios.launch.xml diff --git a/common_sensor_launch/launch/nebula_node_container.launch.py b/common_sensor_launch/launch/nebula_node_container.launch.py index 49e0b958..e885d92e 100644 --- a/common_sensor_launch/launch/nebula_node_container.launch.py +++ b/common_sensor_launch/launch/nebula_node_container.launch.py @@ -34,6 +34,8 @@ def get_lidar_make(sensor_name): return "Hesai", ".csv" elif sensor_name[:3].lower() in ["hdl", "vlp", "vls"]: return "Velodyne", ".yaml" + elif sensor_name.lower() in ["helios", "bpearl"]: + return "Robosense", None return "unrecognized_sensor_model" @@ -75,15 +77,18 @@ def create_parameter_dict(*args): nebula_decoders_share_dir = get_package_share_directory("nebula_decoders") # Calibration file - sensor_calib_fp = os.path.join( - nebula_decoders_share_dir, - "calibration", - sensor_make.lower(), - sensor_model + sensor_extension, - ) - assert os.path.exists( - sensor_calib_fp - ), "Sensor calib file under calibration/ was not found: {}".format(sensor_calib_fp) + if sensor_extension is not None: # Velodyne and Hesai + sensor_calib_fp = os.path.join( + nebula_decoders_share_dir, + "calibration", + sensor_make.lower(), + sensor_model + sensor_extension, + ) + assert os.path.exists( + sensor_calib_fp + ), "Sensor calib file under calibration/ was not found: {}".format(sensor_calib_fp) + else: # Robosense + sensor_calib_fp = "" # Pointcloud preprocessor parameters distortion_corrector_node_param = ParameterFile( @@ -129,6 +134,8 @@ def create_parameter_dict(*args): # cSpell:ignore knzo25 # TODO(knzo25): fix the remapping once nebula gets updated ("velodyne_points", "pointcloud_raw_ex"), + # ("robosense_points", "pointcloud_raw_ex"), #for robosense + # ("pandar_points", "pointcloud_raw_ex"), # for hesai ], extra_arguments=[{"use_intra_process_comms": LaunchConfiguration("use_intra_process")}], ) diff --git a/common_sensor_launch/launch/robosense_Bpearl.launch.xml b/common_sensor_launch/launch/robosense_Bpearl.launch.xml new file mode 100644 index 00000000..8fa49ef1 --- /dev/null +++ b/common_sensor_launch/launch/robosense_Bpearl.launch.xml @@ -0,0 +1,37 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/common_sensor_launch/launch/robosense_Helios.launch.xml b/common_sensor_launch/launch/robosense_Helios.launch.xml new file mode 100644 index 00000000..09addc20 --- /dev/null +++ b/common_sensor_launch/launch/robosense_Helios.launch.xml @@ -0,0 +1,37 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +