robot_localization:使用

本文介绍robot_localization包的功能,支持多种传感器数据输入如Odometry、PoseWithCovarianceStamped等,并详细阐述了状态向量的构成。通过两种典型使用案例展示如何融合传感器数据创建精确的状态估计。此外还介绍了ekf_localization和ukf_localization节点的工作原理以及如何配置参数。

转自:https://blog.youkuaiyun.com/viphl/article/details/116651921

robot_localization包没有限制传感器的数据输入。

支持的状态估计节点数据类型:

• nav_msgs/Odometry
• geometry_msgs/PoseWithCovarianceStamped
• geometry_msgs/TwistWithCovarianceStamped
• sensor_msgs/Imu

状态向量:[x y z α β γ x˙ y˙ z˙ α˙ β˙ γ˙ ˙x˙ ˙y˙ ˙z˙](分别代表线速度,欧拉角,加速度,角加速度)

两种典型使用案例:

  • 融合连续的传感器数据(里程计和IMU)创建局部精确的状态估计
  • 融合连续的传感器数据及全局位姿估计来提供精确而完整的全局状态估计

状态估计节点

  • ekf_localization:扩展卡尔曼滤波
  • ukf_localization:无迹卡尔曼滤波

gps传感器预处理节点

navsat_transform_node:允许用户将地理坐标(纬度和经度)转换为机器人的世界框架(通常是map或odom)

TF树

协方差矩阵(包含初估计方差和噪声方差)

kf_localization_node

指明坐标框架

<param name="map_frame" value="map"/>
<param name="odom_frame" value="odom"/>
<param name="base_link_frame" value="base_link"/>
<param name="world_frame" value="odom"/>

传感器输入

<param name="odom0" value="/controller/odom"/>
<param name="odom1" value="/some/other/odom"/>
<param name="pose0" value="/altitude"/>
<param name="pose1" value="/some/other/pose"/>
<param name="pose2" value="/yet/another/pose"/>
<param name="twist0" value="/optical_flow"/>
<param name="imu0" value="/imu/left"/>
<param name="imu1" value="/imu/right"/>
<param name="imu2" value="/imu/front"/>
<param name="imu3" value="/imu/back"/>

协方差矩阵的输入

噪声方差

process_noise_covariance: [0.05, 0,    0,    0,    0,    0,    0,     0,     0,    0,    0,    0,    0,    0,    0,
                           0,    0.05, 0,    0,    0,    0,    0,     0,     0,    0,    0,    0,    0,    0,    0,
                           0,    0,    0.06, 0,    0,    0,    0,     0,     0,    0,    0,    0,    0,    0,    0,
                           0,    0,    0,    0.03, 0,    0,    0,     0,     0,    0,    0,    0,    0,    0,    0,
                           0,    0,    0,    0,    0.03, 0,    0,     0,     0,    0,    0,    0,    0,    0,    0,
                           0,    0,    0,    0,    0,    0.06, 0,     0,     0,    0,    0,    0,    0,    0,    0,
                           0,    0,    0,    0,    0,    0,    0.025, 0,     0,    0,    0,    0,    0,    0,    0,
                           0,    0,    0,    0,    0,    0,    0,     0.025, 0,    0,    0,    0,    0,    0,    0,
                           0,    0,    0,    0,    0,    0,    0,     0,     0.04, 0,    0,    0,    0,    0,    0,
                           0,    0,    0,    0,    0,    0,    0,     0,     0,    0.01, 0,    0,    0,    0,    0,
                           0,    0,    0,    0,    0,    0,    0,     0,     0,    0,    0.01, 0,    0,    0,    0,
                           0,    0,    0,    0,    0,    0,    0,     0,     0,    0,    0,    0.02, 0,    0,    0,
                           0,    0,    0,    0,    0,    0,    0,     0,     0,    0,    0,    0,    0.01, 0,    0,
                           0,    0,    0,    0,    0,    0,    0,     0,     0,    0,    0,    0,    0,    0.01, 0,
                           0,    0,    0,    0,    0,    0,    0,     0,     0,    0,    0,    0,    0,    0,    0.015]

 

估计方差

initial_estimate_covariance: [1e-9, 0,    0,    0,    0,    0,    0,    0,    0,    0,     0,     0,     0,    0,    0,
                              0,    1e-9, 0,    0,    0,    0,    0,    0,    0,    0,     0,     0,     0,    0,    0,
                              0,    0,    1e-9, 0,    0,    0,    0,    0,    0,    0,     0,     0,     0,    0,    0,
                              0,    0,    0,    1e-9, 0,    0,    0,    0,    0,    0,     0,     0,     0,    0,    0,
                              0,    0,    0,    0,    1e-9, 0,    0,    0,    0,    0,     0,     0,     0,    0,    0,
                              0,    0,    0,    0,    0,    1e-9, 0,    0,    0,    0,     0,     0,     0,    0,    0,
                              0,    0,    0,    0,    0,    0,    1e-9, 0,    0,    0,     0,     0,     0,    0,    0,
                              0,    0,    0,    0,    0,    0,    0,    1e-9, 0,    0,     0,     0,     0,    0,    0,
                              0,    0,    0,    0,    0,    0,    0,    0,    1e-9, 0,     0,     0,     0,    0,    0,
                              0,    0,    0,    0,    0,    0,    0,    0,    0,    1e-9,  0,     0,     0,    0,    0,
                              0,    0,    0,    0,    0,    0,    0,    0,    0,    0,     1e-9,  0,     0,    0,    0,
                              0,    0,    0,    0,    0,    0,    0,    0,    0,    0,     0,     1e-9,  0,    0,    0,
                              0,    0,    0,    0,    0,    0,    0,    0,    0,    0,     0,     0,     1e-9, 0,    0,
                              0,    0,    0,    0,    0,    0,    0,    0,    0,    0,     0,     0,     0,    1e-9, 0,
                              0,    0,    0,    0,    0,    0,    0,    0,    0,    0,     0,     0,     0,    0,    1e-9]

使用navsat_transform_node

过程

  • 将gps数据转换成UTM坐标
  • 使用初始的UTM坐标,EKF/UKF输出和IMU生成从UTM网格到机器人世界框架的(静态)变换T
  • 使用T变换所有测量的gps数据
  • 将数据发给EKF/UKF

需要的输入:
• nav_msgs/Odometry (EKF输出,需要机器人当前的位置)
• sensor_msgs/Imu (必须有陀螺仪,需要确定全局朝向)
• sensor_msgs/NavSatFix (从导航卫星设备输出)

相关设置

<param name="magnetic_declination_radians" value="0"/>
<param name="yaw_offset" value="0"/>
<param name="zero_altitude" value="true"/>
<param name="broadcast_utm_transform" value="true"/>
<param name="publish_filtered_gps" value="true"/>

转自:https://blog.youkuaiyun.com/viphl/article/details/116651921

### 配置和使用 `robot_localization` 包中的 EKF 为了正确配置和使用 `robot_localization` 包中的扩展卡尔曼滤波器 (EKF),需要遵循一系列具体的步骤,这些步骤涉及 ROS 工作环境的准备、包的安装以及参数文件的调整。 #### 安装依赖项 确保已安装必要的软件包。可以通过以下命令完成安装: ```bash sudo apt-get install ros-<your_ros_version>-robot-localization ``` 此命令会下载并安装适用于当前 ROS 版本的 `robot_localization` 软件包[^2]。 #### 参数配置 在实际应用中,`ekf_localization_node` 是核心组件之一,用于实现基于 EKF 的状态估计功能。以下是关键配置要点: 1. **定义输入源** 在 YAML 文件中指定传感器数据源及其对应的测量类型。例如,如果要融合 IMU 和 GPS 数据,则需分别声明它们的作用域及关联属性。 ```yaml frequency: 30 # 设置更新频率(Hz) sensor_timeout: 0.1 # 单位秒的最大等待时间 two_d_mode: false # 是否启用二维模式;默认为三维 transform_time_offset: 0.0 # 时间偏移量设定 imu0: /imu/data # 输入主题名称 imu0_config: [false, false, false, true, true, true, false, false, false, true, true, true, true, true, true] imu0_queue_size: 5 # 缓冲区大小 imu0_nodelay: false # 不延迟标志 ``` 上述片段展示了如何针对 IMU 设备进行细致化的选项定制[^4]^。 2. **初始化条件** 初始协方差矩阵反映了系统的不确定性程度。合理设置初始值有助于提高收敛性能。 ```yaml initial_estimate_covariance: [1e-9, 0, ..., 0 ] # 初始化误差分布表象 [... , ... ,..., ... ] process_noise_covariance: [...] # 过程噪声水平描述 ``` 3. **发布 TF 变换** 如果希望节点自动广播坐标系转换关系,则开启相应开关即可。 ```yaml publish_tf: true # 开启/关闭TF消息传播机制 odom_frame: odom # 输出参考框架标签名 base_link_frame: base_footprint # 移动平台基座参照物标识符 world_frame: odom # 全局地图或者局部里程计视图代号 ``` 通过上述方法能够有效构建起一套完整的定位解决方案体系结构[^3]^。 #### 示例代码展示 下面给出一段简单的启动脚本来加载预设好的参数集并与硬件交互操作起来。 ```xml <!-- launch file example --> <launch> <!-- Load the parameters from a yaml config file --> <param name="ekf_filter_node" command="$(find robot_localization)/scripts/configure_ekf.launch"/> <!-- Start up the actual filter node itself --> <node pkg="robot_localization" type="ekf_localization_node" name="ekf_se".../> </launch> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值