stereo_calib是OpenCV官方代码中提供的最正统的双目demo,无论数据集还是代码都有很好实现。

一、代码效果:
相关的内容包括28张图片,1个xml和stereo_calib.cpp的代码
直接引入的代码不能给正常运行,我们需要进行一些修改。
报了4个错误,主要是定义和引入问题,都可以解决。
包括定义:
#define  INTER_LINEAR_EXACT 1
以及
主要目的,就是确保输入的参数正确,图片能够被读到。
由于原始代码很贴心地将参数都设置正确了(可以参考下图,长为9、宽为6),所以可以放心实用。
但是,目前代码还是无法完全运行,其原因是因为在以上代码中,调用了.xml,我们看看它是什么样子的:
这是一个序列化的文件,保存的是我们需要处理的图片的位置。这里都是相对地址,而我们的图片要么和当前运行的程序放到一个目录下面;要么修改代码;或者,修改这个配置xml文件,将其全部改成绝对地址。
大概是这个样子,当然你放的位置不一样,这里的xml肯定不一样;或者你认为这种方法比较麻烦,采用其他的方法也没有问题。
确保标定的图片能够正确地读入进去。
成功的话,经过较长时间晕死,就会绘制这样的结果图片。按下键盘任意按键,就会切换下一帧。
如果我们自己有采集的图片,进行替换后可以用在这里。
二、代码解析
在能正确运行的基础上,我们来分析这段代码是如何产生作用的。
1)main函数
main函数是整个程序的入口,一般从这个函数开始分析。
这个例程的main函数非常简单,蓝色框图部分,都是对输入参数进行准备;而在绿色部分,是程序本体。
2)StereoCalib
StereoCalib(const vector<string>& imagelist,
 Size boardSize, 
 float squareSize,
 bool displayCorners = false,
 bool useCalibrated=true,
 bool showRectified=true)
第一个参数是输入的图片序列,我们只要将图片地址输入即可;在前面的设定下,这个参数为:
第二个参数是标定板的尺寸;
至于为什么是9*6,之前已经说明了;
后面4个参数都是和显示相关的,保持不变即可。如果你感兴趣,可以变换看效果,最好先看这些参数的英文名称。
这个函数很长,我们拣重要的来讲:
从这个嵌套循环开始,程序进入主体。由于我们做的是一个左右对比的程序,所以一个二维的循环肯定是必须的。
值得注意的是,这里的二维循环并非先循环左边的图片,对应右边的图片,而是采取了另一种方式。
绿色框图部分,比较输入的图片是否为同样大小。这里不考虑非同样大小的情况。
在这个循环中,最核心也是最消耗时间的就是findchessboardcorners函数,它的目的是分析当前图像,找到棋盘图片的角点。
最后,对于识别效果比较好的情况,全部推入goodImageList中去。对于官方提供的例子,13对图像全部为gooImageList,我们也可以根据这里入选的情况,判断当前采集图像的质量。
这里,OpenCV代码提供了一个很好的技巧,用于处理当前图像由于缩放可能带来的问题:

默认情况下是在原始大小下进行寻找,如果没有找到,则放大一次寻找,一旦找到,直接跳出循环。
根据得到角点结果,计算相机参数矩阵。正如我们知道的一样,是3*3矩阵。
调用stereoCalibrate函数,这个函数参数好多呀。
这段是采用拟合的方法,计算误差。
这里是将标定的结果,序列化地保存下来。
三、如何应用
这个函数很长,却代表了标定的完整过程。在使用的过程中,肯定还是要将其分解成各个函数,而后再单独地进行处理。
标定应该只是一个过程,标定成功后的结果可以反复使用,所以这个操作消耗一些时间应该也是没有问题的。

【双目备课】OpenCV例程_stereo_calib.cpp解析的更多相关文章

  1. OpenCV读写视频文件解析(二)

    OpenCV读写视频文件解析(二) VideoCapture::set 设置视频捕获中的属性. C++:bool VideoCapture::set(int propId, double value) ...

  2. OpenCV读写视频文件解析

    OpenCV读写视频文件解析 一.视频读写类 视频处理的是运动图像,而不是静止图像.视频资源可以是一个专用摄像机.网络摄像头.视频文件或图像文件序列. 在 OpenCV 中,VideoCapture ...

  3. 【双目备课】《学习OpenCV第18章》相机模型与标定整编

    一.相机模型 针孔模型.在这个简单模型中,想象光线是从场景或一个很远的物体发射过来的,但只有一条光线从该场景中的任意特定点进入针孔. 我们将这个图像进行抽象,就能够得到这样的结果: 其中,f为像到针孔 ...

  4. 基于OpenCV进行图像拼接原理解析和编码实现(提纲 代码和具体内容在课件中)

    一.背景 1.1概念定义 我们这里想要实现的图像拼接,既不是如题图1和2这样的"图片艺术拼接",也不是如图3这样的"显示拼接",而是实现类似"BaiD ...

  5. OpenCV例程实现人脸检测

    前段时间看的OpenCV,其实有很多的例子程序,参考代码值得我们学习,对图像特征提取三大法宝:HOG特征,LBP特征,Haar特征有一定了解后. 对本文中的例子程序刚开始没有调通,今晚上调通了,试了试 ...

  6. jso cpp解析读写数据

    json write : { "array" : [ { "aaaaaa" : "bbbbbb", "number" : ...

  7. video.py OpenCv例程阅读

    #!/usr/bin/env python ''' Video capture sample. Sample shows how VideoCapture class can be used to a ...

  8. common.py OpenCv例程阅读

    #!/usr/bin/env python ''' This module contais some common routines used by other samples. ''' import ...

  9. camshift.py OpenCv例程阅读

    源码在这 #!/usr/bin/env python ''' Camshift tracker ================ This is a demo that shows mean-shif ...

随机推荐

  1. 【CF429E】Points and Segments 欧拉回路

    [CF429E]Points and Segments 题意:给你数轴上的n条线段$[l_i,r_i]$,你要给每条线段确定一个权值+1/-1,使得:对于数轴上的任一个点,所有包含它的线段的权值和只能 ...

  2. H - Expedition 优先队列 贪心

    来源poj2431 A group of cows grabbed a truck and ventured on an expedition deep into the jungle. Being ...

  3. CXF Spring开发WebService,基于SOAP和REST方式

    版本CXF2.6.9 添加的包文件 这个版本的不可在Tomcat7上运行,会出错. 配置文件 applicationContext.xml <?xml version="1.0&quo ...

  4. Promise及Async/Await

      一.为什么有Async/Await? 我们都知道已经有了Promise的解决方案了,为什么还要ES7提出新的Async/Await标准呢? 答案其实也显而易见:Promise虽然跳出了异步嵌套的怪 ...

  5. poj2109 【贪心】

    Current work in cryptography involves (among other things) large prime numbers and computing powers ...

  6. yarn卸载或增加节点

    yarn卸载或增加节点   卸载节点或者增加节点: 方式一:静态的增添删除:将集群关闭,修改配置文件(etc/hadoop/slaves),重新启动集群(很黄很暴力,不够人性化). 方式二:动态的增加 ...

  7. Android基础总结+SQlite数据库【申明:来源于网络】

    Android基础总结+SQlite数据库[申明:来源于网络] 基础总结篇之一:Activity生命周期:http://blog.csdn.net/liuhe688/article/details/6 ...

  8. c 语言 随机数选取6个数 一定范围内

    种子来源 定时器/****************** 自动筛选种子 dat 目标种子 ************/ #define max 7 //随机生成最大的数为7 #define min 1 / ...

  9. Mycat了解下

    首先说下,因为本身不怎么推荐中间件,所以我对这东西也只是了解,业内mycat用的最好的应该顺风算一个,但是他们是做过二次开发的,咱菜鸡比不了,据说最近出来一个叫cetus的还不错,有空可以关注下 Ⅰ. ...

  10. python框架之Django(14)-rest_framework模块

    APIView django原生View post请求 from django.shortcuts import render, HttpResponse from django import vie ...