Ethzasl MSF源码阅读(1):程序入口和主题订阅

2023-05-16

关于IMU融合知乎上的一篇问答:有哪些开源项目是关于单目+imu做slam的?

Ethz的Stephen Weiss的工作,是一个IMU松耦合的方法。

1.程序入口:ethzasl_msf\msf_updates\src\pose_msf\main.cpp


1 #include "pose_sensormanager.h"
2 
3 int main(int argc, char** argv)
4 {
5   ros::init(argc, argv, "msf_pose_sensor");
6   msf_pose_sensor::PoseSensorManager manager;
7   ros::spin();
8   return 0;
9 }  

PoseSensorManager类,查看构造函数。PoseSensorManager继承自msf_core::MSF_SensorManagerROS,继承自msf_core::MSF_SensorManager<EKFState_T>


 1 PoseSensorManager(ros::NodeHandle pnh = ros::NodeHandle("~/pose_sensor"))
 2 {
 3     bool distortmeas = false;  //< Distort the pose measurements.
 4     imu_handler_.reset(new msf_core::IMUHandler_ROS<msf_updates::EKFState>(*this, "msf_core", "imu_handler"));
 5     pose_handler_.reset(new PoseSensorHandler_T(*this, "", "pose_sensor", distortmeas)); AddHandler(pose_handler_);
 6 
 7     reconf_server_.reset(new ReconfigureServer(pnh));
 8     ReconfigureServer::CallbackType f = boost::bind(&PoseSensorManager::Config, this, _1, _2);//回调
 9     reconf_server_->setCallback(f);
10 
11     init_scale_srv_ = pnh.advertiseService("initialize_msf_scale",
12                                            &PoseSensorManager::InitScale, this);
13     init_height_srv_ = pnh.advertiseService("initialize_msf_height",
14                                             &PoseSensorManager::InitHeight, this);
15   }  

 2. 注意其中的imu_handler_和pose_handler_,分别是IMUHandler_ROS对象和PoseSensorHandler模板类对象。IMUHandler_ROS继承自IMUHandler。


typedef PoseSensorHandler<msf_updates::pose_measurement::PoseMeasurement<>,
      PoseSensorManager> PoseSensorHandler_T;  

(msf_updates::pose_measurement::PoseMeasurement<>是模型类PoseSensorHandler的类参数,这是一个观测量参数。)

注意IMUHandler和PoseSensorHandler最终都继承自msf_core::SensorHandler<typename msf_updates::EKFState>类。

这两个类对象构造的时候都传入了*this指针,即PoseSensorManager对象自身。这很重要,两个类中都调用了PoseSensorManager的成员函数。

可以进入这两个类进行查看构造函数,这2个构造函数都进行了一些主题的订阅。

 IMUHandler_ROS构造,同时查看IMUHandler_ROS::IMUCallback回调函数。


1 IMUHandler_ROS(MSF_SensorManager<EKFState_T>& mng,
2                  const std::string& topic_namespace, const std::string& parameternamespace)
3        : IMUHandler<EKFState_T>(mng, topic_namespace, parameternamespace) 
4 {
5     ros::NodeHandle nh(topic_namespace);
6     subImu_ = nh.subscribe("imu_state_input", 100, &IMUHandler_ROS::IMUCallback, this);
7     subState_ = nh.subscribe("hl_state_input", 10,   &IMUHandler_ROS::StateCallback, this);
8 }  

  PoseSensorHandler构造,同时查看PoseSensorHandler::MeasurementCallback回调函数。


 1 template<typename MEASUREMENT_TYPE, typename MANAGER_TYPE>
 2 PoseSensorHandler<MEASUREMENT_TYPE, MANAGER_TYPE>::PoseSensorHandler(
 3     MANAGER_TYPE& meas, std::string topic_namespace,
 4     std::string parameternamespace, bool distortmeas)
 5     : SensorHandler<msf_updates::EKFState>(meas, topic_namespace, parameternamespace),
 6       n_zp_(1e-6),
 7       n_zq_(1e-6),
 8       delay_(0),
 9       timestamp_previous_pose_(0) 
10 {
11   ros::NodeHandle pnh("~/" + parameternamespace);
12 
13   MSF_INFO_STREAM(
14       "Loading parameters for pose sensor from namespace: "
15           << pnh.getNamespace());
16 
17   pnh.param("pose_absolute_measurements", provides_absolute_measurements_,
18             true);
19   pnh.param("pose_measurement_world_sensor", measurement_world_sensor_, true);
20   pnh.param("pose_use_fixed_covariance", use_fixed_covariance_, false);
21   pnh.param("pose_measurement_minimum_dt", pose_measurement_minimum_dt_, 0.05);
22   pnh.param("enable_mah_outlier_rejection", enable_mah_outlier_rejection_, false);
23   pnh.param("mah_threshold", mah_threshold_, msf_core::kDefaultMahThreshold_);
24 
25   MSF_INFO_STREAM_COND(measurement_world_sensor_, "Pose sensor is interpreting "
26                        "measurement as sensor w.r.t. world");
27   MSF_INFO_STREAM_COND(
28       !measurement_world_sensor_,
29       "Pose sensor is interpreting measurement as world w.r.t. "
30       "sensor (e.g. ethzasl_ptam)");
31 
32   MSF_INFO_STREAM_COND(use_fixed_covariance_, "Pose sensor is using fixed "
33                        "covariance");
34   MSF_INFO_STREAM_COND(!use_fixed_covariance_,
35                        "Pose sensor is using covariance "
36                        "from sensor");
37 
38   MSF_INFO_STREAM_COND(provides_absolute_measurements_,
39                        "Pose sensor is handling "
40                        "measurements as absolute values");
41   MSF_INFO_STREAM_COND(!provides_absolute_measurements_, "Pose sensor is "
42                        "handling measurements as relative values");
43 
44   ros::NodeHandle nh("msf_updates/" + topic_namespace);
45   subPoseWithCovarianceStamped_ =
46       nh.subscribe < geometry_msgs::PoseWithCovarianceStamped
47           > ("pose_with_covariance_input", 20, &PoseSensorHandler::MeasurementCallback, this);
48   subTransformStamped_ = nh.subscribe < geometry_msgs::TransformStamped
49       > ("transform_input", 20, &PoseSensorHandler::MeasurementCallback, this);
50   subPoseStamped_ = nh.subscribe < geometry_msgs::PoseStamped
51       > ("pose_input", 20, &PoseSensorHandler::MeasurementCallback, this);
52 
53   z_p_.setZero();
54   z_q_.setIdentity();
55 
56   if (distortmeas)
57  {
58     Eigen::Vector3d meanpos;
59     double distortpos_mean;
60     pnh.param("distortpos_mean", distortpos_mean, 0.0);
61     meanpos.setConstant(distortpos_mean);
62 
63     Eigen::Vector3d stddevpos;
64     double distortpos_stddev;
65     pnh.param("distortpos_stddev", distortpos_stddev, 0.0);
66     stddevpos.setConstant(distortpos_stddev);
67 
68     Eigen::Vector3d meanatt;
69     double distortatt_mean;
70     pnh.param("distortatt_mean", distortatt_mean, 0.0);
71     meanatt.setConstant(distortatt_mean);
72 
73     Eigen::Vector3d stddevatt;
74     double distortatt_stddev;
75     pnh.param("distortatt_stddev", distortatt_stddev, 0.0);
76     stddevatt.setConstant(distortatt_stddev);
77 
78     double distortscale_mean;
79     pnh.param("distortscale_mean", distortscale_mean, 0.0);
80     double distortscale_stddev;
81     pnh.param("distortscale_stddev", distortscale_stddev, 0.0);
82 
83     distorter_.reset( new msf_updates::PoseDistorter(meanpos, stddevpos, meanatt, stddevatt, distortscale_mean, distortscale_stddev));
84   }
85 }  

 3.reconf_server_->setCallback(f)绑定了一个回调,回调函数PoseSensorManager::Config(xx).


 1 virtual void Config(Config_T &config, uint32_t level)
 2 {
 3     config_ = config;
 4     pose_handler_->SetNoises(config.pose_noise_meas_p,
 5                              config.pose_noise_meas_q);
 6     pose_handler_->SetDelay(config.pose_delay);
 7     if ((level & msf_updates::SinglePoseSensor_INIT_FILTER)
 8         && config.core_init_filter == true) 
 9     {
10       Init(config.pose_initial_scale);
11       config.core_init_filter = false;
12     }
13     // Init call with "set height" checkbox.
14     if ((level & msf_updates::SinglePoseSensor_SET_HEIGHT)
15         && config.core_set_height == true)
16      {
17       Eigen::Matrix<double, 3, 1> p = pose_handler_->GetPositionMeasurement();
18       if (p.norm() == 0) 
19       {
20         MSF_WARN_STREAM(
21             "No measurements received yet to initialize position. Height init "
22             "not allowed.");
23         return;
24       }
25       double scale = p[2] / config.core_height;
26       Init(scale);
27       config.core_set_height = false;
28     }
29 }  

 参考文献:

多传感器卡尔曼融合框架 Ethzasl MSF Framework 编译与使用

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Ethzasl MSF源码阅读(1):程序入口和主题订阅 的相关文章

  • Linux练习(write写入)

    include lt unistd h gt include lt stdlib h gt int main if write 1 34 here is some data n 34 18 61 18 write 2 34 write er
  • matlab练习程序(随机游走图像)

    随机游走类似布朗运动 xff0c 就是随机的向各个方向走吧 虽然代码没什么技术含量 xff0c 不过产生的图像实在太漂亮了 xff0c 所以还是贴上来吧 产生的图像 xff1a matlab代码如下 xff1a clear all clos
  • [翻译完成] 树莓派搭建Google TV

    为什么80 的码农都做不了架构师 xff1f gt gt gt Google TV是啥玩意 Google TV是支持自选图像 宽带网络 传统电视信号的综合平台 xff0c 更附带电视节目搜索功能 谷歌公布了其新版电视的两个版本 第一个叫做B
  • jdk17.0.1安装教程

    1 解压到某文件夹 2 在此电脑 gt 属性 gt 高级系统设置 gt 环境变量 gt 系统变量 加一条JAVA HOME 3 在系统变量Path里 xff0c 加一条 JAVA HOME bin xff08 不能放在第一条 xff09 4
  • 推荐几本GIS专业书籍

    对于开设GIS专业的高校 xff0c 基本上都会有自己的专业教材 xff0c 用的比较多的像邬伦的 地理信息系统 xff1a 原理 方法和应用 和中科院陈述彭院士的 地理信息系统导论 在当初考研的时候 xff0c 自己也买了不少教材 xff
  • Linux 通过命令发送udp 数据

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 如果往本地UDP端口發送數據 xff0c 那麼可以使用以下命令 xff1a echo hello gt dev udp 192 168 1 81 5060 意思是往本地19
  • Qt学习之路(17): Qt标准对话框之QMessageBox

    好久没有更新博客 xff0c 主要是公司里面还在验收一些东西 xff0c 所以没有及时更新 而且也在写一个基于Qt的画图程序 xff0c 基本上类似于PS的东西 xff0c 主要用到的是Qt Graphics View Framework
  • 2019年开发者必读!20位阿里技术大牛们帮你列了一份经典书单! ...

    导读 xff1a 寒冬中 xff0c 最值得投资的是学习 xff0c 是增厚的知识储备 下面就是20位阿里技术大牛们为我们推荐的经典书籍 书籍类型涉及技术 管理 哲学等方面 xff0c 希望这些书籍陪伴你度过这个漫长的寒冬 书单之外 xff
  • 发表一篇顶会论文的经验分享

    背景 xff1a 最近半个月 xff0c 对之前发表的一篇顶会论文进行了修改 xff0c 并重新提交了 这篇论文是一篇计算机领域的A会文章 本篇文章主要对计算机领域论文写作及发表过程中的相关经验做一个总结 希望可以对研究生小白们有点用 刚刚
  • jQuery的md5加密插件及其它js md5加密代码

    jQuery MD5 hash algorithm function lt code gt Calculate the md5 hash of a String String md5 String str lt code gt Calcul
  • matlab双目相机标定校正_基于双目视觉的无人机避障算法(一)

    讲述在10月到12月所做的所有工作 对于一个无人机自主避障来说 xff0c 存在着以下流程 xff1a 感知 xff1a 障碍物检测 行人检测 目标检测SLAM xff1a 为无人机提供位置估计 xff0c 构建稀疏环境地图路径规划 xff
  • pdf文件显示白色

    主要原因是pdf默认关联应用 xff0c 在版本更替时出现了错误 xff0c 重新给pdf设置一下默认关联应用即可 window10步骤如下 xff1a 1 打开我的电脑 选择计算机 打开设置 2 点 应用 3 选择 默认应用 中的 按文件
  • mysql数据库想要保持固定条数数据的操作

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 限定数据库数据条数 xff1a SELECT FROM 表名 order by 字段 desc limit 条数 这样查询到的是倒数几条数据 xff0c 保证了最新的数据
  • Docker容器的创建、启动、和停止

    1 容器是独立运行的一个或一组应用 xff0c 及他们的运行环境 容器是Docker中的一个重要的概念 2 docker容器的启动有三种方式 a 交互方式 xff0c 基于镜像新建容器并启动 例如我们可以启动一个容器 xff0c 打印出当前
  • 每天一个linux命令(4):mkdir命令

    linux mkdir 命令用来 创建指定的 名称的 目录 xff0c 要求创建目录的用户在当前目录中具有写权限 xff0c 并且指定的目录名不能是当前目录中已有的目录 1 xff0e 命令格式 xff1a mkdir 选项 目录 2 xf
  • ansible报错:Failed to connect to the host via ssh: Permission denied

    原因 xff1a 没有在ansible管理节点 xff08 即安装ansible的节点 xff09 上添加目标节点 xff08 即需要管理的节点 xff09 的ssh认证信息 解决办法 xff1a 1 在管理节点生成公钥 ssh keyge
  • 值传递和引用传递-----函数参数传递的两种方式

    回顾 xff1a 在定义函数时函数括号中的变量名成为形式参数 xff0c 简称形参或虚拟参数 xff1b 在主调函数中调用一个函数时 xff0c 该函数括号中的参数名称为实际参数 xff0c 简称实参 xff0c 实参可以是常量 变量或表达
  • Andriod监听支付宝收款实现个人支付宝支付接口!附安卓App

    首先呢 xff0c 我不会开发安卓App xff0c 这款APP是我在酷安网看到的 xff0c 非常简单的一款APP xff0c 安装后填写我们的后端接口 xff08 用于接收收款通知的 xff09 就可以接收收款通知了 所以就算我们没有这
  • 记一次异常排查过程:druid连接池抛出DataSourceDisableException

    为什么80 的码农都做不了架构师 xff1f gt gt gt 先交待下项目背景 xff0c 项目中有个功能是从mysql中获取数据库信息来创建数据库连接 xff0c 用的连接池是druid xff0c jar包版本是1 0 9 1 异常的
  • 3389、135、137、138、139、445等端口解释和关闭方法

    3389端口 xff1a 在服务器中 xff0c 3389端口的开放是必需的 xff0c 因为任何服务器的管理员如果想很好地管理自己的服务器 xff0c 都需要开启这种方便的网络管理服务 不过3389端口一旦开启 xff0c 必然会引来无数

随机推荐

  • 同一个mock 连续多次调用返回不同结果实现方式

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 同一个mock 连续多次调用返回不同结果实现方式 Mockito when methodCall thenReturn 1x thenReturn 2x thenRetur
  • 特别策划:大学毕业生自主创业分析

    转 特别策划 大学毕业生自主创业分析 本期特别策划以 大学毕业生自主创业 为题 xff0c 主要分为两个部分 xff0c 第一部分对大学毕业生自主创业的分布与特点进行了研究分析 xff0c 第二部分为有意向自主创业的大学生提供建议 PART
  • vscode界面上最左边那一栏不见了

    查看 gt 外观 gt 显示活动栏
  • 论文下载&论文阅读方法(吴恩达教你读论文)

    标题 一 论文下载二 吴恩达读论文方法2 1 主体2 2 Math2 3 Coding 三 职业生涯四 给出的建议五 参考 一 论文下载 Source of paper twitter ML subreddit NIPS ICML ICLR
  • 基于有向距离场(SDF)的地图碰撞系统 | Cocos 技术派第15期

    近日 xff0c ID 为 kx dz 的开发者在 Cocos 中文社区分享了一篇名为 介绍一个基于有向距离场 SDF 的地图碰撞系统 的技术文章 xff0c 获得诸多好评 C姐第一时间联系到了作者 xff0c 在获得转载授权的同时 xff
  • SQL 查询当天,本月,本周的记录

    SELECT FROM 表 WHERE CONVERT Nvarchar dateandtime 111 61 CONVERT Nvarchar GETDATE 111 ORDER BY dateandtime DESC 本月记录 SELE
  • VC查找网页源码指定内容

    查找网页源码 xff0c 这段代码也可以作为获取外网IP xff0c 不过获取外网IP只需要前面一部分就行了 xff0c 把网页源码读到缓冲区就行了 CString SiteInfo SiteName 61 http www ip138 c
  • 笔试之内存分配问题

    需要知道的概念 xff1a 1 程序 xff1a 包括代码和数据 xff0c 是静态的概念 2 进程 xff1a 程序的执行过程 xff0c 是指一个程序中的代码在一个数据集合中的运行过程 xff0c 所以说相同代码在不同的数据集合上运行
  • 计算机视觉基础(三)——对极几何中的基本矩阵F和本质矩阵E

    计算机视觉中 xff0c 尤其是双视图几何中 xff0c 基本矩阵F和本质矩阵E扮演着重要角色 xff0c 今天我们就来简单了解一下它们吧 由于公式比较多 xff0c 所以直接在word中编辑好后整个截图过来了 xff08 参考书目 计算机
  • 使用docker搭建开发环境

    我的主力机是windows windows下面有太多提升效率的软件 但是开发的时候不得不使用linux 就单单开发而言 我还是喜欢使用linux 所以就造成了我得在windows下面使用虚拟机 这是最开始的办法 后面得知有vagrant这个
  • ROS的单线程Spinning和多线程Spinning

    单线程Spinning ros spin 是最简单的单线程自旋 它会一直调用直到结束 用法 ros spin 另一个单线程spinning是ros spinOnce 它定期调用等待在那个点上的所有回调 用法 ros spinOnce 简单的
  • antd 的form 表单怎么回显数据_antd Form表单的initialValue问题

    在initial中是有初始值的 xff0c 但是却不显示初始值 xff0c 请大佬解答一下这个问题 const formItem 61 type 3 label 39 柜子编号 39 name 39 ID 39 width 39 150px
  • echarts 与 highcharts

    一 xff0e 简介 echarts echarts是百度公司前端开发的一个图表库 xff0c 2013年发布第一版 xff0c 主要采用canvas画图 xff0c 目前版本3 8 4 xff1b 完全免费 xff1b highchart
  • c语言不同源文件变量,我在哪里可以在c程序中声明全局变量,无论是在头文件还是源文件中...

    本问题已经有最佳答案 xff0c 请猛点这里访问 嗨 xff0c 我是一个C 43 43 开发者 xff0c 现在我正在做C编程 我的问题是 xff0c 在C程序中 xff0c 哪个地方更好地声明全局变量 头文件或源文件 如果我的全局变量未
  • ***网址大全

    网址大全 最全的 国内 基地 http www hackbase com 帝国 http www darkup com 中国 联盟 http www chinahacker com起点 网络 http www qdhack com 边缘 h
  • 监控硬盘容量计算

    如何快速的计算摄像头一天存储量 摄像机的码流即监控视频流的带宽 xff0c 分为主码流和子码流 xff0c 主码流用来存储 xff0c 子码流一般用来预览 xff0c 所以录像回放时大家看到的视频质量要高于预览时看到的 在不同分辨率 帧率以
  • 【原】Hadoop伪分布模式的安装

    Hadoop伪分布模式的安装 环境参数 1 Host OS xff1a Win7 64bit 2 IDE xff1a Eclipse Version Luna Service Release 2 4 4 2 3 虚拟机 xff1a VMwa
  • 背景建模技术(四):视频分析(VideoAnalysis)模块

    视频分析模块主要包含两个函数 xff0c 一个是VideoAnalysis setup xff08 xff09 xff0c 其主要功能就是确定测试的视频是视频文件或摄像头输入亦或是采用命令行参数 xff1b 第二个函数是VideoAnaly
  • ubuntu 安装docker + seagull实现图形化管理

    环境 xff1a ubuntu 14 04 server 通过Docker源安装最新版本 要安装最新的 Docker 版本 xff0c 首先需要安装 apt transport https 支持 xff0c 之后通过添加源来安装 sudo
  • Ethzasl MSF源码阅读(1):程序入口和主题订阅

    关于IMU融合知乎上的一篇问答 xff1a 有哪些开源项目是关于单目 43 imu做slam的 xff1f Ethz的Stephen Weiss的工作 xff0c 是一个IMU松耦合的方法 1 程序入口 xff1a ethzasl msf