1

所有,我有一个使用 OpenCV 校准相机的 python 脚本。它现在在 stackoverflow 帮助的帮助下工作。但是,我遇到了失真常数的问题。我似乎无法控制适合的常量数量。我只想要 4 个失真常数,而不是 5 个。在文档中它指出“也就是说,如果向量包含四个元素,则意味着 K3=0”,这就是我想要的。于是我发起dist_const = np.zeros(4),传给cv2.calibrateCamera,但是返回的dist_const有5个常量返回。我也尝试了标志 CV_CALIB_FIX_K3,但不​​断收到“必须分配一个迭代器”错误。有没有人见过这种行为,任何帮助将不胜感激。

import cv2 
from cv2 import cv 
import numpy as np

obj_points = [[-9.7,3.0,4.5],[-11.1,0.5,3.1],[-8.5,0.9,2.4],[-5.8,4.4,2.7],[-4.8,1.5,0.2],[-6.7,-1.6,-0.4],[-8.7,-3.3,-0.6],[-4.3,-1.2,-2.4],[-12.4,-2.3,0.9],[-14.1,-3.8,-0.6],[-18.9,2.9,2.9],[-14.6,2.3,4.6],[-16.0,0.8,3.0],[-18.9,-0.1,0.3],[-16.3,-1.7,0.5],[-18.6,-2.7,-2.2]]

img_points = [[993.0,623.0],[942.0,705.0],[1023.0,720.0],[1116.0,645.0],[1136.0,764.0],[1071.0,847.0],[1003.0,885.0],[1142.0,887.0],[886.0,816.0],[827.0,883.0],[710.0,636.0],[837.0,621.0],[789.0,688.0],[699.0,759.0],[768.0,800.0],[697.0,873.0]]

obj_points = np.array(obj_points,'float32')
img_points = np.array(img_points,'float32')

w = 1680
h = 1050
size = (w,h)

camera_matrix = np.zeros((3,3),'float32')
camera_matrix[0,0]= 2200.0
camera_matrix[1,1]= 2200.0
camera_matrix[2,2]=1.0

camera_matrix[0,2]=750.0 
camera_matrix[1,2]=750.0

dist_coefs = np.zeros(4,'float32')

retval,camera_matrix,dist_coefs,rvecs,tvecs = cv2.calibrateCamera([obj_points],[img_points],size,camera_matrix,dist_coefs,flags=cv.CV_CALIB_USE_INTRINSIC_GUESS)

print camera_matrix
print dist_coefs

链接到我的另一个问题,有 dist_coefs 的结果,来自我试图用 python/opencv 替换的 caltech matlab 代码。

约翰

4

3 回答 3

6

将您的 calibrateCamera 调用更改为:

retval,camera_matrix,dist_coefs,rvecs,tvecs = cv2.calibrateCamera([obj_points],[img_points],size,camera_matrix,dist_coefs,flags=cv2.CALIB_USE_INTRINSIC_GUESS + cv2.CALIB_FIX_K3)

您不希望我像在示例中那样混合 cv2 和 cv 命名空间。

于 2012-04-23T02:25:13.080 回答
0

我明白你的意思了。可能是因为您只使用单个图像进行校准。

于 2012-04-14T02:19:20.877 回答
0

我遇到了同样的问题,我找到的解决方案是:

import cv2
from cv2 import cv


... flags = cv2.cv.CALIB_USE_INTRINSIC_GUESS + ...
于 2015-03-26T12:25:41.663 回答