相机标定中一些细节--畸变模型和参数

2024-06-09 11:52

本文主要是介绍相机标定中一些细节--畸变模型和参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

张正友标定方法做相机标定的主要过程是先估计每张图片的单应性矩阵,然后通过这一系列的单应性矩阵估计出内外参数初值,最后再考虑畸变模型的加入进行非线性优化。同时优化内参、外参和畸变参使得重投影误差最小。

镜头的畸变表现出来的非线性关系,通常使用一些近似的手段来建模逼近它,如下几种常见的镜头畸变模型:

  • Brown-Conrady
  • Brandt-Kannala
  • CMei
  • David Scaramuzza

其中Brown-Conrady适用于畸变较小的情况,另外几个畸变模型都是针对广角和鱼眼镜头设计的。要做好一个相机的标定除了精确的标定板和规范的图片采集过程,还需要选择合适的标定模型和参数才能达到。在此主要讨论Brown-Conrady模型的一些情况。

Brown-Conrady 畸变模型

即是Opencv中经常用到的[k1,k2,p1,p2,k3,…]这套参数。在opencv的issue中曾经有人提到一类标定问题,主要情况是重投影误差小但是矫正后的图片比较奇怪,具体的说就是校正后的图片中间区域很正直,但是边缘区域就一团糟了。这在后续的AR/SLAM/SFM等应用中会带来各种问题。

这一情况主要的原因有:

1、图片采集不规范,用于标定的图片大多集中在图像中间区域,标定板变化姿态不多,使得标定结果过拟合图像中间区域引起。规范采图即可解决。

2、还有就是畸变参数选择不合适引起的优化过拟合结果。

在这一畸变模型中 1 + k 1 r 2 + k 2 r 4 + k 3 r 6 1 + k_1 r^2 + k_2 r^4 + k_3 r^6 1+k1r2+k2r4+k3r6,径向畸变用高次多项式来逼近这一非线性关系,而忽略了实际透镜的畸变特点进行非线性优化。虽然能达到一定的拟合效果,但是带来了更多的自由度变化空间。也即是高次多项式函数能近似镜头的非线性畸变但不仅限于此,很可能会使得重投影误差虽然更小了,但是远离了镜头实际畸变关系达到过拟合的情况。例如我们拟合带噪声的二次抛物线,用二次多项式拟合的残差通常会大于用更高次的多项式拟合的残差,但是曲里拐弯的高次多项式并不适配二次抛物线的本来面目。也违背了赤池信息量准则。

更具体的说,径向畸变的高次多项式函数需要满足单调性约束。要么单调递增(枕形畸变)要么单调递减(桶形畸变),才符合真实镜头的畸变特点。而Opencv中的优化过程并未考虑这一约束进行优化,使得最后的标定结果常常走样,远离了相机镜头真实的成像关系。当不使用k3时,会自然满足这一单调性约束。在一些资料中有说只使用k1和k2就够了,背后原因阐明不多。

此外[k4,k5,k6]是在畸变较大的情况引入的,比如广角和鱼眼相机的畸变,为了使用更小的阶数来达到更高阶数多项式模型的矫正效果。而实际带来了更多的优化参数,往往效果欠佳。对于这类大畸变需要使用后三种畸变模型。如果要使用[k4,k5,k6]需要保证 1 + k 4 r 2 + k 5 r 4 + k 6 r 6 1 + k_4 r^2 + k_5 r^4 + k_6 r^6 1+k4r2+k5r4+k6r6的所有根要在图像边界外,否则边界内有像素使得分母为0带来异常。

https://github.com/opencv/opencv/issues/15992
https://github.com/opencv/opencv/issues/15577

小结

总而言之,在一般的非广角相机使用k1和k2足矣,或者再添加p1和p2即可,若使用k3一定要小心。如果是广角和鱼眼相机使用另外三种畸变模型。

在线标定工具

标定一次输出三种畸变模型的结果,方便进行对比挑选。
参考 https://blog.csdn.net/J10527/article/details/137022339
在这里插入图片描述

这篇关于相机标定中一些细节--畸变模型和参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

ABAP怎么把传入的参数刷新到内表里面呢?

1.在执行相关的功能操作之前,优先执行这一段代码,把输入的数据更新入内表里面 DATA: lo_guid TYPE REF TO cl_gui_alv_grid.CALL FUNCTION 'GET_GLOBALS_FROM_SLVC_FULLSCR'IMPORTINGe_grid = lo_guid.CALL METHOD lo_guid->check_changed_data.CALL M

人工和AI大语言模型成本对比 ai语音模型

这里既有AI,又有生活大道理,无数渺小的思考填满了一生。 上一专题搭建了一套GMM-HMM系统,来识别连续0123456789的英文语音。 但若不是仅针对数字,而是所有普通词汇,可能达到十几万个词,解码过程将非常复杂,识别结果组合太多,识别结果不会理想。因此只有声学模型是完全不够的,需要引入语言模型来约束识别结果。让“今天天气很好”的概率高于“今天天汽很好”的概率,得到声学模型概率高,又符合表达

智能客服到个人助理,国内AI大模型如何改变我们的生活?

引言 随着人工智能(AI)技术的高速发展,AI大模型越来越多地出现在我们的日常生活和工作中。国内的AI大模型在过去几年里取得了显著的进展,不少独创的技术点和实际应用令人瞩目。 那么,国内的AI大模型有哪些独创的技术点?它们在实际应用中又有哪些出色表现呢?此外,普通人又该如何利用这些大模型提升工作和生活的质量和效率呢?本文将为你一一解析。 一、国内AI大模型的独创技术点 多模态学习 多

OpenCompass:大模型测评工具

大模型相关目录 大模型,包括部署微调prompt/Agent应用开发、知识库增强、数据库增强、知识图谱增强、自然语言处理、多模态等大模型应用开发内容 从0起步,扬帆起航。 大模型应用向开发路径:AI代理工作流大模型应用开发实用开源项目汇总大模型问答项目问答性能评估方法大模型数据侧总结大模型token等基本概念及参数和内存的关系大模型应用开发-华为大模型生态规划从零开始的LLaMA-Factor

模型压缩综述

https://www.cnblogs.com/shixiangwan/p/9015010.html

Java面试八股之JVM参数-XX:+UseCompressedOops的作用

JVM参数-XX:+UseCompressedOops的作用 JVM参数-XX:+UseCompressedOops的作用是启用对象指针压缩(Ordinary Object Pointers compression)。这一特性主要应用于64位的Java虚拟机中,目的是为了减少内存使用。在传统的64位系统中,对象引用(即指针)通常占用8字节(64位),而大部分应用程序实际上并不需要如此大的地址空间

AI赋能天气:微软研究院发布首个大规模大气基础模型Aurora

编者按:气候变化日益加剧,高温、洪水、干旱,频率和强度不断增加的全球极端天气给整个人类社会都带来了难以估计的影响。这给现有的天气预测模型提出了更高的要求——这些模型要更准确地预测极端天气变化,为政府、企业和公众提供更可靠的信息,以便做出及时的准备和响应。为了应对这一挑战,微软研究院开发了首个大规模大气基础模型 Aurora,其超高的预测准确率、效率及计算速度,实现了目前最先进天气预测系统性能的显著

PyTorch模型_trace实战:深入理解与应用

pytorch使用trace模型 1、使用trace生成torchscript模型2、使用trace的模型预测 1、使用trace生成torchscript模型 def save_trace(model, input, save_path):traced_script_model = torch.jit.trace(model, input)<