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

相关文章

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服