ROS2中的QoS(Quality of Service)详解

  • 1. 主要QoS参数
  • 2. 为什么需要设置QoS
  • 3. QoS兼容性规则
  • 4. 选择QoS策略的建议
  • 5. 调试QoS问题的方法
  • 6. 踩坑:订阅话题没有输出
    • 可能的原因:
    • 调试方法

QoS是ROS2中用于控制通信质量和行为的机制。它定义了发布者和订阅者之间消息传递的各种策略和保证,包括可靠性、持久性、延迟等特性。

1. 主要QoS参数

  1. Reliability(可靠性)
# 两种模式:
QoSReliabilityPolicy.RELIABLE      # 可靠传输,确保消息送达
QoSReliabilityPolicy.BEST_EFFORT   # 尽力传输,不保证送达
  1. Durability(持久性)
QoSDurabilityPolicy.TRANSIENT_LOCAL  # 为新订阅者保留最后的消息
QoSDurabilityPolicy.VOLATILE         # 不保留消息
  1. History(历史记录)
QoSHistoryPolicy.KEEP_LAST   # 保留最后N条消息
QoSHistoryPolicy.KEEP_ALL    # 保留所有消息
  1. Depth(深度)
depth=10  # 消息队列深度

2. 为什么需要设置QoS

  1. 发布者和订阅者QoS必须兼容

ROS2中,发布者和订阅者的QoS设置必须兼容才能正常通信。不兼容的QoS设置会导致连接失败。

  1. 默认QoS差异
# ROS2不同API的默认QoS可能不同
# 有些默认是RELIABLE,有些是BEST_EFFORT

3. QoS兼容性规则

  1. Reliability兼容性
# 兼容组合:
Publisher: RELIABLE    <-> Subscriber: RELIABLE    ✓
Publisher: BEST_EFFORT <-> Subscriber: BEST_EFFORT ✓
Publisher: RELIABLE    <-> Subscriber: BEST_EFFORT ✓
Publisher: BEST_EFFORT <-> Subscriber: RELIABLE    ✗ (不兼容)
  1. Durability兼容性
# 兼容组合:
Publisher: TRANSIENT_LOCAL <-> Subscriber: TRANSIENT_LOCAL ✓
Publisher: VOLATILE        <-> Subscriber: VOLATILE        ✓
Publisher: TRANSIENT_LOCAL <-> Subscriber: VOLATILE        ✓
Publisher: VOLATILE        <-> Subscriber: TRANSIENT_LOCAL ✗ (不兼容)

4. 选择QoS策略的建议

  1. 传感器数据(如激光雷达、摄像头)
# 使用BEST_EFFORT,因为数据频率高,偶尔丢失可接受
qos_profile = QoSProfile(depth=10,reliability=QoSReliabilityPolicy.BEST_EFFORT,history=QoSHistoryPolicy.KEEP_LAST
)
  1. 控制命令
# 使用RELIABLE,确保命令不丢失
qos_profile = QoSProfile(depth=10,reliability=QoSReliabilityPolicy.RELIABLE,history=QoSHistoryPolicy.KEEP_LAST
)
  1. 配置参数
# 使用TRANSIENT_LOCAL,新订阅者可以获得最后的配置
qos_profile = QoSProfile(depth=1,reliability=QoSReliabilityPolicy.RELIABLE,durability=QoSDurabilityPolicy.TRANSIENT_LOCAL,history=QoSHistoryPolicy.KEEP_LAST
)

5. 调试QoS问题的方法

  1. 检查QoS兼容性
# 查看话题的QoS信息
ros2 topic info /inner/information/object_computation -v
  1. 使用QoS分析工具
# 安装QoS分析工具
sudo apt install ros-humble-rqt-graph
rqt_graph
  1. 在代码中打印QoS信息
def check_qos_compatibility(self):"""检查QoS兼容性"""topic_info = self.get_topic_names_and_types()self.get_logger().info(f'话题信息: {topic_info}')

您的问题通过设置BEST_EFFORT解决了,说明您的发布程序使用的是BEST_EFFORT策略,而订阅程序默认使用了RELIABLE策略,导致不兼容。设置为BEST_EFFORT后,订阅者可以接收任何可靠性级别的消息。

6. 踩坑:订阅话题没有输出

通过程序发布ros2消息给/test_ros2话题 ,通过python程序

self.subscription = self.create_subscription(Object, '/test_ros2', object_callback, 100)

订阅话题后,没有打印任何信息。但是通过终端命令行ros2 topic pub /test_ros2 custom_msgs/Object 去发布,通过ros2 topic echo 查看话题,又有打印的信息。

可能的原因:

  1. 话题名称不匹配

检查您程序中发布消息的话题名称是否完全匹配订阅者的话题名称。确保:

  • 发布者使用的话题名称:/test_ros2
  • 订阅者使用的话题名称:/test_ros2
  • 注意前缀斜杠、大小写、拼写等
  1. 消息类型不匹配

确认发布程序使用的消息类型与订阅者期望的类型完全一致:

# 发布者应该使用
from custom_msgs.msg import Object
  1. QoS设置不匹配

检查发布者和订阅者的QoS设置是否兼容。

调试方法

  1. 检查话题状态
# 查看当前活跃的话题
ros2 topic list
# 查看特定话题的信息
ros2 topic info /test_ros2
# 实时监听话题消息
ros2 topic echo /test_ros2
  1. 检查消息发布频率

如果程序只发布一次消息就退出,可能订阅者还没来得及接收。尝试:

# 在发布程序中循环发布或添加延迟
for i in range(5):  # 发布5次publisher.publish(msg)time.sleep(1)
  1. 使用相同的QoS设置

在订阅者中明确设置QoS:

from rclpy.qos import QoSProfile, QoSReliabilityPolicyqos_profile = QoSProfile(depth=10)
qos_profile.reliability = QoSReliabilityPolicy.BEST_EFFORTself.subscription = self.create_subscription(Object,'/test_ros2',self.object_callback,qos_profile
)

最终采用方法3得到解决。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/88694.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/88694.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/88694.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Cursor三大核心AI功能

一&#xff1a;Tab键&#xff1a;智能小助手 1.1 单行/多行代码补全 在代码中写出要实现的功能&#xff0c;第一次按Tab生成代码&#xff0c;第二次按Tab接受代码。1.2 智能代码重写 对已有代码重新编写。 写个注释告诉AI重构方法&#xff0c;然后鼠标点到方法内部&#xff0c;…

cesium添加原生MVT矢量瓦片方案

项目中需要基于cesium接入mvt格式的服务并支持属性拾取查询&#xff0c;通过一系列预研测试&#xff0c;最后选择cesium-mvt-imagery-provider开源插件完成&#xff0c;关键源码信息如下&#xff1a; npm i cesium cesium-mvt-imagery-provider //安装依赖包// 加载图层import…

AI金融风控:识别欺诈,量化风险的新利器

AI金融风控&#xff1a;识别欺诈&#xff0c;量化风险的新利器深度学习算法穿透海量交易数据&#xff0c;92.5%的不良贷款识别率宣告了金融风险防控新时代的来临。深圳桑达银络科技有限公司在2025年6月申请的“基于人工智能的金融交易反欺诈系统”专利&#xff0c;揭示了金融风…

【unitrix】 5.0 第二套类型级二进制数基本结构体(types2.rs)

一、源码 这是一个使用 Rust 类型系统实现类型级(type-level)二进制数的设计。 //! 类型级二进制数表示方案&#xff08;第二套方案&#xff09; //! //! 使用嵌套泛型结构体表示二进制数&#xff0c;支持整数和小数表示。use crate::sealed::Sealed;/// 类型级二进制数结构体 …

DAY01:【ML 第一弹】机器学习概述

一、三大概念 1.1 人工智能&#xff08;AI&#xff09; Artificial Intelligence 人工智能AI is the field that studies the synthesis and analysis of computational agents that act intelligently 1.2 机器学习&#xff08;ML&#xff09; Machine Learning 机器学习Fi…

AGX Xavier 搭建360环视教程【一、先确认方案】

设备默认自带 NVIDIA 硬件编解码能力&#xff08;NVDEC/NVENC&#xff09;&#xff0c;但是需要你在 OpenCV 和 FFmpeg 里正确启用 调通 GStreamer 或 nvmpi&#xff0c;才真正能用起来&#xff01;这里的硬解码是核心&#xff1a;Jetson 平台的硬解码&#xff0c;要么走 GStr…

服务器怎么跑Python项目?

在服务器上运行 Python 项目通常涉及 环境配置、依赖安装、项目部署 和 进程管理。以下是详细步骤&#xff1a;1. 连接服务器确保你能通过 SSH 访问服务器&#xff1a;ssh usernameyour_server_ip&#xff08;如果是本地测试&#xff0c;可跳过这一步&#xff09;2. 安装 Pytho…

【软件设计师】

UML 类图中的关系用例图中的关系 关系例子类图用例图顺序图 概念示例通信图活动图泳道图状态图

Java 内部类详解:从基础到实战,掌握嵌套类、匿名类与局部类的使用技巧

作为一名 Java 开发工程师&#xff0c;你一定在实际开发中遇到过这样的场景&#xff1a;想在一个类内部定义另一个逻辑相关的类&#xff1b;需要为某个接口或抽象类提供一个临时实现&#xff08;比如监听器&#xff09;&#xff1b;想利用面向对象特性来组织代码结构&#xff0…

Java设计模式之行为型模式(观察者模式)介绍与说明

一、模式结构 观察者模式包含以下四个角色&#xff1a; Subject&#xff08;主题/被观察者&#xff09; 维护观察者列表&#xff0c;提供注册&#xff08;registerObserver&#xff09;、移除&#xff08;removeObserver&#xff09;观察者的方法&#xff0c;并定义通知所有观察…

实现一个点击输入框可以弹出的数字软键盘控件 qt 5.12

我们将创建两个自定义组件&#xff1a; 1. NumericInputField&#xff1a;一个输入框&#xff0c;当点击时弹出数字键盘。 2. NumericKeyboard&#xff1a;一个可缩放的数字键盘。 设计思路&#xff1a; - NumericInputField 是一个常规的输入框&#xff0c;但点击后会弹出 Num…

Java 深入解析:JVM对象创建与内存机制全景图

第一章&#xff1a;引言 Java 是一种面向对象的编程语言&#xff0c;对象&#xff08;Object&#xff09;是其最基本的组成单位。Java 的“一切皆对象”不仅体现在语法层面&#xff0c;更体现在运行时&#xff0c;几乎所有数据都以对象形式存在于内存中。 然而&#xff0c;很…

Redis 基本操作笔记

1. Redis 简介 Redis&#xff08;Remote Dictionary Server&#xff09;是一个开源的、高性能的键值对存储系统&#xff0c;通常作为数据库、缓存、消息中间件等使用。它支持多种数据类型&#xff0c;包括字符串、哈希、列表、集合、有序集合等。 Redis 特点&#xff1a; 性能&…

Docker从环境配置到应用上云的极简路径

Docker从环境配置到应用上云的极简路径主要包括环境配置、应用容器化、选择云平台及部署应用等步骤&#xff0c;具体如下&#xff1a; - 配置Docker环境&#xff1a; - 安装Docker&#xff1a;根据操作系统下载对应版本的Docker安装包。如在Linux系统中&#xff0c;可使用命令…

Slicer渲染Dicom到nrrd

Slicer渲染Dicom到nrrd 工作中遇到一些处理Dicom数据的需求&#xff0c;个人通过网络上的一些教程 对于原始数据尝试转换到nrrd时&#xff0c;发现部分的窗体数据的渲染方向不一致 进一步发现这些很多定义的方向是跟设备厂家强相关的&#xff0c;不同厂家对于同一段的Dicom参…

QT中设计qss字体样式但是没有用【已解决】

检查一下stylesheet里面是不是有不能被QT读取的CSS语言&#xff0c;可能会跟字体颜色冲突错误示范&#xff1a;/* 错误示例&#xff1a;QSS 中使用 box-shadow */ QPushButton {box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Qt 不支持此属性 */ }删掉就行了如果后续想用阴影…

uniapp获取状态栏高度,胶囊按钮的高度,底部安全区域的高度,自定义导航栏

相关API uni.getSystemInfoSync() uni.getMenuButtonBoundingClientRect() 创建一个utils文件夹&#xff0c;该文件下封装一个systemInfo.js /*** 系统信息工具类* 封装获取系统状态栏、导航栏和安全区域等相关信息的方法*/// 获取系统信息并缓存 const systemInfo uni.get…

jQuery 文本属性值

一、前言在网页开发中&#xff0c;我们经常需要对页面上的文本内容进行操作&#xff0c;例如动态修改段落文字、读取用户输入框的内容、更新按钮文本等。jQuery 提供了简洁而强大的方法来处理这些常见的文本操作需求。本文将带你全面了解 jQuery 中用于操作文本内容的三个核心方…

JAVA并发——为什么Java中的ThreadLocal对key的引用为弱引用

1、ThreadLocal 的用途 给每个线程提供自己独立的变量副本&#xff0c;实现线程间隔离。 常用于&#xff1a; 数据库连接、Session 缓存、用户上下文&#xff08;如 userId&#xff09;线程池中的线程复用时避免共享污染&#xff1b;实现线程封闭的设计模式 2、内存泄漏 使用弱…

【C++】多线程同步三剑客介绍

目录 条件变量 头文件 主要操作函数 1、等待操作 2、唤醒操作 使用示例 信号量 头文件 主要操作函数 1、信号量初始化 2、等待操作&#xff08;P操作&#xff09; 3、信号操作&#xff08;V操作&#xff09; 4、获取信号量值 5、销毁信号量 使用示例 互斥锁 …