从录制到规划:手把手教你用CARLA录制点云,在Autoware中构建完整自动驾驶仿真闭环 从CARLA到Autoware构建自定义自动驾驶仿真场景的完整实践指南在自动驾驶技术快速迭代的今天仿真测试已成为算法验证不可或缺的环节。CARLA与Autoware作为开源仿真平台和自动驾驶框架的黄金组合为研究者提供了高度灵活的测试环境。本文将深入探讨如何从零构建一个完整的自定义仿真场景——从CARLA环境中的点云数据采集到Autoware中的高精地图制作与算法验证形成端到端的工作闭环。1. 场景设计与数据采集规划任何成功的仿真实验都始于清晰的场景定义。假设我们需要在CARLA的Town03地图中构建一个包含复杂十字路口的测试区域该区域具有以下特征不规则的交叉角度多车道合并与分流动态交通参与者交互数据采集前的关键准备工作CARLA环境配置# 启动CARLA服务器假设版本0.9.11 ./CarlaUE4.sh -prefernvidia -quality-levelEpic传感器配置方案传感器类型参数配置数据用途64线激光雷达水平FOV 360°, 垂直FOV 30°, 10Hz点云地图构建前视摄像头1920x1080, 90° FOV, 30Hz视觉基准验证IMU100Hz采样率初始位姿估计采集路径规划以十字路口为中心按8字形路线行驶3圈速度控制在20-30km/h以保证点云密度避开动态障碍物密集区域提示在数据采集前建议先使用CARLA的PythonAPI编写简单的数据采集脚本确保能完整覆盖目标区域。2. CARLA点云数据录制与处理数据采集是构建高精度仿真环境的基础。CARLA通过ROS bridge可以方便地将传感器数据录制为ROS bag包。完整录制流程启动ROS bridge连接CARLAroslaunch carla_ros_bridge carla_ros_bridge.launch town:Town03配置并启动传感器节点后开始录制关键话题rosbag record -O carla_lidar_data /carla/ego_vehicle/lidar /carla/ego_vehicle/odometry录制完成后需要对bag包进行预处理# 点云数据过滤示例使用PCL库 import pcl cloud pcl.load(raw_cloud.pcd) # 创建VoxelGrid滤波器对象 vox cloud.make_voxel_grid_filter() vox.set_leaf_size(0.1, 0.1, 0.1) # 设置体素大小 cloud_filtered vox.filter() pcl.save(cloud_filtered, filtered_cloud.pcd)常见问题解决方案问题现象可能原因解决方法点云出现空洞车辆速度过快降低采集车速增加重叠率点云边缘畸变传感器同步问题检查ROS时间同步配置建筑表面不平整动态物体干扰后期处理时手动移除动态点3. 高精地图构建与矢量标注获得高质量点云后下一步是将其转化为Autoware可用的高精地图。这需要两个关键组件点云地图和矢量地图。使用Vector Map Builder创建车道线导入处理后的PCD文件rosrun map_file points_map_loader points_map_loader.launch load_path:/path/to/filtered_cloud.pcd标注流程关键步骤使用lanelet2格式定义道路拓扑标注车道中心线确保连续性设置正确的交通规则属性验证拓扑连接关系导出Autoware兼容格式map_directory/ ├── lanelet2_map.osm ├── pointcloud_map.pcd └── traffic_rules.yaml车道标注注意事项相邻车道线应有5-10cm重叠交叉口区域需要明确划分通行区域确保所有车道都有正确的方向属性特殊区域如公交车道需要额外标注注意矢量地图的精度直接影响后续规划算法的表现建议至少进行三次交叉验证。4. Autoware仿真环境集成与测试完成地图制作后需要将其集成到Autoware的仿真环境中进行全链路验证。启动文件配置要点修改my_map_test.launch文件的关键参数arg namepath default$(env HOME)/autoware_map/custom_town03/ arg namepcd_name defaulttown03_processed.pcd/ !-- 点云地图加载 -- include file$(find map_file)/launch/points_map_loader.launch arg namepath_pcd value$(arg path)/$(arg pcd_name)/ /include !-- 矢量地图加载 -- node pkgmap_file typevector_map_loader namevector_map_loader args$(arg path)/dtlane.csv $(arg path)/lane.csv $(arg path)/line.csv $(arg path)/node.csv $(arg path)/point.csv $(arg path)/whiteline.csv/完整测试流程启动CARLA仿真环境./CarlaUE4.sh -prefernvidia -carla-server -world-port2000启动Autoware各模块# 感知层 roslaunch autoware_launch sensing.launch vehicle_model:lexus sensor_model:aip_xx1 # 定位层 roslaunch autoware_launch localization.launch map_path:/path/to/custom_map # 规划层 roslaunch autoware_launch planning.launch在RViz中设置测试路径使用2D Pose Estimate设置初始位置使用2D Nav Goal设置目标点监控规划轨迹与实际行驶的偏差典型问题排查表模块异常现象检查点定位车辆位置偏移TF树配置、初始位姿感知障碍物漏检传感器标定参数规划路径震荡地图拓扑连接性控制跟踪偏差车辆动力学参数5. 进阶技巧与性能优化当基础流程跑通后可以考虑以下优化手段提升仿真效果点云地图优化技巧使用NDT算法进行多帧配准应用地面分割提升定位精度动态物体去除算法比较# 基于统计滤波的离群点去除 sor cloud.make_statistical_outlier_filter() sor.set_mean_k(50) # 设置邻域点数 sor.set_std_dev_mul_thresh(1.0) # 标准差倍数阈值 cloud_filtered sor.filter()仿真加速方案使用CARLA的异步模式settings world.get_settings() settings.synchronous_mode False world.apply_settings(settings)简化传感器配置降低激光雷达线数减少摄像头分辨率调整更新频率自动化测试脚本示例import carla import rospy from autoware_msgs.msg import VehicleCmd def run_test_scenario(): # 初始化CARLA客户端 client carla.Client(localhost, 2000) world client.get_world() # 设置测试起点 spawn_point carla.Transform( carla.Location(x120.4, y195.3, z0.6), carla.Rotation(pitch0.0, yaw180.0, roll0.0)) # 通过ROS发送控制指令 pub rospy.Publisher(/vehicle_cmd, VehicleCmd, queue_size1) cmd VehicleCmd() cmd.ctrl_cmd.linear_velocity 5.0 # 5 m/s pub.publish(cmd)在实际项目中我们发现十字路口场景的仿真最关键的环节是矢量地图的拓扑关系定义。一个常见的错误是忽略了车道之间的连接关系导致规划算法无法生成合理路径。建议在完成地图制作后先用简单的测试用例验证基本连通性再逐步增加场景复杂度。