[ROS] 多传感器卡尔曼融合框架 Ethzasl MSF Framework 编译与使用
多传感器融合是机器人导航上面一个非常基本的问题,通常在一个稳定可用的机器人系统中,会使用视觉(RGB或RGBD)、激光、IMU、马盘等一系列传感器的数据来最终输出一个稳定和不易丢失的姿态。Ethzasl MSF Framework 是一个机器人上面的多传感器融合框架,它使用了扩展卡尔曼的原理对多传感器进行融合。同时内部使用了很多工程上的 trick 解决多传感器的刷新率同步等问题,API 封装也相对简单,非常适合新手使用。
0、系统环境:
Ubuntu 14.04.3
ROS indigo
1、新建 MSF 工作目录:
在命令行执行如下命令:
1 2 3 | mkdir -p MSF/src cd ./MSF/src catkin_init_workspace |
退出 src 目录到 PATH_TO_MSF 根目录下,编译生成 ROS 工程文件:
1 2 | cd .. catkin_make |
后面我们将这个新建的 MSF 路径称为 PATH_TO_MSF。
2、下载依赖库和 Ethzasl MSF Framework:
进入 PATH_TO_MSF/src 目录。
1 | cd ./src |
在此目录下载所有依赖库和 MSF 框架。
1)下载 glog:
1 | git clone https://github.com/ethz-asl/glog_catkin.git |
2)下载 catkin_simple:
1 | git clone https://github.com/catkin/catkin_simple.git |
3)下载 asctec_mav_framework:
1 | git clone https://github.com/ethz-asl/asctec_mav_framework.git |
4)最后下载 Ethzasl MSF Framework 框架源代码:
1 | git clone https://github.com/ethz-asl/ethzasl_msf.git |
3、编译 ROS 工程:
1)设置环境:
退出 src 目录,进入 PATH_TO_MSF 目录。在命令行中使用如下命令设置当前窗口的编译环境:
1 2 | cd .. source devel/setup.bash |
2)再次编译整个工程:
1 | catkin_make |
中间可能会出现很多 warning,不过最后如果能够 100% 完成 built target 就成功了。
4、运行例子: MSF Viconpos Sensor Framework(使用 ROS Bag):
官方的例子使用了 Vicon 的设备进行 6ROF 的姿态估计,这个传感器很专业,但是我们一般没有。这里面我们使用官方提供的一个 bag 文件来进行模拟。
这个数据包有 3.8 MB 左右,如果速度慢的可以下载我百度网盘的文件:
http://pan.baidu.com/s/1eShq7lg
我这里将其放置在 PATH_TO_MSF/data 目录下面。
2)修改 src/ethzasl_msf/msf_updates/viconpos_sensor_fix.yaml 文件:
将其中所有的:
1 | /pose_sensor/pose_sensor/ |
替换为:
1 | /msf_viconpos_sensor/pose_sensor/ |
找到:
1 | /pose_sensor/core/data_playback: false |
修改成:
1 | /pose_sensor/core/data_playback: true |
3)修改 src/ethzasl_msf/msf_updates/launch/viconpos_sensor.launch 文件:
找到:
1 | <rosparam file="$(find msf_updates)/viconpos_sensor_fix.yaml"/> |
在这一行的前面加入两行 remap 操作,将传感器的 topic 与引擎的 topic 对应上:
1 2 | <remap from="/msf_core/imu_state_input" to="/auk/fcu/imu" /> <remap from="msf_updates/transform_input" to="/vicon/auk/auk" /> |
找到:
1 | </node> |
在其之后添加(这一步是初始化卡尔曼滤波器的,非常重要):
1 | <node pkg="rosservice" type="rosservice" name="initialize" args="call --wait /msf_viconpos_sensor/pose_sensor/initialize_msf_scale 1"/> |
4)启动 ros 内核:
在一个窗口打开 roscore:
1 | roscore |
5)启动 MSF pose_sensor 节点:
快捷键 Ctrl + Alt + T 新建窗口,在 PATH_TO_MSF 目录下执行如下命令打开 pose_sensor 节点:
1 2 | source devel/setup.bash roslaunch msf_updates viconpos_sensor.launch |
6)打开动态配置参数功能(可选):
快捷键 Ctrl + Alt + T 新建窗口,执行如下命令打开动态配置功能:
1 | rosrun rqt_reconfigure rqt_reconfigure |
可以看到如下窗口,在窗口中选中 msf_viconpos_sensor 下面菜单:
在菜单中即可动态设置参数。
7)播放 vicon 的 bag 文件:
快捷键 Ctrl + Alt + T 新建窗口,在 PATH_TO_MSF 目录下执行如下命令:
1 | rosbag play data/dataset.bag --pause -s 25 |
这一行命令是暂停并从第 25s 后开始播放 bag 文件,文档中说这是为了等待 MAV 硬件系统站稳并处于非观察模式(不理解)。
总之,如果你准备好运行了,就可以开始点击空格键进行数据播放了,播放的数据大约剩余 86s 左右。
切换到 MSF pose_sensor 节点的窗口,如果你看到输出类似如下的窗口,就是表示系统运行成功了:
5、数据模拟:
刚才跑成功了数据融合节点,但是并没有任何可视化的输出可以给我们看到。ethzasl msf 提供了一些脚本来进行数据模拟的功能,可以让我们更直观地看到结果。
1)修改 src/ethzasl_msf/msf_core/scripts/plot_relevant 文件:
找到:
1 2 | rxplot msf_core/state_out/data[0]:data[1]:data[2] msf_core/state_out/data[3]:data[4]:data[5] -b $T -t "position & velocity" -l px,py,pz,vx,vy,vz & rxplot msf_core/state_out/data[13]:data[14]:data[15] msf_core/state_out/data[16] -b $T -t "acc bias & scale" -l x,y,z,L |
修改成:
1 2 3 | rqt_plot msf_core/state_out/data[0]:data[1]:data[2] # rxplot msf_core/state_out/data[0]:data[1]:data[2] msf_core/state_out/data[3]:data[4]:data[5] -b $T -t "position & velocity" -l px,py,pz,vx,vy,vz & # rxplot msf_core/state_out/data[13]:data[14]:data[15] msf_core/state_out/data[16] -b $T -t "acc bias & scale" -l x,y,z,L |
2)启动 plot_relevant 脚本:
快捷键 Ctrl + Alt + T 新建窗口,在 PATH_TO_MSF 目录下执行如下命令打开 plot_relevant 脚本:
1 2 | source devel/setup.bash rosrun msf_core plot_relevant |
另外也可以直接在命令行运行:
1 | rqt_plot msf_core/state_out/data[0]:data[1]:data[2] |
如果一切正常,即可看到如下曲线绘制,这样就表示成功运行起来了:
好巧,我也再看,ROS官网的那个tutorial看的实在是费劲。
你好,请问你的编译通过了么
编译通过了
您好,请问我总是在编译时85%出错:
[ 85%] Completed 'glog_src'
[ 85%] Built target glog_src
Linking CXX executable /home/zhenghan/MSF/devel/lib/asctec_hl_gps/gps_conversion_node
[ 85%] Built target gps_conversion_node
make: *** [all] 错误 2
Invoking "make -j4 -l4" failed
是什么原因,该怎么解决呢?谢谢!
使用我的那个包也有问题吗?我的确没遇到。如果不行可以试试改成单线程编译价格 -j1 之类的
你最后是怎么解决的呢,我也遇到了同样的问题
请问怎么解决
hello,我编译时提示找不到文件 #include ,请教下在哪里呢?
make[2]: *** 没有规则可以创建“/home/blue/MSF/devel/lib/libmsf_core.so”需要的目标“/home/blue/MSF/devel/lib/libglog.so”。 停止。
请问有人遇到过这么问题么?
我也遇到这个问题,你解决了吗
有人在编译到时候遇到这种情况吗?下载不了?
####
#### Running command: "make -j4 -l4" in "/home/wangzihui/MSF/build"
####
[ 0%] Built target std_msgs_generate_messages_py
[ 1%] Built target msf_timing
[ 1%] Built target geometry_msgs_generate_messages_py
[ 2%] Performing download step (download, verify and extract) for 'glog_src'
-- downloading...
src='https://github.com/google/glog/archive/v0.3.5.zip'
dst='/home/wangzihui/MSF/build/glog_catkin/glog_src-prefix/src/v0.3.5.zip'
timeout='none'
CMake Error at glog_src-stamp/download-glog_src.cmake:21 (message):
error: downloading 'https://github.com/googe/glog/archive/v0.3.5.zip'
failed
你是怎么解决的呀
请问你是怎么解决的,我也有这个问题
我也是这个问题,试了很多种办法都解决不了,请问你怎么解决的?
请问遇到这种情况该怎么办呢?
#### Running command: "make -j4 -l4" in "/home/wangzihui/MSF/build"
####
[ 1%] Performing download step (download, verify and extract) for 'glog_src'
[ 2%] Built target std_msgs_generate_messages_py
[ 2%] Built target msf_timing
-- downloading...
src='https://github.com/google/glog/archive/v0.3.5.zip'
dst='/home/wangzihui/MSF/build/glog_catkin/glog_src-prefix/src/v0.3.5.zip'
[ 2%] Built target geometry_msgs_generate_messages_py
timeout='none'
CMake Error at glog_src-stamp/download-glog_src.cmake:21 (message):
error: downloading 'https://github.com/google/glog/archive/v0.3.5.zip'
failed
status_code: 1
status_string: "Unsupported protocol"
log: Protocol "https" not supported or disabled in libcurl
Closing connection -1
CMake Error at /usr/share/catkin/cmake/catkinConfig.cmake:75 (find_package):
Could not find a package configuration file provided by
"message_generation" with any of the following names:
message_generationConfig.cmake
message_generation-config.cmake
Add the installation prefix of "message_generation" to CMAKE_PREFIX_PATH or
set "message_generation_DIR" to a directory containing one of the above
files. If "message_generation" provides a separate development package or
SDK, be sure it has been installed.
Call Stack (most recent call first):
asctec_mav_framework/asctec_hl_comm/CMakeLists.txt:4 (find_package)
-- Configuring incomplete, errors occurred!
See also "/home/tang/Documents/MSF/build/CMakeFiles/CMakeOutput.log".
See also "/home/tang/Documents/MSF/build/CMakeFiles/CMakeError.log".
Makefile:304: recipe for target 'cmake_check_build_system' failed
make: *** [cmake_check_build_system] Error 1
Invoking "make cmake_check_build_system" failed
请问这个该怎么解决呢?
Project 'msf_core' tried to find library 'glog'. The library is neither a
target nor built/installed properly. Did you compile project
'glog_catkin'? Did you find_package() it before the subdirectory containing
its code is included?