0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

机器人坐标系Launch文件解析

麦辣鸡腿堡 来源:古月居 作者:古月居 2023-11-22 17:44 次阅读

Launch文件解析

先来看下刚才运行的launch文件,里边启动了四个节点,分别是:

  • 小海龟仿真器
  • 海龟1的坐标系广播
  • 海龟2的坐标系广播
  • 海龟跟随控制

其中,两个坐标系的广播复用了turtle_tf_broadcaster节点,通过传入的参数名修改维护的坐标系名称。

learning_tf/launch/turtle_following_demo.launch.py

from launch import LaunchDescriptionfrom launch.actions import DeclareLaunchArgumentfrom launch.substitutions import LaunchConfigurationfrom launch_ros.actions import Nodedef generate_launch_description():    return LaunchDescription([        Node(            package='turtlesim',            executable='turtlesim_node',            name='sim'        ),        Node(            package='learning_tf',            executable='turtle_tf_broadcaster',            name='broadcaster1',            parameters=[                {'turtlename': 'turtle1'}            ]        ),        DeclareLaunchArgument(            'target_frame', default_value='turtle1',            description='Target frame name.'        ),        Node(            package='learning_tf',            executable='turtle_tf_broadcaster',            name='broadcaster2',            parameters=[                {'turtlename': 'turtle2'}            ]        ),        Node(            package='learning_tf',            executable='turtle_following',            name='listener',            parameters=[                {'target_frame': LaunchConfiguration('target_frame')}            ]        ),     ])

坐标系动态广播

海龟1和海龟2在world坐标系下的坐标变换,在turtle_tf_broadcaster节点中实现,除了海龟坐标系的名字不同之外,针对两个海龟的功能是一样的。

learning_tf/turtle_tf_broadcaster.py

#!/usr/bin/env python3# -*- coding: utf-8 -*-"""@作者: 古月居(www.guyuehome.com)@说明: ROS2 TF示例-广播动态的坐标变换"""import rclpy                                       # ROS2 Python接口from rclpy.node import Node                        # ROS2 节点类from geometry_msgs.msg import TransformStamped     # 坐标变换消息import tf_transformations                          # TF坐标变换库from tf2_ros import TransformBroadcaster           # TF坐标变换广播器from turtlesim.msg import Pose                     # turtlesim小海龟位置消息class TurtleTFBroadcaster(Node):    def __init__(self, name):        super().__init__(name)                                # ROS2节点父类初始化        self.declare_parameter('turtlename', 'turtle')        # 创建一个海龟名称的参数        self.turtlename = self.get_parameter(                 # 优先使用外部设置的参数值,否则用默认值            'turtlename').get_parameter_value().string_value        self.tf_broadcaster = TransformBroadcaster(self)      # 创建一个TF坐标变换的广播对象并初始化        self.subscription = self.create_subscription(         # 创建一个订阅者,订阅海龟的位置消息            Pose,            f'/{self.turtlename}/pose',                       # 使用参数中获取到的海龟名称            self.turtle_pose_callback, 1)    def turtle_pose_callback(self, msg):                              # 创建一个处理海龟位置消息的回调函数,将位置消息转变成坐标变换        transform = TransformStamped()                                # 创建一个坐标变换的消息对象        transform.header.stamp = self.get_clock().now().to_msg()      # 设置坐标变换消息的时间戳        transform.header.frame_id = 'world'                           # 设置一个坐标变换的源坐标系        transform.child_frame_id = self.turtlename                    # 设置一个坐标变换的目标坐标系        transform.transform.translation.x = msg.x                     # 设置坐标变换中的X、Y、Z向的平移        transform.transform.translation.y = msg.y        transform.transform.translation.z = 0.0        q = tf_transformations.quaternion_from_euler(0, 0, msg.theta) # 将欧拉角转换为四元数(roll, pitch, yaw)        transform.transform.rotation.x = q[0]                         # 设置坐标变换中的X、Y、Z向的旋转(四元数)        transform.transform.rotation.y = q[1]        transform.transform.rotation.z = q[2]        transform.transform.rotation.w = q[3]        # Send the transformation        self.tf_broadcaster.sendTransform(transform)     # 广播坐标变换,海龟位置变化后,将及时更新坐标变换信息def main(args=None):    rclpy.init(args=args)                                # ROS2 Python接口初始化    node = TurtleTFBroadcaster("turtle_tf_broadcaster")  # 创建ROS2节点对象并进行初始化    rclpy.spin(node)                                     # 循环等待ROS2退出    node.destroy_node()                                  # 销毁节点对象    rclpy.shutdown()                                     # 关闭ROS2 Python接口

完成代码的编写后需要设置功能包的编译选项,让系统知道Python程序的入口,打开功能包的setup.py文件,加入如下入口点的配置:

entry_points={        'console_scripts': [            'static_tf_broadcaster = learning_tf.static_tf_broadcaster:main',            'turtle_tf_broadcaster = learning_tf.turtle_tf_broadcaster:main',            'tf_listener = learning_tf.tf_listener:main',        ],    },

海龟跟随

坐标系都正常广播了,接下来我们就可以订阅两只海龟的位置关系,并且变换成速度指令进行控制啦。

learning_tf/turtle_following.py

#!/usr/bin/env python3# -*- coding: utf-8 -*-"""@作者: 古月居(www.guyuehome.com)@说明: ROS2 TF示例-通过坐标变化实现海龟跟随功能"""import mathimport rclpy                                              # ROS2 Python接口库from rclpy.node import Node                               # ROS2 节点类import tf_transformations                                 # TF坐标变换库from tf2_ros import TransformException                    # TF左边变换的异常类from tf2_ros.buffer import Buffer                         # 存储坐标变换信息的缓冲类from tf2_ros.transform_listener import TransformListener  # 监听坐标变换的监听器类from geometry_msgs.msg import Twist                       # ROS2 速度控制消息from turtlesim.srv import Spawn                           # 海龟生成的服务接口class TurtleFollowing(Node):    def __init__(self, name):        super().__init__(name)                                      # ROS2节点父类初始化        self.declare_parameter('source_frame', 'turtle1')           # 创建一个源坐标系名的参数        self.source_frame = self.get_parameter(                     # 优先使用外部设置的参数值,否则用默认值            'source_frame').get_parameter_value().string_value        self.tf_buffer = Buffer()                                   # 创建保存坐标变换信息的缓冲区        self.tf_listener = TransformListener(self.tf_buffer, self)  # 创建坐标变换的监听器        self.spawner = self.create_client(Spawn, 'spawn')           # 创建一个请求产生海龟的客户端        self.turtle_spawning_service_ready = False                  # 是否已经请求海龟生成服务的标志位        self.turtle_spawned = False                                 # 海龟是否产生成功的标志位        self.publisher = self.create_publisher(Twist, 'turtle2/cmd_vel', 1) # 创建跟随运动海龟的速度话题        self.timer = self.create_timer(1.0, self.on_timer)         # 创建一个固定周期的定时器,控制跟随海龟的运动    def on_timer(self):        from_frame_rel = self.source_frame                         # 源坐标系        to_frame_rel   = 'turtle2'                                 # 目标坐标系        if self.turtle_spawning_service_ready:                     # 如果已经请求海龟生成服务            if self.turtle_spawned:                                # 如果跟随海龟已经生成                try:                    now = rclpy.time.Time()                        # 获取ROS系统的当前时间                    trans = self.tf_buffer.lookup_transform(       # 监听当前时刻源坐标系到目标坐标系的坐标变换                        to_frame_rel,                        from_frame_rel,                        now)                except TransformException as ex:                   # 如果坐标变换获取失败,进入异常报告                    self.get_logger().info(                        f'Could not transform {to_frame_rel} to {from_frame_rel}: {ex}')                    return                msg = Twist()                                      # 创建速度控制消息                scale_rotation_rate = 1.0                          # 根据海龟角度,计算角速度                msg.angular.z = scale_rotation_rate * math.atan2(                    trans.transform.translation.y,                    trans.transform.translation.x)                scale_forward_speed = 0.5                          # 根据海龟距离,计算线速度                msg.linear.x = scale_forward_speed * math.sqrt(                    trans.transform.translation.x ** 2 +                    trans.transform.translation.y ** 2)                self.publisher.publish(msg)                        # 发布速度指令,海龟跟随运动            else:                                                  # 如果跟随海龟没有生成                if self.result.done():                             # 查看海龟是否生成                    self.get_logger().info(                        f'Successfully spawned {self.result.result().name}')                    self.turtle_spawned = True                                     else:                                              # 依然没有生成跟随海龟                    self.get_logger().info('Spawn is not finished')        else:                                                      # 如果没有请求海龟生成服务            if self.spawner.service_is_ready():                    # 如果海龟生成服务器已经准备就绪                request = Spawn.Request()                          # 创建一个请求的数据                request.name = 'turtle2'                           # 设置请求数据的内容,包括海龟名、xy位置、姿态                request.x = float(4)                request.y = float(2)                request.theta = float(0)                self.result = self.spawner.call_async(request)     # 发送服务请求                self.turtle_spawning_service_ready = True          # 设置标志位,表示已经发送请求            else:                self.get_logger().info('Service is not ready')     # 海龟生成服务器还没准备就绪的提示def main(args=None):    rclpy.init(args=args)                       # ROS2 Python接口初始化    node = TurtleFollowing("turtle_following")  # 创建ROS2节点对象并进行初始化    rclpy.spin(node)                            # 循环等待ROS2退出    node.destroy_node()                         # 销毁节点对象    rclpy.shutdown()                            # 关闭ROS2 Python接口

完成代码的编写后需要设置功能包的编译选项,让系统知道Python程序的入口,打开功能包的setup.py文件,加入如下入口点的配置:

entry_points={        'console_scripts': [            'static_tf_broadcast
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 机器人
    +关注

    关注

    206

    文章

    27043

    浏览量

    201423
  • 仿真器
    +关注

    关注

    14

    文章

    988

    浏览量

    82996
  • 坐标系
    +关注

    关注

    0

    文章

    29

    浏览量

    7239
  • ROS
    ROS
    +关注

    关注

    1

    文章

    271

    浏览量

    16682
收藏 人收藏

    评论

    相关推荐

    机器人坐标系的建立

    机器人的电机传动控制坐标系是怎样确定的,是基于什么控制原理,学习机器人的控制理论有哪些比较经典的书籍,求大神指导?
    发表于 06-10 17:03

    机器人与CCD

    labview 视觉机器人抓取工件 CCD相机的二维坐标系的建立?希望分享,谢谢
    发表于 08-18 20:53

    机器人底盘传感器位置坐标及底盘配置工具的使用

    可以在如下图所示位置找到。注意:在首次安装的时候需要将电脑连接网络,否则可能导致插件安装失败。 二、机器人底盘参考坐标系X轴方向为机器人前进方向,Z轴方向为垂直向上。X轴Y轴的零点为底盘的水平
    发表于 01-24 14:42

    KUKA机器人问题解答

    1 开机坐标系无效 世界坐标系是以枪头为基点,在这种坐标系机器人所有的动作都是按照以枪头为顶点来完成移动,XYZ方向切割枪方向不改变,如果机器人在
    发表于 07-15 07:48

    如何计算才能把坐标系转换成水平的坐标系

    当mpu6050初始放置的时候是倾斜的,如何计算才能把坐标系转换成水平的坐标系?转换后的效果是保证倾角不变,水平转动mpu,出来的数据是水平转动的。我用当前四元数与初始的四元数做差,得到的四元数坐标系还是与mpu
    发表于 07-31 22:19

    CAD制图软件新手攻略:坐标系及标注坐标

    浩辰CAD制图软件为绘图空间提供了一个绝对的坐标系,并称之为世界坐标系,这个坐标系存在于任何一个图形之中,而且不可更改。相对于世界坐标系,用户可根据需要创建无限多的CAD
    发表于 09-23 10:28

    解决电压方程在静止坐标系与运动坐标系转换问题

    本文将解决电压方程在静止坐标系与运动坐标系转换问题。本文将呈现的转换关系是电压方程由静止坐标系转换至运动坐标系,反之同理可证。
    发表于 08-27 07:17

    介绍坐标系机器人之间的纽带即连杆坐标系

    介绍坐标系以及它们之间的变换关系,数学的意味还是很浓的。讲了那么多的公式和规律,它们要怎么用在机器人上呢?这篇文章将介绍坐标系机器人之间的纽带即连杆
    发表于 09-01 06:17

    机器人坐标系标定方法研究

    针对借助激光跟踪仪标定机器人所涉及的坐标系统一问题,对基于空间几何法拟合建立的基坐标系机器人理论基坐标系的转换关系进行了研究,提出了一种基
    发表于 03-07 10:43 2次下载

    机器人4大坐标系讲解

    任何机器人都离不开基坐标系,也是机器人TCP在三维空间运动空间所必须的基本坐标系(面对机器人前后:X轴 ,左右:Y轴, 上下:Z轴)。
    的头像 发表于 05-14 09:56 2.2w次阅读
    <b class='flag-5'>机器人</b>4大<b class='flag-5'>坐标系</b>讲解

    带你来剖析机器人坐标系吧!

    大地坐标系:大地坐标系是以大地作为参考的直角坐标系。在多个机器人联动的和带有外轴的机器人会用到,90%的大地
    的头像 发表于 05-09 15:49 4153次阅读

    机器人坐标系用法和算法原理

    一般都会定义机器人第一轴的旋转轴为基坐标系Z轴,旋转中心即是坐标系原点,X和Y的方向是的电机零点确定,所以只要你不更换电机的零点和机械结构,单个机器人里这个基
    发表于 05-11 15:57 1150次阅读
    <b class='flag-5'>机器人</b><b class='flag-5'>坐标系</b>用法和算法原理

    深度剖析机器人的四大坐标系

    大地坐标系:大地坐标系是以大地作为参考的直角坐标系。在多个机器人联动的和带有外轴的机器人会用到,90%的大地
    发表于 11-13 11:24 882次阅读
    深度剖析<b class='flag-5'>机器人</b>的四大<b class='flag-5'>坐标系</b>

    机器人中都有哪些坐标系

    坐标系是我们非常熟悉的一个概念,也是机器人学中的重要基础,在一个完整的机器人系统中,会存在很多坐标系,这些坐标系之间的位置关系该如何管理?
    的头像 发表于 11-22 17:20 667次阅读
    <b class='flag-5'>机器人</b>中都有哪些<b class='flag-5'>坐标系</b>

    机器人坐标系管理TF跟随功能解析

    .py** ros2 run turtlesim turtle_teleop_key 看到的效果和ROS自带的例程相同。 原理解析 在两只海龟的仿真器中,我们可以定义三个坐标系,比如仿真器的全局参考系叫做
    的头像 发表于 11-22 17:35 273次阅读
    <b class='flag-5'>机器人</b><b class='flag-5'>坐标系</b>管理TF跟随功能<b class='flag-5'>解析</b>