优化器:g2o快速上手

一、方法总览

使用g2o进行优化的时候,总体流程大约需要如下几个步骤:

is-a: 表示继承关系
has-a、has-many:表示包含关系
在这里插入图片描述

二、举例说明

十四讲中的一个例子。我们来看下怎么使用g2o实现非线性优化。
在这里插入图片描述

1. 代码实现

基本就是按照总览中的图来进行配置:

  • 设置线性求解器
  • 使用线性求解器初始化BlockSolver
  • 使用BlockSolver的指针初始化solver(这时候选择具体的solver形式)
  • 设置优化器:配置优化器的求解方案为solver
  • 往图模型中添加对应的节点和边
  • 最后执行优化

头文件:

在这里插入图片描述

代码实现如下所示:
在这里插入图片描述

2. 对应图模型

这个例子中的对应图模型样子:

其中每条边就是每次观测。

在这个例子中,每次的观测就是(x, y)数据值。
在这里插入图片描述

3. 对应的点和边的写法

顶点部分
  • 确定点的维度和数据类型
  • 设置估计值,也就是初始值
  • 设置点的更新方式(如果是旋转的话,更新就不是简单的加法)
边部分
  • 确定边的维度(error维度),数据类型和对应顶点的数据类型
  • 确定计算误差方式(通常需要计算雅克比)
    在这里插入图片描述

三、自定义边

通常做优化,最重要也最容易出错的地方,就是定义边。

继承的话,如下四个函数必须重写。
在这里插入图片描述

函数具体解释:

在这里插入图片描述
另外的一些重要参数:

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值