IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 单目初始化及尺度不确定 -> 正文阅读

[人工智能]单目初始化及尺度不确定

单目里程计:
问题:通过单目相机图像序列,计算得到图像序列对应的相机位姿 ( R , t ) (R,t) (R,t)

两个特点:

1、需要足够平移才能完成初始化
2、尺度不确定及尺度漂移

1、单目初始化需要相机足够的平移,才能够完成初始化。
使用2D-2D的方式来估计两帧相机之间的位姿时,可以通过求解**H(单应矩阵homography)F(基础矩阵fundamental)以及BA(bundle adjustment)**等方式来解析出相机的位姿。

在近纯旋转(低偏移)的情况下,F阵解算失效,通过H和BA的方式可以解析R,此时解析出的t是不可靠的,并且由于 t t t小,因此也无法使用三角测距的方法来恢复地图点的深度。

由于单目恢复地图点三维坐标的方式,通过对极几何(三角化)的方式,因此必须需要两帧图像之间有足够的偏移(t)运动。此在三角化特征点(triangulation)方法有所阐述。

因此,只有t足够大时,才能被解析,才能通过对极几何的方式,恢复地图点深度。

此外,地图点的深度解析与偏移t的解析值存在相关性。因此单目中存在尺度不确定。

2、尺度不确定及尺度漂移
两帧图像中有一对匹配图像特征点: p i 1 和 p i 2 p_i^1和p_i^2 pi1?pi2?,设两帧图像之间对应相机的运动为 ( R , t ) (R,t) (R,t),则:
d 1 p i 1 = d 2 R p i 2 + t d_1p_i^1=d_2Rp_i^2+t d1?pi1?=d2?Rpi2?+t d 1 [ u 1 v 1 1 ] = d 2 R [ u 2 v 2 1 ] + t d_1\left[\begin{matrix}u_1\\v_1\\1\\\end{matrix}\right]=d_2R\left[\begin{matrix}u_2\\v_2\\1\\\end{matrix}\right]+t d1????u1?v1?1????=d2?R???u2?v2?1????+t
两侧同乘以常数 c c c,得:
c d 1 p i 1 = c d 2 R p i 2 + c t cd_1p_i^1=cd_2Rp_i^2+ct cd1?pi1?=cd2?Rpi2?+ct
如下示意图,地图点深度( d d d)与偏移( t t t)相关,地图点不同深度,则对应一个 t t t值。同样的观测可以计算出无穷组 d d d t t t
在这里插入图片描述
可知:使用单目来实现SLAM时,存在尺度不确定。

因此,单目VIO需要初始化过程,初始化过程中,检测足够大的平移运动,解析出t及地图点深度,并确定尺度。

尺度的确定有两种方法:
1)对初始两帧的平移向量t归一化作为后续的单位;也可以通过
2)令初始化时所有特征点进行归一化,这里的归一化令特征点平均深度为1,这种方式可以控制场景规模大小,使计算在数值上更稳定。

以上来自[视觉十四讲-第二版](176页)及https://blog.csdn.net/weixin_42269064/article/details/115691673

VINS-Mono中,使用本质矩阵(E)解算出相机运动(R,t),这里的t并未进行尺度评估,在视觉与IMU对齐时,利用IMU的积分数据来估计尺度值。
ORB-Mono中,使用基础矩阵(F)和单应矩阵(H)来解析(R,t),将地图点归一化,即尺度使用的是(invMedianDepth),
<ORB_SLAM/src/ Tracking.cc > 中的Tracking::CreateInitialMapMonocular()中:

    // step1:获取初始关键帧的地图点的深度中值Z
    float medianDepth = pKFini->ComputeSceneMedianDepth(2);
    float invMedianDepth = 1.0f/medianDepth;
 
    if(medianDepth<0 || pKFcur->TrackedMapPoints(1)<100)
    {
        cout << "Wrong initialization, reseting..." << endl;
        Reset();
        return;
    }
 
    //step2:相机位姿归一化x'/z,y'/z,z'/z
    cv::Mat Tc2w = pKFcur->GetPose();
    Tc2w.col(3).rowRange(0,3) = Tc2w.col(3).rowRange(0,3)*invMedianDepth;
    pKFcur->SetPose(Tc2w);
 
    //step3:地图点归一化
    vector<MapPoint*> vpAllMapPoints = pKFini->GetMapPointMatches();
    for(size_t iMP=0; iMP<vpAllMapPoints.size(); iMP++)
    {
        if(vpAllMapPoints[iMP])
        {
            MapPoint* pMP = vpAllMapPoints[iMP];
            pMP->SetWorldPos(pMP->GetWorldPos()*invMedianDepth);
        }

因此ORB-Mono估计的轨迹需要对齐尺度,若用evo时,需加上-s参数。

SVO单目使用直接法来初始化相机位移,前几帧使用真实值来得到尺度参数。

单目在确定尺度后,随着计算,尺度会出现漂移。当初始帧固定尺度后,由于后期计算的误差,如t的解析误差,会同步带来地图点深度的误差,地图点深度误差,同步会得到t的解析误差,从而累积,形成尺度漂移。

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-22 18:36:57  更:2022-04-22 18:40:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 18:20:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码