g2o -- curve_fit代码解析

2024-03-04 21:04
文章标签 代码 解析 curve fit g2o

本文主要是介绍g2o -- curve_fit代码解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

本文介绍通过g2o框架,优化点和曲线的匹配(曲线拟合)。曲线的公式如下所示:

它有三个参数:a, b, lamba。

代码解析

自定义顶点

/*** \brief the params, a, b, and lambda for a * exp(-lambda * t) + b*/
class VertexParams : public g2o::BaseVertex<3, Eigen::Vector3d> { // 它包含三个参数public:EIGEN_MAKE_ALIGNED_OPERATOR_NEW;VertexParams() {}bool read(std::istream& /*is*/) override { return false; }bool write(std::ostream& /*os*/) const override { return false; }void setToOriginImpl() override {} // 设定参数的原始值void oplusImpl(const double* update) override { // 增量更新函数,调整当前参数的值Eigen::Vector3d::ConstMapType v(update); // 构造参数增量_estimate += v;}
};

自定义边

/*** \brief measurement for a point on the curve** Here the measurement is the point which is lies on the curve.* The error function computes the difference between the curve* and the point.*/
class EdgePointOnCurve: public g2o::BaseUnaryEdge<1, Eigen::Vector2d, VertexParams> { // 一条边只含有一个顶点,使用上面定义顶点的数据结构public:EIGEN_MAKE_ALIGNED_OPERATOR_NEWEdgePointOnCurve() {}bool read(std::istream& /*is*/) override {cerr << __PRETTY_FUNCTION__ << " not implemented yet" << endl;return false;}bool write(std::ostream& /*os*/) const override {cerr << __PRETTY_FUNCTION__ << " not implemented yet" << endl;return false;}template <typename T>bool operator()(const T* params, T* error) const { // 误差函数const T& a = params[0];const T& b = params[1];const T& lambda = params[2];T fval = a * exp(-lambda * T(measurement()(0))) + b; // 计算理论值error[0] = fval - measurement()(1); // 和观察值进行比较return true;}G2O_MAKE_AUTO_AD_FUNCTIONS  // use autodiff
};

生成待拟合的点

  // generate random datag2o::Sampler::seedRand();double a = 2.;double b = 0.4;double lambda = 0.2;Eigen::Vector2d* points = new Eigen::Vector2d[numPoints];for (int i = 0; i < numPoints; ++i) {double x = g2o::Sampler::uniformRand(0, 10);double y = a * exp(-lambda * x) + b;// add Gaussian noisey += g2o::Sampler::gaussRand(0, 0.02);points[i].x() = x;points[i].y() = y;}

初始化求解器

  // setup the solverg2o::SparseOptimizer optimizer;optimizer.setVerbose(false);// allocate the solverg2o::OptimizationAlgorithmProperty solverProperty;optimizer.setAlgorithm(g2o::OptimizationAlgorithmFactory::instance()->construct("lm_dense",solverProperty));

添加顶点

在本示例中,只存在一个顶点,就是待优化的参数

  // 1. add the parameter vertexVertexParams* params = new VertexParams();params->setId(0);params->setEstimate(Eigen::Vector3d(1, 1, 1));  // 参数的初始化值optimizer.addVertex(params);

添加边

在本示例中,每一个待拟合点,都对应一条边。也就是一个观察点就是一个观测值。

  // 2. add the points we measured to be on the curvefor (int i = 0; i < numPoints; ++i) {EdgePointOnCurve* e = new EdgePointOnCurve;e->setInformation(Eigen::Matrix<double, 1, 1>::Identity());e->setVertex(0, params);e->setMeasurement(points[i]);optimizer.addEdge(e);}

求解器求解

  optimizer.initializeOptimization();optimizer.setVerbose(verbose);optimizer.optimize(maxIterations); // 最大的迭代次数

结果展示

  // print out the resultcout << "Target curve" << endl;cout << "a * exp(-lambda * x) + b" << endl;cout << "Iterative least squares solution" << endl;cout << "a      = " << params->estimate()(0) << endl;cout << "b      = " << params->estimate()(1) << endl;cout << "lambda = " << params->estimate()(2) << endl;cout << endl;

这篇关于g2o -- curve_fit代码解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/774429

相关文章

SQL 外键Foreign Key全解析

《SQL外键ForeignKey全解析》外键是数据库表中的一列(或一组列),用于​​建立两个表之间的关联关系​​,外键的值必须匹配另一个表的主键(PrimaryKey)或唯一约束(UniqueCo... 目录1. 什么是外键?​​ ​​​​2. 外键的语法​​​​3. 外键的约束行为​​​​4. 多列外键​

Java进行日期解析与格式化的实现代码

《Java进行日期解析与格式化的实现代码》使用Java搭配ApacheCommonsLang3和Natty库,可以实现灵活高效的日期解析与格式化,本文将通过相关示例为大家讲讲具体的实践操作,需要的可以... 目录一、背景二、依赖介绍1. Apache Commons Lang32. Natty三、核心实现代

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

SpringBoot实现二维码生成的详细步骤与完整代码

《SpringBoot实现二维码生成的详细步骤与完整代码》如今,二维码的应用场景非常广泛,从支付到信息分享,二维码都扮演着重要角色,SpringBoot是一个非常流行的Java基于Spring框架的微... 目录一、环境搭建二、创建 Spring Boot 项目三、引入二维码生成依赖四、编写二维码生成代码五

全解析CSS Grid 的 auto-fill 和 auto-fit 内容自适应

《全解析CSSGrid的auto-fill和auto-fit内容自适应》:本文主要介绍了全解析CSSGrid的auto-fill和auto-fit内容自适应的相关资料,详细内容请阅读本文,希望能对你有所帮助... css  Grid 的 auto-fill 和 auto-fit/* 父元素 */.gri

Maven 依赖发布与仓库治理的过程解析

《Maven依赖发布与仓库治理的过程解析》:本文主要介绍Maven依赖发布与仓库治理的过程解析,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录Maven 依赖发布与仓库治理引言第一章:distributionManagement配置的工程化实践1

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

Spring三级缓存解决循环依赖的解析过程

《Spring三级缓存解决循环依赖的解析过程》:本文主要介绍Spring三级缓存解决循环依赖的解析过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、循环依赖场景二、三级缓存定义三、解决流程(以ServiceA和ServiceB为例)四、关键机制详解五、设计约