ROS:坐标管理系统

一、机器人中的坐标变换

机器人运动学的核心,描述任意两个坐标系之中任意两个向量之间的变换,可以用一个4×4的变换矩阵(Transformation Matrices)来描述它的平移和旋转变化。
变换矩阵中有包括旋转矩阵(Rotation Matrix)的信息和位置移动(Translation)的信息。
在这里插入图片描述

二、TF功能包

2.1TF功能包简介

一个机器人中,可以有很多坐标系,我们需要去描述任意两个坐标系之间的关系,涉及到大量的矩阵运算。我们可以用ROS中的TF(Transform)功能包来解决问题。
在这里插入图片描述
TF功能包的特点:默认能记录10秒内机器人所有坐标系之间的位置关系。
如:
5秒钟之前,机器人头部坐标系相对于全局坐标系的关系是什么样的?
机器人夹取的物体相对于机器人中心坐标系的位置在哪里?
机器人中心坐标系相对于全局坐标系的位置在哪里?

2.2TF坐标变换实现

实现机制:
广播TF变换
监听TF变换

这有别于之前topic和service的机制。
在ROS Master启动后,启动TF后,会在后台维护一个名为“TF树(TF Tree)”的数据结构。所有的坐标系都是通过树形结构保存在这个树结构当中,当有结点想查询某两个坐标系之间的关系的话,直接可以查询这个TF Tree来得到。

2.3TF案例

在这里插入图片描述
比如这辆带激光雷达的车,车体是以base_link为坐标系的,激光雷达是以base_laser为坐标系的,可以看到base_laser是base_link向x轴平移了0.1m,向z轴平移了0.2m,y轴没有平移。
当base_laser测到离墙面的距离为0.3m,即向量(0.3,0,0)时,就可以根据图下方的TF tree进行坐标系之间的数据变换的运算,从而算出base_link的相对与测距点的相对向量(0.4,0,0.2)。

三、小海龟跟随实验

3.1打开小程序

roslaunch turtle_tf turtle_tf_demo.launch

注:第一次运行可能会报错
报错的原因可能是Python解释器的指向问题。
打开终端依次输入:

cd /usr/bin/
sudo rm -r python
sudo cp python3 python

在这里插入图片描述
打开后就会有两只海龟,直接用键盘操作一只海龟前进,另一只会跟过来。
在这里插入图片描述

3.2查看当前的TF树

查看当前的TF tree,查看一下坐标系之间的关系。

rosrun tf view_frames

在这里插入图片描述
注:noetic直接运行可能会报错,无法生成pdf文件。解决方案:
先打开它指向的那个view_frames文件的修改权限:

sudo chmod a+w /opt/ros/noetic/lib/tf/view_frames

打开,88行后加上

vstr = str(vstr)

在这里插入图片描述
加上后重新运行。
可在用户文件夹下生成一个pdf文件:
在这里插入图片描述

可以看到有3个坐标系,除了两个海龟自身的坐标系,还有个world坐标系。
这颗TF树展示了当前的坐标间的位置关系,turtle1和turtle2是相对world坐标系变化的。
在这里插入图片描述

3.3坐标相对位置关系可视化1(tf_echo)

想看两个海龟的相对变换关系,输入:

rosrun tf tf_echo turtle1 turtle2

在这里插入图片描述
我们接着操控海龟1移动,相对关系就发生了变化:
在这里插入图片描述
这里包含了Translation和Rotation的信息。
Translation表示了相对位移的信息(是一个3×1的向量)。
Rotation表示了旋转矩阵的信息(一个3×3的矩阵,但自由度为3),它又有两种表示方式:
1.RPY表示法(pitch俯仰角、yaw偏航角、roll翻滚角)
2.四元数法(Quaternion)
都可以表示旋转矩阵的信息

Rotation和Translation合起来可以构成变换矩阵

3.4坐标相对位置关系可视化2(rviz)

rviz命令

rosrun rviz rviz -d `rospack find turtle_tf` /rviz/turtle_rviz.rviz

在这里插入图片描述
打开rviz界面。
上面Fixed Frame选 world。Add选添加TF,可以看到3个坐标系了。
在这里插入图片描述
控制海龟运动,坐标系发生改变,然后坐标系turtle2原点会靠近turtle1原点:
在这里插入图片描述
在这里插入图片描述
下图中左边变换矩阵的运算,其实就是坐标移动的本质。两个坐标系相对于world坐标系的变换的乘积可以求得两个坐标系相对的变换关系。
在这里插入图片描述
参考视屏:古月居ROS入门21讲
在这里插入图片描述

### RVIZ 运行时无 TF 数据解决方案 当遇到 RVIZ 中显示 `No tf data` 的错误提示,通常意味着系统未能接收到必要的坐标变换数据。这可能是由于多种原因造成的,括但不限于: - 缺少发布静态或动态转换的节点 - 节点配置不正确 - 时间同步问题 - 订阅者和发布者的频率不同步 #### 诊断方法 为了排查具体的原因,可以先尝试启动一些基础工具来验证是否存在有效的 TF 发布源。例如,可以通过命令行运行缓冲区服务器和其他辅助工具[^1]: ```bash ros2 run tf2_ros buffer_server ``` 如果仍然无法解决问题,则可能需要进一步检查是否有其他必需的服务正在运行。 #### 创建并测试简单的TF广播器 对于初学者来说,最简单的方法是从零开始构建一个能够正常工作的最小化示例环境。按照官方教程创建一个新的 ROS ,并实现基本的功能,比如设置两个框架之间的固定关系[^3]: ```bash cd ~/catkin_ws/src catkin_create_pkg learning_tf roscpp rospy tf turtlesim ``` 接着,在此内编写代码以定期发送已知置变化的消息给 `/tf` 主题。这样可以帮助确认整个流程是否通畅以及定潜在的问题所在。 #### 使用正确的消息类型 值得注意的是,在ROS 2中应该采用 `geometry_msgs/TransformStamped` 类型作为传输载体而不是旧版本中的自定义结构体[^2]。因此,请确保所有涉及的数据交换都遵循这一标准。 #### 实现监听功能 最后一步是建立订阅机制以便接收来自上述过程产生的更新通知。下面是一个Python脚本片段用于展示如何完成这项工作: ```python import rclpy from geometry_msgs.msg import TransformStamped from tf2_ros.buffer import Buffer from tf2_ros.transform_listener import TransformListener def main(args=None): rclpy.init() node = rclpy.create_node('my_tf2_listener') buffer = Buffer() listener = TransformListener(buffer, node) while True: try: trans: TransformStamped = buffer.lookup_transform( 'world', 'object_frame', time=rclpy.time.Time()) print(f'Position of object relative to world frame is {trans}') except Exception as e: pass if __name__ == '__main__': main() ``` 通过以上步骤应当能有效解决大部分情况下RVIZ报告缺少TF信息的情况。当然实际操作过程中还需要考虑更多细节因素的影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hello xiǎo lěi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值