【Ros控制机械臂学习笔记】报错joint_state_publisher-2

        当初导出URDF文件的时候,先运行了一遍display.launch文件,按照网上的一些教程,检查了以各个关节的转动情况,发现没问题,然后为了深入了解URDF文件,就看着资料,给创建好的URDF文件加了好多中文注释,结束保存后就没再运行过了,最近运行配置助手生成的文件总是出错,各种种奇怪的问题,于是重新运行了URDF文件中的display.launch 文件,抛出如下错误:

 然后RVIZ中的界面中添加robotmodel之后显示如下:

       找了一堆资料后发现,问题就处在之前添加的中文注释中,在URDF文件中是不可以添加中文注释的,也不是能在第一行添加注释,把自己的注释删除之后,重新运行,问题就解决了。删除中文注释之后的结果。

 

### 加载并激活 ROS2 控制器 为了加载并激活 `fishbot_joint_state_broadcaster` 控制器,在 ROS2 中通常需要遵循特定的过程。这涉及到编辑控制器配置文件以及编写启动脚本来确保控制器能够正确初始化。 #### 编辑控制器配置文件 控制器的参数一般定义在一个 YAML 文件中,此文件指定了要使用的具体控制器及其属性。对于 `joint_state_broadcaster` 类型的控制器来说,应该有如下形式的内容: ```yaml controller_manager: ros__parameters: update_rate: 100 # 更新频率设置为每秒100次 fishbot_joint_state_broadcaster: type: joint_state_broadcaster/JointStateBroadcaster ``` 上述代码片段展示了如何指定控制器管理器更新速率和声明 `fishbot_joint_state_broadcaster` 的类型[^1]。 #### 创建启动文件 接下来,创建一个用于加载这些配置并将控制器添加到控制器管理器中的 Python 启动脚本或者 launch 文件。下面是一个简单的例子,演示了怎样利用 Launch API 来实现这一点: ```python from launch import LaunchDescription from launch_ros.actions import Node def generate_launch_description(): return LaunchDescription([ Node( package='controller_manager', executable='spawner.py', arguments=['fishbot_joint_state_broadcaster'], output='screen' ), ]) ``` 这段代码的作用是在运行时调用 controller_manager 提供的 spawner 工具来实例化所需的广播器[^2]。 #### 使用命令行工具激活控制器 除了编程方式外,还可以直接通过命令行工具来进行操作。一旦完成了前面提到的工作空间构建与环境准备之后,可以执行以下指令来加载并启动控制器: ```bash ros2 control load_controller fishbot_joint_state_broadcaster --set-state start ``` 这条命令将会向控制系统发送请求以装载指定名称的控制器,并立即将其状态设为活动模式。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值