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;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/509939.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[青少年CTF擂台挑战赛 2024 #Round] Misc 1ez_model

[青少年CTF擂台挑战赛 2024 #Round] Misc 1ez_model 题目描述&#xff1a;从Pytorch开始的AI之路 下载附件&#xff0c;是一个pth文件 .pth 文件通常是 PyTorch 模型的权重文件&#xff0c;它包含了模型的参数。要还原&#xff08;或加载&#xff09;一个大模型&#xff0c;你…

msvcp140.dll丢失的多种解决方法解析,总结4种msvcp140.dll修复的手段

msvcp140.dll是一个重要的系统文件&#xff0c;属于Microsoft Visual C Redistributable软件包。如果计算机显示找不到msvcp140.dll文件的错误&#xff0c;这通常意味着该文件丢失、损坏或未被正确注册。今天&#xff0c;我们将深入探究这个文件的相关知识&#xff0c;并提供一…

654.最大二叉树

这段Java代码实现了一个名为Solution的类&#xff0c;其中包含两个方法&#xff1a;constructMaximumBinaryTree()和constructMaximumBinaryTree1()&#xff0c;目的是从给定的整数数组nums中构建出一个最大二叉树。以下是详细的注释说明&#xff1a; class Solution {// 主方…

蓝桥杯集训·每日一题2024 (前缀和)

笔记&#xff1a; 例题&#xff1a; #include<bits/stdc.h> using namespace std; const int N 5000010; char str[N]; int s[N]; int main(){int t;cin>>t;for(int a1;a<t;a){int n;cin>>n;scanf("%s",str1);for(int i1;i<n;i){s[i]s[i-1]…

lv20 QT事件5

1 事件模型 2 事件处理 virtual void keyPressEvent(QKeyEvent *event) virtual void keyReleaseEvent(QKeyEvent *event) virtual void mouseDoubleClickEvent(QMouseEvent *event) virtual void mouseMoveEvent(QMouseEvent *event) virtual void mousePressEvent(QMou…

【MySQL系列】在 MacOS 上安装 MySQL

在 MacOS 上有两种方式安装 MySQL 服务器&#xff1a;通过 brew 安装和通过安装包安装。 文章目录 1、通过 brew 安装 MySQL1.1、安装 MySQL1.2、启动 MySQL 服务器1.3、配置 MySQL 服务器1.4、MySQL 服务器管理命令 2、通过安装包安装 MySQL2.1、下载安装包2.2、安装 MySQL2.3…

程序人生:当看到男友学测试拿高薪后,我突然悟了......

Hello&#xff0c;大家好&#xff0c;我是小雨 认识软件测试是因为我男朋友&#xff0c;他在华测教育培训软测后出去就业非常不错&#xff0c;所以我也萌生了转行的想法&#xff0c;当时我的想法是&#xff0c;他都能学会&#xff0c;那我肯定没问题&#xff0c;所以在他的介绍…

Mongodb安装配置

Mongodb安装配置 一、MongoDB简介二、Windows下MongoDB安装2.1.MongoDB下载2.2.安装MongoDB【解压版】2.2.1.解压2.2.2.创建和 bin 目录同级 data\db 目录来存储 MongoDB 产生的数据2.2.3.进入 bin 目录&#xff0c;cmd命令行窗口&#xff0c;使用命令的指定存储数据文件的形式…

[NSSCTF 2nd]MyJs

做一题ejs原型链污染 首先是登录界面 源码里面提示了源码的路由 js不熟先审计一下 const express require(express); #导入Express框架&#xff0c;用于构建Web应用程序的服务器和路由 const bodyParser require(body-parser); #导入body-parser中间件&#xff0c;用于解析…

网盘拉新如何对接?盘点最靠谱的一手渠道平台

2024网盘行业再次重燃战火。字节旗下产品头条搜索极速版APP、悟空浏览器APP推出对应的网盘功能&#xff0c;刚刚开放了拉新推广&#xff0c;现在是一个不能错过新项目的好时机。 如果你对网盘拉新推广充满热情&#xff0c;千万不要错过星子助推联合字节推出的网盘项目机会。小…

视频如何无水印保存?这三种下载方法赶紧收藏

在互联网时代&#xff0c;视频已成为我们获取信息、娱乐休闲的重要途径。然而&#xff0c;有时我们想要保存或分享某些视频时&#xff0c;却发现下载起来却带有水印。为了解决这个问题&#xff0c;今天给大家带来几个无水印下载的方法。 方法一&#xff1a;水印云 水印云是一…

基于OpenCompass的大模型评测实践

大模型评测教程 随着人工智能技术的快速发展&#xff0c; 大规模预训练自然语言模型成为了研究热点和关注焦点。OpenAI于2018年提出了第一代GPT模型&#xff0c;开辟了自然语言模型生成式预训练的路线。沿着这条路线&#xff0c;随后又陆续发布了GPT-2和GPT-3模型。与此同时&a…