本文为原创博客, 转载请注明出处:https://blog.csdn.net/q_z_r_s
机器感知 一个专注于SLAM、三维重建、机器视觉等相关技术文章分享的公众号 |
参考自:http://wiki.ros.org/ROS/Tutorials
【Beginner Level】ROS入门教程(一)
【Beginner Level】ROS入门教程(二)
【Beginner Level】ROS入门教程(三)
【Beginner Level】ROS入门教程(四)
【Beginner Level】ROS入门教程(五)
安装ROS: 详见ROS安装教程
确保ROS环境变量已被设置
printenv | grep ROS
#输出如下
linux@linux:~$ printenv | grep ROS
ROS_ROOT=/opt/ros/indigo/share/ros
ROS_PACKAGE_PATH=/opt/ros/indigo/share:/opt/ros/indigo/stacks
ROS_MASTER_URI=http://localhost:11311
ROSLISP_PACKAGE_DIRECTORIES=
ROS_DISTRO=indigo
ROS_ETC_DIR=/opt/ros/indigo/etc/ros
关于catkin和rosbuild的选择
ROS Indigo发布于2014年, ROS Groovy发布于2012, 根据官网说明, ROS Groovy及其之后的版本使用catkin, ROS Fuerte及更老的版本使用rosbuild, 因此, 我这里使用catkin
$ mkdir -p ~/catkin_ws/src
$ cd ~/catkin_ws/
$ catkin_make
在工作空间中首次运行catkin_make
命令后, 它会在./src
目录下创建一个CMakeLists.txt.
linux@linux:~/catkin_ws$ ls
build devel src
在devel
文件夹中, 有几个setup.*sh
的文件, source
任何一个, 都将覆盖工作空间顶层环境
$ source devel/setup.bash
输入以下命令, 确保ROS_PACKAGE_PATH
环境变量包含了当前路径
$ echo $ROS_PACKAGE_PATH
/home/youruser/catkin_ws/src:/opt/ros/kinetic/share
#自己添加的, 非官网
linux@linux:~/catkin_ws$ printenv | grep ROS
ROS_ROOT=/opt/ros/indigo/share/ros
ROS_PACKAGE_PATH=/home/linux/catkin_ws/src:/opt/ros/indigo/share:/opt/ros/indigo/stacks
ROS_MASTER_URI=http://localhost:11311
ROSLISP_PACKAGE_DIRECTORIES=/home/linux/catkin_ws/devel/share/common-lisp
ROS_DISTRO=indigo
ROS_ETC_DIR=/opt/ros/indigo/etc/ros
通过对比, 仅有ROS_PACKAGE_PATH
和ROSLISP_PACKAGE_DIRECTORIES
发生了变化
sudo apt-get install ros-indigo-ros-tutorials
ROS代码分布于很多packages
中, 使用诸如ls
和cd
这样命令行来进行文件导航是及其繁琐乏味的, 因此ROS提供了相关的工具来使用
使用rospack
rospack可以获得有关packages的信息, 此处展示find
命令, 帮助命令为rospack help
linux@linux:~/catkin_ws$ rospack find roscpp
/opt/ros/indigo/share/roscpp
使用roscd
roscd是rosbash的一部分, 此命令可以让你直接把目录改变到一个package中或一个stack中
#语法, 可以直接进入某个package文件夹中
roscd [locationname[/subdir]]
linux@linux:~/catkin_ws$ roscd roscpp
linux@linux:/opt/ros/indigo/share/roscpp$ pwd
/opt/ros/indigo/share/roscpp
注: 和其他ROS工具类似, roscd只寻找ROS_PACKAGE_PATH
所列出路径, 其中的每个路径用:
来分隔.
roscd log
此命令会进入ROS存储log的文件夹, 如果执行此命令之前名优运行过ROS程序, 此命令会报错, 找不到此文件夹.
linux@linux:/opt/ros/indigo/share/roscpp$ roscd log
No active roscore
bash: cd: /home/linux/.ros/log: 没有那个文件或目录
使用rosls
rosls与roscd类似, 不多介绍.
Tab补全
rosls, roscd, TAB都与Linux shell提供了同样的功能, 不多介绍
此类书写风格在ROS工具中很常用.
此章节使用roscreate-pkg
或catkin
创建一个新的package, 并用rospack列出包的的依赖关系.
必须包含一个catkin兼容的package.xml文件
必须包含一个使用catkin的CMakeLists.txt
每个package必须有自己的文件夹: 这意味着没有嵌套的包,也没有共享同一目录的多个包.
最简单的package如下:
my_package/
CMakeLists.txt
package.xml
使用catkin packages工作的推荐方式是使用catkin工作空间, 当然也可以单独建立一个catkin package. 一个普通的工作空间大概如下:
workspace_folder/ -- WORKSPACE
src/ -- SOURCE SPACE
CMakeLists.txt -- 'Toplevel' CMake file, provided by catkin
package_1/
CMakeLists.txt -- CMakeLists.txt file for package_1
package.xml -- Package manifest for package_1
...
package_n/
CMakeLists.txt -- CMakeLists.txt file for package_n
package.xml -- Package manifest for package_n
创建工作空间的方法见: 1.2 创建ROS工作空间
catkin_create_pkg
$ cd ~/catkin_ws/src
$ catkin_create_pkg beginner_tutorials std_msgs rospy roscpp
$ cd ~/catkin_ws
$ catkin_make
$ . ~/catkin_ws/devel/setup.bash
一级依赖: $ rospack depends1 beginner_tutorials
此命令的输出与穿件package时传入的参数一致, 这些对packages的依赖存储在package.xml中.
间接依赖: $ rospack depends1 rospy
大多数情况下, 一个依赖项都会有它自己的依赖. rospack可以递归检测所有的嵌套依赖.
定制package.xml
包括description, maintainer, license, dependencies(包括了buildtool_depend, build_depend, exec_depend)
定制CMakeLists.txt
catkin_make可以看做是组合调用了标准Cmake工作流: cmake, make
# In a CMake project
$ mkdir build
$ cd build
$ cmake ..
$ make
$ make install # (optionally)
# In a catkin workspace
$ catkin_make
$ catkin_make install # (optionally)
catkin_make命令将编译src
目录下的所有工程. 对于源码不在当前目录下的使用方法为:
# In a catkin workspace
$ catkin_make --source my_src
$ catkin_make install --source my_src # (optionally)
编译Package
在当前工作空间中(~/catkin_ws/): catkin_make
.
本节引入ROS graph的概念, 并探讨roscore, rosnode, rosrun的使用.
可执行程序
.在ROS package中, 一个node实际上只不过是一个可执行文件. ROS nodes使用ROS client library与其他nodes进行通信. Nodes可以发布和订阅一个Topic. Nodes也可以提供或使用一个Service.
ROS client library允许使用不同编程语言写出来的nodes进行通信
roscore是当你使用ROS时第一个应该运行的东西
rosnode显示当前正在运行的有关ROS nodes的信息
#列出活跃状态的nodes
$ rosnode list
#显示有关指定node的信息
$ rosnode info /rosout
rosrun允许使用package名来直接运行一个package中的node(不用非得知道package的路径).
#Usage:
$ rosrun [package_name] [node_name]
#run the turtlesim_node in the turtlesim package
$ rosrun turtlesim turtlesim_node
ROS支持为node重新指定名字
$ rosrun turtlesim turtlesim_node __name:=my_turtle
linux@linux:~$ rosnode list
/my_turtle
/rosout
可以使用$ rosnode ping my_turtle
来测试是否真的跑起来了.
本节引入ROS topics, 与此同时使用rostopic和rqt_plot工具.
roscore
可进行测试$ rosrun turtlesim turtlesim_node
$ rosrun turtlesim turtle_teleop_key
, 使用方向键控制turtle移动使用rqt-graph
rqt-graph
创建系统的一个动态图. rtq-graph
是rqt package
的一部分, 安装方法如下:
$ sudo apt-get install ros-<distro>-rqt
$ sudo apt-get install ros-<distro>-rqt-common-plugins
在新终端中输入:$ rosrun rqt_graph rqt_graph
会出现一个可视化窗口, 显示nodes之间的关系.
引入rostopic
rostopic
工具用来获取ROS topics.
使用rostopic echo
rostopic echo
显示发布在一个topic上的数据, 只有在运行之后有新的消息发布到topic上时才会有输出.
#Usage:
$ rostopic echo [topic]
$ rostopic echo /turtle1/cmd_vel
使用rostopic list
使用$ rostopic list -v
列出所有的topics
topics上的通信是通过在nodes之间发送ROS messages进行的. 发布者和订阅者必须发送和接收同种类型的消息. 这意味着, topic的类型是由发布在其上的message类型定义的. message的类型可通过rostopic type [topic]
来查询. 可以使用rosmsg show type
查看信息格式.
rostopic pub
可以在一个topic上发布数据
#Usage:
$ rostopic pub [topic] [msg_type] [args]
#双短线表示后边的不是命令选项
$ rostopic pub -1 /turtle1/cmd_vel geometry_msgs/Twist -- '[2.0, 0.0, 0.0]' '[0.0, 0.0, 1.8]'
rostopic hz
报告数据发布速率: $ rostopic hz [topic]
使用指令: $ rosrun rqt_plot rqt_plot
, 添加需要查看的topic即可.
本节介绍ROS Services and Parameters, 与此同时使用rosservice和rosparam命令行工具. Services
是nodes间进行通信的另一种方式, Services
允许nodes发送一个请求(request和接收一个响应(response).
#Usage:
rosservice list [topic]#列出[topic]所提供的服务
rosservice type [service]#显示服务类型
rosservice call [service] [args]#调用服务
#查看带参数的示例
rosservice find #find services by service type
rosservice uri #print service ROSRPC uri
$ rosservice type /spawn | rossrv show
float32 x
float32 y
float32 theta
string name
---
string name
$ rosservice call /spawn 2 2 0.2 ""#name field is optional
name: turtle2
rosparam
循序我们存储和操作ROS Parameter Server
上的数据, Parameter Server
可以存储整型, 浮点型, 布尔型, 字典, 列表. rosparam
使用YAML
标记语言语法.
#Usage:
rosparam set [param_name] #set parameter
#设置参数之后使用/clear服务刷新操作
$ rosservice call /clear
rosparam get [param_name] #get parameter
rosparam load #load parameters from file
rosparam dump #dump parameters to file
rosparam delete #delete parameter
rosparam list #list parameter names
#Usage:
rosparam dump [file_name] [namespace]
rosparam load [file_name] [namespace]
#write all the parameters to the file params.yaml
$ rosparam dump params.yaml
# load these yaml files into new namespaces, e.g. copy
$ rosparam load params.yaml copy
$ rosparam get /copy/background_b