Nav2 Logo
  • 入门指南
    • 安装步骤
    • 运行示例
    • 导航
  • 开发指南
    • 构建与安装
      • 安装
      • 构建
        • 已发布的分发二进制文件
        • 滚动开发源
        • Docker 容器镜像
      • 生成 Doxygen
      • 帮助
        • Build Troubleshooting Guide
    • 开发容器
      • Dev 容器指南
        • 创建 Dev 容器
        • 使用开发容器
      • 什么是、为什么和如何?
        • 什么是开发容器?
        • 为什么使用开发容器?
        • 开发容器是如何工作的?
      • 前提条件
      • 入门
      • 安全
    • 参与其中
      • 参与
      • 流程
      • 许可
      • 开发者原产地证书 (DCO)
  • 导航概念
    • ROS 2
      • Action Server
      • 生命周期节点和绑定
    • 行为树
    • 导航服务器
      • 规划器、控制器、平滑器和恢复服务器
      • 规划
      • 控制器
      • 行为
      • 平滑器
      • 机器人足迹
      • 航点跟踪
    • 状态估计
      • 标准
      • 全球定位:定位和 SLAM
      • 里程计
    • 环境表示
      • 成本图和图层
      • Costmap Filters
      • 其他形式
    • Nav2学术概况
  • 首次机器人设置指南
    • 设置转换
      • 变换简介
      • 静态变换发布器演示
      • Navigation2 中的变换
      • 结论
    • 设置 URDF
      • URDF 和机器人状态发布器
      • 设置环境
      • 编写 URDF
      • 构建和启动
      • 使用 RVIZ 进行可视化
      • 添加物理属性
      • 结论
    • 设置里程计
      • 里程表简介
      • 在您的机器人上设置里程计
      • 使用 Gazebo 模拟里程计系统
        • 设置和先决条件
        • 将 Gazebo 插件添加到 URDF
        • 启动和构建文件
        • 构建、运行和验证
      • 机器人定位演示
        • 配置机器人定位
        • 启动和构建文件
        • 构建、运行和验证
      • 结论
    • 设置传感器
      • 传感器介绍
        • 常见传感器消息
      • 使用 Gazebo 模拟传感器
        • 将 Gazebo 插件添加到 URDF
        • 启动和构建文件
        • 构建、运行和验证
      • 地图绘制和定位
      • Costmap 2D
        • Configuring nav2_costmap_2d
        • 构建、运行和验证
      • 结论
    • 设置机器人的足迹
      • 足迹介绍
      • 配置机器人的足迹
      • 构建、运行和验证
      • 在 RViz 中可视化足迹
      • 结论
    • 设置
      • 计划器和控制器服务器
      • 选择算法插件
        • 规划服务器
        • 控制服务器
      • 结论
  • 机器人使用
  • 常规教程
    • 使用物理 Turtlebot 3 进行导航
      • 概述
      • 要求
      • 教程步骤
        • 0- 设置环境变量
        • 1- 启动 Turtlebot 3
        • 2- 启动 Nav2
        • 3- 启动 RVIZ
        • 5- 发送目标姿势
    • (SLAM)边导航边建图
      • 概述
      • 要求
      • 教程步骤
        • 0- 启动机器人接口
        • 1- 启动 Navigation2
        • 2- 启动 SLAM
        • 3- 使用 SLAM
        • 4- 入门简化
    • (STVL)使用外部 Costmap 插件
      • 概述
      • Costmap2D and STVL
      • 教程步骤
        • 0- 设置
        • 1- 安装STVL
        • 1- 修改Navigation2参数
        • 2- 启动 Navigation2
        • 3- RVIZ
    • 使用 GPS 定位导航
      • 概述
      • 要求
      • GPS 定位概述
      • 教程步骤
        • 0- 设置 Gazebo World
        • 1- 设置 GPS 定位系统
        • 2- 设置导航系统
        • 3- 交互式 GPS 航点跟随器
        • 4- 记录 GPS 航点跟随器和航点记录
      • 结论
    • Groot - 与行为树交互
      • 概述
      • 可视化行为树
      • 编辑行为树
      • 添加自定义节点
    • 使用 VIO 增强机器人里程计
      • 概述
      • 设置 ZED X 相机
      • 设置 ZED ROS
      • 将 VIO 融合到本地状态估计中
        • 将 VSLAM 融合到全局状态估计中
      • 测试一下!
    • 动态物体跟踪
      • 概述
      • 教程步骤
        • 0- 创建行为树
        • 1- 设置Rviz点击点
        • 2- 在 Nav2 模拟中运行动态对象跟踪
    • 使用禁区导航
      • 概述
      • 要求
      • 教程步骤
        • 1. 准备过滤口罩
        • 2. 配置 Costmap 过滤器信息发布服务器
        • 3. 启用禁止访问过滤器
        • 4. 运行 Nav2 堆栈
    • 限速导航
      • 概述
      • 要求
      • 教程步骤
        • 1. 准备过滤面罩
        • 2. 配置 Costmap 过滤器信息发布服务器
        • 3. 启用速度过滤器
        • 4. 运行 Nav2 堆栈
    • 使用对接服务器
      • 概述
      • 要求
      • 充电底座插件
      • 码头数据库
      • 配置对接服务器
      • 添加对接服务器以启动
      • Docking Action API
      • 综合起来
    • 使用旋转垫片控制器
      • 概述
      • 什么是旋转垫片控制器?
      • 配置旋转垫片控制器
      • 配置主控制器
      • 演示执行
    • 为 BT 添加平滑器
      • 概述
      • 要求
      • 教程步骤
        • 0-熟悉 Smoother BT 节点
        • 1- 指定更平滑的插件
        • 2- 修改您的 BT XML
    • 使用碰撞监视器
      • 概述
      • 要求
      • 配置碰撞监视器
      • 使用速度多边形配置碰撞监视器
      • Preparing Nav2 stack
      • 演示执行
    • 添加新的 Nav2 任务服务器
      • 生命周期节点
      • 作品
      • 错误代码
      • 结论
    • 过滤噪声引起的障碍物
      • 概述
      • 要求
      • 教程步骤
        • 1. 启用降噪层
        • 2. 运行 Nav2 堆栈
      • 工作原理
    • 相机校准
      • 概述
      • 要求
      • 教程步骤
    • 在 ROS 2/Nav2 中获取 Backtrace
      • 概述
      • 预赛
      • From a Node
      • 从启动文件
      • 来自大型项目
      • 来自 Nav2 启动
      • 崩溃时自动回溯
    • ROS 2 / Nav2 中的分析
      • 概述
      • 预赛
      • 来自节点的配置文件
      • 来自启动文件的配置文件
      • 来自 Nav2 启动
      • 解释结果
    • Docker 开发:从零到英雄
      • 概述
      • 预赛
      • 重要的 Docker 命令
      • 探索你的第一个容器
      • 了解 ROS Docker 镜像
      • 对于基于 Docker 的开发
        • 树立发展形象
        • 来自 Docker 的可视化
      • 对于基于 Docker 的部署
      • 结论
      • 附录
        • Nav2 开发图像
        • Nav2 部署图像
  • 插件教程
    • 编写新的 Costmap2D 插件
      • 概述
      • 要求
      • 教程步骤
        • 1-编写一个新的 Costmap2D 插件
        • 2- 导出并制作 GradientLayer 插件
        • 3- 在 Costmap2D 中启用插件
        • 4- 运行 GradientLayer 插件
    • 编写新的 Planner 插件
      • 概述
      • 要求
      • 教程步骤
        • 1- 创建一个新的 Planner 插件
        • 2- 导出规划器插件
        • 3-通过 params 文件传递​​插件名称
        • 4- 运行 StraightLine 插件
    • 编写新的控制器插件
      • 概述
      • 要求
      • 教程步骤
        • 1- 创建一个新的控制器插件
        • 2- 导出控制器插件
        • 3- 通过 params 文件传递​​插件名称
        • 4- 运行 Pure Pursuit Controller 插件
    • 编写新的行为树插件
      • 概述
      • 要求
      • 教程步骤
        • 1- 创建新的 BT 插件
        • 2- 导出规划器插件
        • 3- 将插件库名称添加到配置中
        • 4- 运行您的自定义插件
    • 编写新的行为插件
      • 概述
      • 要求
      • 教程步骤
        • 1-创建一个新的行为插件
        • 2- 导出行为插件
        • 3-通过 params 文件传递​​插件名称
        • 4- 运行行为插件
    • 编写新的导航器插件
      • 概述
      • 要求
      • 教程步骤
        • 1- 创建一个新的导航器插件
        • 2- 导出导航器插件
        • 3-通过 params 文件传递​​插件名称
        • 4-运行插件
  • 配置指南
    • 行为树导航器
      • 参数
      • Example
    • 行为树 XML 节点
      • 动作插件
        • Wait
        • Spin
        • BackUp
        • DriveOnHeading
        • AssistedTeleop
        • ComputePathToPose
        • FollowPath
        • NavigateToPose
        • ClearEntireCostmap
        • ClearCostmapExceptRegion
        • ClearCostmapAroundRobot
        • ReinitializeGlobalLocalization
        • TruncatePath
        • TruncatePathLocal
        • PlannerSelector
        • ControllerSelector
        • SmootherSelector
        • GoalCheckerSelector
        • ProgressCheckerSelector
        • NavigateThroughPoses
        • ComputePathThroughPoses
        • ComputeCoveragePath
        • CancelCoverage
        • RemovePassedGoals
        • RemoveInCollisionGoals
        • CancelControl
        • CancelBackUp
        • CancelSpin
        • CancelWait
        • CancelDriveOnHeading
        • CancelAssistedTeleop
        • SmoothPath
        • GetPoseFromPath
        • DockRobot
        • UndockRobot
      • 条件插件
        • GoalReached
        • TransformAvailable
        • DistanceTraveled
        • GoalUpdated
        • GloballyUpdatedGoal
        • InitialPoseReceived
        • IsStuck
        • TimeExpired
        • IsBatteryLow
        • IsPathValid
        • PathExpiringTimer
        • AreErrorCodesPresent
        • WouldAControllerRecoveryHelp
        • WouldAPlannerRecoveryHelp
        • WouldASmootherRecoveryHelp
        • IsBatteryCharging
      • 控制插件
        • PipelineSequence
        • RoundRobin
        • RecoveryNode
      • 装饰器插件
        • RateController
        • DistanceController
        • SpeedController
        • GoalUpdater
        • PathLongerOnApproach
        • SingleTrigger
      • 例子
    • Costmap 2D
      • Costmap2D ROS参数
      • Default Plugins
      • 插件参数
        • Static Layer Parameters
        • Inflation Layer Parameters
        • Obstacle Layer Parameters
        • Voxel Layer Parameters
        • Range Sensor Parameters
        • Denoise Layer Parameters
      • 代价地图过滤器参数
        • Keepout Filter Parameters
        • Speed Filter Parameters
        • Binary Filter Parameters
      • 例子
    • 生命周期 Manager
      • 参数
      • Example
    • 规划服务器
      • 参数
      • Default Plugins
      • Example
    • Coverage Server
      • 参数
      • Example
    • NavFn Planner
      • Parameters
      • Example
    • Smac Planner
      • 提供的插件
        • Smac 2D Planner
        • Smac Hybrid-A* Planner
        • Smac State Lattice Planner
      • 描述
    • Theta Star Planner
      • 参数
      • Example
    • Controller Server
      • 参数
      • Provided Plugins
        • SimpleProgressChecker
        • PoseProgressChecker
        • SimpleGoalChecker
        • StoppedGoalChecker
      • Default Plugins
      • Example
    • DWB Controller
      • Controller
        • DWB Controller
        • XYTheta Iterator
        • Kinematic Parameters
        • Publisher
      • Plugins
        • LimitedAccelGenerator
        • StandardTrajectoryGenerator
      • Trajectory Critics
        • BaseObstacleCritic
        • GoalAlignCritic
        • GoalDistCritic
        • ObstacleFootprintCritic
        • OscillationCritic
        • PathAlignCritic
        • PathDistCritic
        • PreferForwardCritic
        • RotateToGoalCritic
        • TwirlingCritic
      • Example
    • Regulated Pure Pursuit
      • 受监管的纯追踪参数
      • Example
    • Model Predictive Path Integral Controller
      • MPPI 参数
        • 轨迹可视化
        • 路径处理器
        • 阿克曼运动模型
        • 限制性批评家
        • 目标角度评论家
        • Goal Critic
        • Obstacles Critic
        • Cost Critic
        • Path Align Critic
        • Path Angle Critic
        • Path Follow Critic
        • Prefer Forward Critic
        • Twirling Critic
        • Velocity Deadband Critic
      • Example
      • Notes to Users
        • General Words of Wisdom
        • Prediction Horizon, Costmap Sizing, and Offsets
        • Obstacle, Inflation Layer, and Path Following
    • Rotation Shim Controller
      • 旋转垫片控制器参数
      • Example
    • Graceful Controller
      • 优雅控制器参数
      • Example
    • Map Server / Saver
      • 地图保护程序参数
      • Map Server Parameters
      • Costmap Filter Info Server Parameters
      • Example
    • AMCL
      • Parameters
      • Example
    • Behavior Server
      • 行为服务器参数
      • Default Plugins
      • 自旋行为参数
      • 备份行为参数
      • DriveOnHeading Behavior Parameters
      • AssistedTeleop 行为参数
      • Example
    • 更流畅的服务器
      • 更平滑的服务器参数
      • Example
    • Simple Smoother
      • 简单平滑器参数
      • Example
    • Savitzky-Golay Smoother
      • Savitzky-Golay 平滑器参数
      • Example
    • Constrained smoother
      • 更平滑的服务器参数
      • Example
    • Velocity Smoother
      • 速度平滑器参数
      • Example
    • 碰撞监测
      • 提供的节点
        • Collision Monitor Node
        • Collision Detector Node
    • Waypoint Follower
      • 参数
      • 提供的插件
        • WaitAtWaypoint
        • PhotoAtWaypoint
        • InputAtWaypoint
      • 默认插件
      • Example
    • Loopback Simulator
      • 参数
      • Example
    • Docking Server
      • 参数
      • SimpleChargingDock 参数
      • Example
  • 调优指南
    • 通货膨胀势场
    • 机器人占地面积与半径
    • 原地旋转行为
    • 规划器插件选择
    • 控制器插件选择
    • 在 Smac 规划器中缓存障碍启发式方法
    • Costmap2D插件
    • Nav2 启动选项
    • 我们很乐意提供的其他页面
  • Nav2 行为树
    • 简介
      • 动作节点
      • 条件节点
      • 装饰节点
      • 控制:PipelineSequence
      • 控制:恢复
      • 控制:循环赛
    • 行为树详细演练
      • 概述
      • 先决条件
      • 通过重新规划和恢复导航至姿势
      • 导航子树
      • 恢复子树
    • 导航至目的地
    • Navigate Through Poses
    • 导航至姿势并在目标障碍附近暂停
    • 如果路径无效,则通过一致的重新规划导航到姿势
    • 跟随动态点
    • 里程校准
  • 导航插件
    • 行为树导航器
    • Costmap Layers
    • Costmap Filters
    • Controllers
    • Planners
    • Smoothers
    • Behaviors
    • Waypoint Task Executors
    • Goal Checkers
    • Progress Checkers
    • Behavior Tree Nodes
  • 迁移指南
    • Dashing to Eloquent
      • 新软件包
      • 新插件
      • Navigation2 架构变化
    • Eloquent 到 Foxy
      • 一般
      • 服务器更新
      • 新插件
      • 地图服务器重做
      • 新的粒子过滤消息
      • 在每个导航操作中选择行为树
      • FollowPoint 功能
      • 新的 Costmap 层
    • Foxy to Galactic
      • NavigateToPose 动作反馈更新
      • NavigateToPose BT-node 接口更改
      • 添加了 NavigateThroughPoses 和 ComputePathThroughPoses 操作
      • ComputePathToPose BT-node 接口更改
      • ComputePathToPose 操作接口更改
      • 备份 BT 节点接口更改
      • 备份恢复接口更改
      • Nav2 控制器和目标检查器插件接口更改
      • FollowPath goal_checker_id 属性
      • Groot 支持
      • 新插件
      • 成本地图过滤器
      • SmacPlanner
      • ThetaStarPlanner
      • RegulatedPurePursuitController
      • Costmap2D current_ 用法
      • 参数中的标准时间单位
      • 光线追踪参数
      • 障碍物标记参数
      • 恢复操作更改
      • 默认行为树更改
      • NavFn 规划器参数
      • 新的 ClearCostmapExceptRegion 和 ClearCostmapAroundRobot BT 节点
      • 新的行为树节点
      • sensor_msgs/PointCloud 更改为 sensor_msgs/PointCloud2
      • ControllerServer 新参数 Failure_tolerance
      • 删除了 BT XML 启动配置
      • Nav2 RViz 面板操作反馈信息
    • Galactic to Humble
      • Smac Planner 的重大改进
      • Simple (Python) Commander
      • Reduce Nodes and Executors
      • API Change for nav2_core
      • 扩展 BtServiceNode 来处理服务结果
      • 包括新的旋转垫片控制器插件
      • Spawning the robot in Gazebo
      • 恢复行为超时
      • 3 个 2D 规划器的新参数“use_final_approach_orientation”
      • SmacPlanner2D 和 Theta*:修复被忽略的目标方向
      • SmacPlanner2D、NavFn 和 Theta*:修复小路径角点情况
      • 更改并修复动态参数变化检测的行为
      • 动态参数
      • BT 动作节点异常更改
      • BT 导航器 Groot 多个导航器
      • 删除了 RPP 中的运动限制
      • 添加了更平滑的任务服务器
      • 删除了 RPP 中的使用接近速度缩放参数
      • 将 AMCL 运动模型重构为插件
      • 放弃对 Nav2 的实时 Groot 监控的支持
      • 仅当路径无效时才重新规划
      • 修复 CostmapLayer clearArea 反转参数逻辑
      • 动态组合
      • BT 取消节点
      • BT PathLongerOnApproach 节点
      • BT TruncatePathLocal 节点
      • 约束平滑器
      • 以恒定速率重新规划,如果路径无效
      • 欧几里得距离 2D
      • 恢复到行为
      • Launch 和 Lifecycle Manager 中的重生支持
      • 新的 Nav2 速度平滑器
      • 目标检查器 API 已更改
      • 添加了辅助遥操作
    • 从 Humble 到 Iron
      • 新的行为树导航器插件
      • 添加了碰撞监视器
      • 从 yaml 中删除了 use_sim_time
      • Smac Planner 的运行时加速
      • Smac 和简单平滑器的递归细化
      • 简单指挥官 Python API
      • Smac Planner 起始姿势包含在路径中
      • 扩展规划器基准测试
      • Smac Planner 路径公差
      • costmap_2d_node 默认构造函数
      • 导航失败的反馈
      • 成本图过滤器
      • Savitzky-Golay 平滑器
      • Launch 中 map_server 节点的 Map yaml 文件路径更改
      • SmootherSelector BT 节点
      • 发布 Costmap 图层
      • 授予行为服务器访问两个 Costmap 的权限
      • 新型模型预测路径积分控制器
      • 行为树使用错误代码
      • 从 RViz 中的 Nav2 面板加载、保存和循环航点
      • DWB 正向与反向修剪
      • 对长前瞻距离的曲线进行更稳定的调节
      • 发布碰撞监视器状态
      • 在碰撞监视器中重命名 ROS 参数
      • 碰撞监视器中的新安全行为模型“限制”
      • 速度平滑器在超时时应用减速
      • PoseProgressChecker 插件
      • 允许多个目标检查器并更改参数progress_checker_plugin的名称和类型
      • IsBatteryChargingCondition BT 节点
      • 行为服务器错误代码
      • 新的 Denoise Costmap Layer 插件
      • SmacPlannerHybrid viz_expansions 参数
    • Iron 到 Jazzy
      • BehaviorTree.CPP 升级到版本 4.5+
      • 为命令添加了 TwistStamped 选项
      • 在碰撞监视器中添加 VelocityPolygon
      • 在碰撞监视器中更改多边形点参数格式
      • 软实时操作服务器简介
      • “opennav_coverage”项目
      • opennav_docking 项目
      • 引入新的多机器人启动
      • 体素和障碍物层的新选项
      • use_interpolation RPP 参数已弃用
      • 对 MPPI 目标评论家的更改
      • MPPI 路径角度评价器的变化
      • MPPI 路径处理的方向性变化
      • 添加新的 MPPI 成本评论器
      • MPPI 加速
      • 移动错误代码枚举
      • 参数文件中的替换
      • 允许行为服务器插件访问操作结果
      • Smac Planner 调试参数名称更改
      • Smac Planner 接近目标捷径解决方案
      • 添加了 GPS 航点跟随器服务器
      • Smac Planner Hybrid-A* 新功能
      • nav2_collision_monitor 中的新节点:碰撞检测器
      • 在碰撞监视器/检测器中动态启用/禁用源/多边形
      • 公开操作服务器的结果超时
      • RewrittenYaml 可以向 YAML 添加新参数
      • 简单指挥官 API 允许多机器人命名空间
      • 更改 wait_action 节点中的持续时间类型
      • 当所需的转换不可用时,costmap 激活会失败
      • 子树获得共享资源
      • 碰撞监视器:添加了基于 source_timeout 参数的看门狗机制,具有默认阻止行为
      • BtActionServer:使用本机库 haltTree()
      • 从 2 个 BT 节点中删除全局框架
      • CostmapUpdate.msg 的介绍
      • 完整堆栈使用节点时钟
      • 新的优雅运动控制器
      • BT Navigator 中的插件库仅包含自定义节点
      • 用于选择规划器、控制器、目标检查器、进度检查器和平滑器的新 RViz 插件
      • RPP 新增可选的“interpolate_curvature_after_goal”行为,并修复“use_rotate_to_heading”和“allow_reversing”之间的冲突
      • GlobalPlanner 的取消检查器接口
      • 新的 BtActionServer/BtNavigator 参数
      • 新的碰撞监控参数
      • 控制器的新优雅取消 API
      • 使用双冒号 (::) 标准化插件命名
      • 碰撞监视器:圆形多边形的动态半径
      • 静态层:新参数“footprint_clearing_enabled”
      • 生命周期节点:添加了 bond_heartbeat_period 参数(并允许禁用债券机制)
      • 旋转垫片控制器:新参数“rotate_to_goal_heading”
      • MPPI 控制器:增加加速度约束
      • RegulatedPurePursuit 控制器 [RPP]:新参数 use_cancel_deceleration
    • Jazzy 到 K-Turtle
      • 新的 Nav2 环回模拟器
      • 使用静态基础设施或动态对接进行对接
      • 用于对接的新 RViz 面板
      • 新的 BT 节点
      • 用于成本图成本单元检查的新 RViz 工具
      • 修复闪烁可视化
      • 通过 DWB 轨迹限制速度的选项
      • 在目标退出时禁用零速度发布的选项
  • Simple Commander API
    • 概述
    • Commander API
    • Costmap API
    • Footprint Collision Checker API
    • 示例和演示
  • Roadmaps
    • Jazzy Roadmap
    • Iron Roadmap
    • Humble Roadmap
  • 关于和联系方式
    • Related Projects
    • 关于
    • 联系方式
Nav2
Edit
  • 常规教程
  • 限速导航

限速导航

  • 概述

  • 要求

  • 教程步骤

概述

本教程将介绍如何简单使用速度过滤器,该过滤器旨在限制地图上标记的速度限制区域中机器人的最大速度。SpeedFilter 成本地图过滤器插件涵盖了此功能,本文档将启用和使用该插件。

要求

假设 ROS 2、Gazebo 和 TurtleBot3 软件包已在本地安装或构建。请确保 Nav2 项目也在本地构建,因为它是在 构建与安装 中创建的。

教程步骤

1. 准备过滤面罩

正如在 导航概念 中所写,任何 Costmap Filter(包括 Speed Filter)都会读取在过滤器掩码文件中标记的数据。有关过滤器掩码、其类型、详细结构以及如何制作新过滤器掩码的所有信息都写在 使用禁区导航 教程的“1. 准备过滤器掩码”一章中。绘制 Speed Filter 的过滤器掩码的原理与 Keepout Filter 相同(用请求的区域注释地图),只是“OccupancyGrid”掩码值有另一层含义:这些值是地图上单元格对应区域的编码速度限制。

让我们看看它是如何解码的。众所周知, OccupancyGrid 值属于 [0..100] 范围。对于速度过滤器, 0 值表示在掩码上零单元对应的区域中没有速度限制。 [1..100] 范围内的值通过以下公式线性转换为速度限制值:

速度限制 = 滤波掩码数据 * 乘数 + 基数;

where:

  • filter_mask_data ——是应限制最大速度的掩模上相应单元的 OccupancyGrid 值。

  • base 和 multiplier 是从 Costmap Filter Info Server 发布的 nav2_msgs/CostmapFilterInfo 消息中获取的系数(参见下面的下一章)。

解码后的 speed_limit 值可能具有以下两种含义之一:

  • 速度限制以机器人最大速度的百分比表示。

  • 速度限制以绝对值表示(例如 m/s)。

速度过滤器使用的含义是从 nav2_msgs/CostmapFilterInfo 消息中读取的。 在本教程中,我们将使用第一种速度限制,以机器人最大速度的百分比表示。

Note

对于以百分比表示的速度限制, speed_limit 将完全用作属于 [0..100] 范围的百分比,而不是 [0.0..1.0] 范围。

创建一个 PGM/PNG/BMP 格式的新图像:将用于世界模拟的 turtlebot3_world.pgm 主地图从 Nav2 存储库复制到新的 speed_mask.pgm 文件。在您最喜欢的光栅图形编辑器中打开 speed_mask.pgm ,并用灰色填充限速区域。在我们的示例中,较深的颜色表示限速较高的区域:

../../_images/drawing_speed_mask.png

区域 A 填充有 40% 灰色,区域 B 填充有 70% 灰色,这意味着速度限制将在区域 A 中取 100% - 40% = 60% ,在区域 B 中取 100% - 70% = 30% ,该速度限制在该机器人允许的最大速度值范围内。 我们将使用没有阈值的“比例”地图模式。在此模式下,较深的颜色将具有较高的 OccupancyGrid 值。例如,对于灰色为 70% 的区域 B , OccupancyGrid 数据将等于 70 。因此,为了达到目标,我们需要选择 base = 100.0 和 multiplier = -1.0 。这会将比例 OccupancyGrid 值反转为所需的值。为了方便起见,在 yaml 文件中没有选择任何阈值( free_thresh 和 occupied_thresh ):从过滤器蒙版到速度限制百分比的亮度值有 1:1 的全范围转换。

Note

base 和 multiplier 的选择很典型,但不是强制性的。例如,您可以选择地图模式为 raw。在这种情况下,颜色亮度将直接转换为 OccupancyGrid 值。对于以 raw 模式保存的蒙版, base 和 multiplier 将分别等于 0.0 和 1.0。

另一件重要的事情是,没有必要使用整个 “[0..100]” 百分比刻度。可以选择 “base” 和 “multiplier” 系数,以便速度限制值属于百分比范围中间的某个值。例如,“base = 40.0”,“multiplier = 0.1” 将给出 “[40.0%..50.0%]” 范围内的速度限制,步长为 “0.1%”。这可能对微调有用。

所有限速区域都填满后,保存 speed_mask.pgm 图像。

与所有其他地图一样,过滤器蒙版应具有自己的 YAML 元数据文件。将 `turtlebot3_world.yaml <https://github.com/ros-planning/navigation2/blob/main/nav2_bringup/bringup/maps/turtlebot3_world.yaml>”复制到“speed_mask.yaml`_。打开“speed_mask.yaml”并更新字段,如下所示(如前所述,对于“scale”模式,要使用整个颜色亮度范围,不应有阈值:“free_thresh = 0.0”和“occupied_thresh = 1.0”):

image: turtlebot3_world.pgm
->
image: speed_mask.pgm

mode: trinary
->
mode: scale

occupied_thresh: 0.65
free_thresh: 0.196
->
occupied_thresh: 1.0
free_thresh: 0.0

由于 Costmap2D 不支持方向, origin 向量的最后第三个“偏航”分量应等于零(例如: origin: [1.25, -5.18, 0.0] )。保存 speed_mask.yaml,新的过滤器掩码即可使用。

Note

世界地图本身和过滤器蒙版可能具有不同的大小、原点和分辨率,这可能会很有用(例如,当过滤器蒙版覆盖地图上较小的区域或一个过滤器蒙版被重复使用多次时,例如为酒店​​中相同形状的房间标注限速区域)。对于这种情况,您还需要更正 YAML 中的“分辨率”和“原点”字段,以便过滤器蒙版正确地放置在原始地图之上。此示例显示使用主地图作为基础,但这不是必需的。

2. 配置 Costmap 过滤器信息发布服务器

每个 costmap 过滤器都会在 nav2_msgs/CostmapFilterInfo 类型的消息中读取传入的元信息(例如过滤器类型或数据转换系数)。这些消息由 Costmap Filter Info Publisher Server 发布。该服务器作为生命周期节点运行。根据 设计文档,nav2_msgs/CostmapFilterInfo 消息与 OccupancyGrid 过滤器掩码主题成对发送。因此,除了 Costmap Filter Info Publisher Server 之外,还应启用一个配置为发布过滤器掩码的 Map Server 新实例。

为了在您的配置中启用 Speed Filter,应在 Python 启动文件中将两个服务器启用为生命周期节点。例如,这可能如下所示,但也可以将它们作为 Composition Node 添加到导航组件容器中:

import os

from ament_index_python.packages import get_package_share_directory

from launch import LaunchDescription
from launch.actions import DeclareLaunchArgument
from launch.substitutions import LaunchConfiguration
from launch_ros.actions import Node
from nav2_common.launch import RewrittenYaml


def generate_launch_description():
    # Get the launch directory
    costmap_filters_demo_dir = get_package_share_directory('nav2_costmap_filters_demo')

    # Create our own temporary YAML files that include substitutions
    lifecycle_nodes = ['filter_mask_server', 'costmap_filter_info_server']

    # Parameters
    namespace = LaunchConfiguration('namespace')
    use_sim_time = LaunchConfiguration('use_sim_time')
    autostart = LaunchConfiguration('autostart')
    params_file = LaunchConfiguration('params_file')
    mask_yaml_file = LaunchConfiguration('mask')

    # Declare the launch arguments
    declare_namespace_cmd = DeclareLaunchArgument(
        'namespace',
        default_value='',
        description='Top-level namespace')

    declare_use_sim_time_cmd = DeclareLaunchArgument(
        'use_sim_time',
        default_value='true',
        description='Use simulation (Gazebo) clock if true')

    declare_autostart_cmd = DeclareLaunchArgument(
        'autostart', default_value='true',
        description='Automatically startup the nav2 stack')

    declare_params_file_cmd = DeclareLaunchArgument(
            'params_file',
            default_value=os.path.join(costmap_filters_demo_dir, 'params', 'speed_params.yaml'),
            description='Full path to the ROS 2 parameters file to use')

    declare_mask_yaml_file_cmd = DeclareLaunchArgument(
            'mask',
            default_value=os.path.join(costmap_filters_demo_dir, 'maps', 'speed_mask.yaml'),
            description='Full path to filter mask yaml file to load')

    # Make re-written yaml
    param_substitutions = {
        'use_sim_time': use_sim_time,
        'yaml_filename': mask_yaml_file}

    configured_params = RewrittenYaml(
        source_file=params_file,
        root_key=namespace,
        param_rewrites=param_substitutions,
        convert_types=True)

    # Nodes launching commands
    start_lifecycle_manager_cmd = Node(
            package='nav2_lifecycle_manager',
            executable='lifecycle_manager',
            name='lifecycle_manager_costmap_filters',
            namespace=namespace,
            output='screen',
            emulate_tty=True,  # https://github.com/ros2/launch/issues/188
            parameters=[{'use_sim_time': use_sim_time},
                        {'autostart': autostart},
                        {'node_names': lifecycle_nodes}])

    start_map_server_cmd = Node(
            package='nav2_map_server',
            executable='map_server',
            name='filter_mask_server',
            namespace=namespace,
            output='screen',
            emulate_tty=True,  # https://github.com/ros2/launch/issues/188
            parameters=[configured_params])

    start_costmap_filter_info_server_cmd = Node(
            package='nav2_map_server',
            executable='costmap_filter_info_server',
            name='costmap_filter_info_server',
            namespace=namespace,
            output='screen',
            emulate_tty=True,  # https://github.com/ros2/launch/issues/188
            parameters=[configured_params])

    ld = LaunchDescription()

    ld.add_action(declare_namespace_cmd)
    ld.add_action(declare_use_sim_time_cmd)
    ld.add_action(declare_autostart_cmd)
    ld.add_action(declare_params_file_cmd)
    ld.add_action(declare_mask_yaml_file_cmd)

    ld.add_action(start_lifecycle_manager_cmd)
    ld.add_action(start_map_server_cmd)
    ld.add_action(start_costmap_filter_info_server_cmd)

    return ld

其中, params_file 变量应设置为 YAML 文件,其中包含 Costmap Filter Info Publisher Server 和 Map Server 节点的 ROS 参数。这些参数及其含义列在 Map Server / Saver 页面中。请参阅该页面了解更多信息。 params_file 的示例如下:

costmap_filter_info_server:
  ros__parameters:
    use_sim_time: true
    type: 1
    filter_info_topic: "/costmap_filter_info"
    mask_topic: "/speed_filter_mask"
    base: 100.0
    multiplier: -1.0
filter_mask_server:
  ros__parameters:
    use_sim_time: true
    frame_id: "map"
    topic_name: "/speed_filter_mask"
    yaml_filename: "speed_mask.yaml"

Note, that:

  • 对于速度过滤器,以最大速度的百分比设置速度限制,应将 costmap 过滤器的 type 设置为 1。所有可能的 costmap 过滤器类型都可以在 Map Server / Saver 页面中找到。

  • 过滤器掩码主题名称应等于 Costmap Filter Info Publisher Server 的 mask_topic 参数和 Map Server 的 topic_name 参数。

  • 如上一章所述,为了本教程示例的目的,应将 base 和 multiplier 分别设置为 100.0 和 -1.0。

可以在 navigation2_tutorials 存储库的 nav2_costmap_filters_demo 目录中找到现成的独立 Python 启动脚本、带有 ROS 参数的 YAML 文件和 Speed Filter 的过滤器掩码示例。要简单地运行在 入门指南 中编写的 Turtlebot3 标准模拟上调整的 Filter Info Publisher Server 和 Map Server,请构建演示并启动 costmap_filter_info.launch.py​​,如下所示:

$ mkdir -p ~/tutorials_ws/src
$ cd ~/tutorials_ws/src
$ git clone https://github.com/ros-planning/navigation2_tutorials.git
$ cd ~/tutorials_ws
$ colcon build --symlink-install --packages-select nav2_costmap_filters_demo
$ source ~/tutorials_ws/install/setup.bash
$ ros2 launch nav2_costmap_filters_demo costmap_filter_info.launch.py params_file:=src/navigation2_tutorials/nav2_costmap_filters_demo/params/speed_params.yaml mask:=src/navigation2_tutorials/nav2_costmap_filters_demo/maps/speed_mask.yaml

3. 启用速度过滤器

Costmap Filters 是 Costmap2D 插件。您可以通过在“nav2_params.yaml”中的“plugins”参数中添加“speed_filter”来启用 Costmap2D 中的“SpeedFilter”插件。Speed Filter 插件应定义以下参数:

  • plugin: 插件类型。在我们的例子中是 nav2_costmap_2d::SpeedFilter.

  • filter_info_topic: 过滤器信息主题名称。这需要等于上一章中 Costmap Filter Info Publisher Server 的 filter_info_topic 参数。

  • speed_limit_topic: 发布速度限制的主题名称。

SpeedFilter 支持的完整参数列表列在 Speed Filter Parameters 页面上。

您可以将插件放在 nav2_params.yaml 中的 global_costmap 部分,以将速度限制掩码应用于全局代价地图,或放在 local_costmap 中,以将速度掩码应用于局部代价地图。但是,切勿同时为全局和局部代价地图启用 SpeedFilter 插件。否则,它可能导致在速度限制边界上出现不必要的多个“速度限制”-“无限制”消息链,从而导致机器人抖动或其他不可预测的行为。

在本教程中,我们将为全局代价地图启用速度过滤器。为此,请使用以下配置:

global_costmap:
  global_costmap:
    ros__parameters:
      ...
      plugins: ["static_layer", "obstacle_layer", "inflation_layer"]
      filters: ["speed_filter"]
      ...
      speed_filter:
        plugin: "nav2_costmap_2d::SpeedFilter"
        enabled: True
        filter_info_topic: "/costmap_filter_info"
        speed_limit_topic: "/speed_limit"

如 `设计<https://github.com/ros-planning/navigation2/blob/main/doc/design/CostmapFilters_design.pdf>`_ 中所述,速度过滤器发布针对控制器服务器的速度限制 `消息<https://github.com/ros-planning/navigation2/blob/main/nav2_msgs/msg/SpeedLimit.msg>`_ ,以便在需要时限制机器人的最大速度。控制器服务器有一个 speed_limit_topic ROS参数,应将其设置为与 speed_filter 插件值相同。地图服务器中的这个主题还可以用于限速区以外的任何其他限速应用,例如根据有效载荷质量动态调整最大速度。

将控制器服务器的“speed_limit_topic”参数设置为与“speed_filter”插件设置的值相同的值:

controller_server:
  ros__parameters:
    ...
    speed_limit_topic: "/speed_limit"

4. 运行 Nav2 堆栈

启动 Costmap Filter Info Publisher Server 和 Map Server 并为全局/本地代价地图启用 Speed Filter 后,按照:ref:getting_started 中的说明运行 Nav2 堆栈:

ros2 launch nav2_bringup tb3_simulation_launch.py

为了更好地可视化速度过滤器掩码,在 RViz 中左侧的“显示”窗格中展开“地图”,并将“主题”从“/map”更改为“/speed_filter_mask”。 将目标设置在限速区域后面,并检查过滤器是否正常工作:机器人在经过限速区域时应减速。下面是它可能的样子(第一张图片显示为全局成本地图启用的速度过滤器,第二张图片显示“speed_mask.pgm”过滤器掩码):

../../_images/speed_global.gif ../../_images/speed_mask.png

© Copyright 2023.