个人理解OpenCV对标定的处理是这样的
来源:互联网 发布:淘宝店铺怎么提升流量 编辑:程序博客网 时间:2024/04/30 10:38
个人理解OpenCV对标定的处理是这样的:
1.打印一幅棋盘图贴到一个平板上,转动该模板,用摄像机拍摄20张(一般多于6张即可,多了结果可以更精确)图片
2.对于每一张图片都用cvFindChessboardCorners提取角点坐标,这个函数提取的仅是一个粗略坐标,然后调用cvFindCornerSubPix()来获取精确角点坐标。提出来后可以用cvDrawChessboardCorners画到图片上。
有几张图片,这个过程就重复多少遍。最终提取的20张图片角点坐标全存到N*2维矩阵指针image_points中。
3.初始化定标点的三维坐标,也是20张图片上的角点坐标全赋值。可以认为每张图上对应点的坐标是一样的(Z坐标为0)。角点的三维坐标都存到N*3维矩阵指针object_points中。
4.调用cvCalibrateCamera2求摄像机的内外参数矩阵。对于外参数,该函数实际得到的是N*3维的旋转矢量和N*3维的平移矢量,而不是矩阵。N行的矢量,第i行就对应着第i张图片的外参数。如果想得到3*3的矩阵形式,需要先把第i行的值取出来,再调用函数cvRodrigues2进行转换。
虽然每张图片的物体坐标我们假设是一样的,但是投影坐标坐标不同,所以获得的外参数是不一样的。个人理解,几张图片的参考点是不一样的。都是以模板物理位置为参考点,得到的外参数是摄像机相对于该位置的旋转和平移。
1.打印一幅棋盘图贴到一个平板上,转动该模板,用摄像机拍摄20张(一般多于6张即可,多了结果可以更精确)图片
2.对于每一张图片都用cvFindChessboardCorners提取角点坐标,这个函数提取的仅是一个粗略坐标,然后调用cvFindCornerSubPix()来获取精确角点坐标。提出来后可以用cvDrawChessboardCorners画到图片上。
有几张图片,这个过程就重复多少遍。最终提取的20张图片角点坐标全存到N*2维矩阵指针image_points中。
3.初始化定标点的三维坐标,也是20张图片上的角点坐标全赋值。可以认为每张图上对应点的坐标是一样的(Z坐标为0)。角点的三维坐标都存到N*3维矩阵指针object_points中。
4.调用cvCalibrateCamera2求摄像机的内外参数矩阵。对于外参数,该函数实际得到的是N*3维的旋转矢量和N*3维的平移矢量,而不是矩阵。N行的矢量,第i行就对应着第i张图片的外参数。如果想得到3*3的矩阵形式,需要先把第i行的值取出来,再调用函数cvRodrigues2进行转换。
虽然每张图片的物体坐标我们假设是一样的,但是投影坐标坐标不同,所以获得的外参数是不一样的。个人理解,几张图片的参考点是不一样的。都是以模板物理位置为参考点,得到的外参数是摄像机相对于该位置的旋转和平移。
- 个人理解OpenCV对标定的处理是这样的
- Opencv摄像机的标定
- 相机标定的理解及采用opencv和matlab工具箱的标定方法
- 我理解的webservice是这样的
- 我理解的webservice是这样的
- 个人对getInitParameter的理解
- 个人对宏观经济学的理解
- 个人对withValueBackReference的理解
- 个人对MVC的理解
- 对SVM的个人理解
- 个人对jms的理解
- 个人对aop的理解
- 个人对压缩的理解
- 个人对runtime的理解
- 对原型的个人理解
- 对 synchronized 的个人理解
- 对递归的个人理解
- 个人对贪心的理解
- aop(关于事物 的一点点注解)
- USACO A Game解题报告
- k近邻与k-d树
- MyEclipse开发JDBC应用基本过程
- 10420 - List of Conquests
- 个人理解OpenCV对标定的处理是这样的
- 解决下载Android源码时遇到的url连接错误问题
- 国内支持html5的视频网站(持续收集整理中)
- 51单片机定时器2捕获模式测脉冲频率
- 第12章 性能
- 批量修改后缀名的bash 脚本
- Android开发入门笔记
- hadoop使用心得
- HTML 5视频标签全属性详解