解决 calibration.cpp:3408: error: (-210:Unsupported format or combination of formats)

本文主要是介绍解决 calibration.cpp:3408: error: (-210:Unsupported format or combination of formats),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、完整报错

报错代码如下:

ret, cameraMatrix, distCoeffs, rvecs, tvecs = cv2.calibrateCamera(cal_img.object_points, cal_img.corners, img_size,None, None)          
cv2.error: OpenCV(4.8.0) /io/opencv/modules/calib3d/src/calibration.cpp:3408: error: (-210:Unsupported format or combination of formats) objectPoints should contain vector of vectors of points of type Point3f in function 'collectCalibrationData'

官方API对参数的描述,点我进入OpenCV库cv2.calibrateCamera的API。

calibrateCamera	(	
InputArrayOfArrays 	objectPoints,
InputArrayOfArrays 	imagePoints,
Size 	imageSize,
InputOutputArray 	cameraMatrix,
InputOutputArray 	distCoeffs,
OutputArrayOfArrays 	rvecs,
OutputArrayOfArrays 	tvecs,
int 	flags = 0,
TermCriteria 	criteria = TermCriteria(TermCriteria::COUNT+TermCriteria::EPS, 30, DBL_EPSILON) 
)	

 参数调试截图(错误代码行):
cv2.calibrateCamera函数 cal_img.object_points, cal_img.corners,均是np类型数组,如下图1所示:
在这里插入图片描述

图1 错误的输入

 实际上,cv2.calibrateCamera函数需要多张输入图片,读取成list或者np类型,该类型中每一个存储都是np类型,且objectPoints必须是整数,如下图2所示,读者可以好好比对一下。

在这里插入图片描述
在这里插入图片描述

图2 两种正确的输入

2、报错原因

  在做相机标定时候,我采用了OpenCV库中的cv2.calibrateCamera来标定内参,但是因为对相机标定没那么熟悉,想着把标定板的坐标[[0, 0, 0], [1, 0, 0], [2, 0, 0], ...] 直接加上实际标定板距离世界坐标系原点的相对位置坐标[x, y, z],标定板的黑色正方形边长d,就把标定板的坐标变成了[[0+x+d, y, 0+z], [0+x+2d, y, 0+z], [0+x+3d, y, 0+z], ...],妄想一步就求出外参,实则用错函数,我也不知道读者是不是跟我一样的思想,我只是一个小白,这是学习中踩下的坑。 话不多说,直接说解决方案。

3、解决方案

3.1 求内参

  注意看上图2即可,objectPointsimagePoints 必须是list或者np类型,列表中包含多张图片数据(np类型)。且objectPoints中的每个点必须是整数,如上图2所示,读者可以好好比对一下。
  这样修改可以使得代码不报错,但是没求出来的内外参没有那么准确,因为您只用了一张图片来求,我无非是帮你生维度了,建议读入多张图片。

ret, cameraMatrix, distCoeffs, rvecs, tvecs = cv2.calibrateCamera(np.expand_dims(objectPoints, axis=0), np.expand_dims(imagePoints, axis=0), img_size,None, None) 

3.2 求外参

  如果读者是只有一张图片,读取的变量如图一所示,那么什么也不需要改,将你的变量直接放入下列函数中,但需要相机内参与畸变矩阵已知!!!

 _, rvecs, tvecs = cv2.solvePnP(object_points, corners, self.cameraMatrix, self.distCoeffs)

4、更为简单的方法

4.1 拉取代码

  拉取我写的标定代码,把cfg.yml中的文件地址改为自己的地址即可,我也上传了一些图片,用于跑代码,作者可以仿照着给图片。【点我进入GitHub代码】

git clone https://github.com/Wei-JL/camera_calibration.git

cfg.yml文件如下:

CameraID: 1 # 该属性没有用到
CamerName: HSCamera1 # 该属性没有用到
ImageSize: [640, 480]
Pattern: "INVAILD_STRING" # 该属性没有用到
BoardSize: [13, 9] # 标定板的角点13 x 9
FrameNum: 30 # 该数字没有用到,尽可能大于30张用于求内参和畸变矩阵
SquareSize: 0.018 # 标定板的黑色正方形的边长,单位M
DistanceFromOrigin: [0.555, 0.55, 0.96] # X-Y-Z 右手坐标系,单位M, y轴向前
DemarcateEdgeDistance: [0.021, 0.012] #标定板一端的多余留白的宽,以及多余留白的长SaveIMGPath: [False, "./out_draw_img/"]
# 求内参所用的图片文件夹路径
InternalImgPath: "./imgData/InternalParametersIMG/"
# 求外参所用的图片文件夹路径
ExternalImgPath: "./imgData/ExternalParametersIMG/"
# 保存生成的内外参
SaveYMLPath: "./ymlResult/CameraPropertiesYML.yml"

直接运行main.py,得到 ymlResult/CameraPropertiesYML.yml内容如下:

%YAML:1.0
---
cameraMatrix: !!opencv-matrixrows: 3cols: 3dt: ddata: [ 5.8872269401549318e+02, 0., 3.1396526288061324e+02, 0.,5.8916193444451278e+02, 2.3596852375684645e+02, 0., 0., 1. ]
distCoeffs: !!opencv-matrixrows: 1cols: 5dt: ddata: [ 2.3846216967883582e-02, 3.1566029814152891e-01,-3.4342893273889208e-03, -3.9197758689113425e-03,-1.2329393625222367e+00 ]
external_rot_index0: !!opencv-matrixrows: 3cols: 1dt: ddata: [ -5.0544041998692286e-02, 9.4373234595587441e-02,-2.3742117741779416e-02 ]
external_tra_index0: !!opencv-matrixrows: 3cols: 1dt: ddata: [ -1.2322397186032250e+01, 1.7099433969274160e+00,3.0594561071329622e+01 ]
external_rot_index1: !!opencv-matrixrows: 3cols: 1dt: ddata: [ -5.0544053387929486e-02, 9.4373100695407761e-02,-2.3742107968675215e-02 ]
external_tra_index1: !!opencv-matrixrows: 3cols: 1dt: ddata: [ -1.2322397408243795e+01, 1.7099434779488030e+00,3.0594561991082113e+01 ]

4.2 成功运行截图

在这里插入图片描述

这篇关于解决 calibration.cpp:3408: error: (-210:Unsupported format or combination of formats)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是

在Ubuntu上打不开GitHub的完整解决方法

《在Ubuntu上打不开GitHub的完整解决方法》当你满心欢喜打开Ubuntu准备推送代码时,突然发现终端里的gitpush卡成狗,浏览器里的GitHub页面直接变成Whoathere!警告页面... 目录一、那些年我们遇到的"红色惊叹号"二、三大症状快速诊断症状1:浏览器直接无法访问症状2:终端操作异常

mybatis直接执行完整sql及踩坑解决

《mybatis直接执行完整sql及踩坑解决》MyBatis可通过select标签执行动态SQL,DQL用ListLinkedHashMap接收结果,DML用int处理,注意防御SQL注入,优先使用#... 目录myBATiFBNZQs直接执行完整sql及踩坑select语句采用count、insert、u

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

Java中字符编码问题的解决方法详解

《Java中字符编码问题的解决方法详解》在日常Java开发中,字符编码问题是一个非常常见却又特别容易踩坑的地方,这篇文章就带你一步一步看清楚字符编码的来龙去脉,并结合可运行的代码,看看如何在Java项... 目录前言背景:为什么会出现编码问题常见场景分析控制台输出乱码文件读写乱码数据库存取乱码解决方案统一使

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned