python - 如何使用相机参数计算像素之间以厘米为单位的世界距离?
问题描述
我分别使用ROS、OpenCv和Matlab校准了我的相机。人们说我需要外部参数来计算图像中像素之间的实际距离(以厘米为单位)。ROS 没有显式地提供外部参数,它提供了一个 (4,3) 投影矩阵,它是内部和外部参数相乘后的输出。
这就是为什么我再次使用 OpenCv 和 Matlab 校准我的相机以获取外部参数。虽然我搜索了如何计算像素之间的实际距离(即从 (x1,y1) 到 (x2,y2)),但我无法弄清楚如何计算实际距离。此外,我不明白使用哪些参数来计算距离。我想使用 OpenCv 计算像素之间的距离并将输出写入 txt 文件,这样我就可以使用这个 txt 文件来移动我的机器人。
例如,这里是路径的像素输出样本数组,
array([[ 4.484375 , 799.515625 ],
[ 44.484375 , 487. ],
[255.296875 , 476.68261719],
[267.99707031, 453.578125 ],
[272.484375 , 306. ],
[403.484375 , 300.515625 ],
[539.484375 , 296.515625 ],
[589.421875 , 270.00292969],
[801.109375 , 275.18554688],
[819. , 467.515625 ]])
我想按顺序找到这些像素之间的实际距离(以厘米为单位)。
OpenCv 计算参数的代码:
import numpy as np
import cv2
import glob
# termination criteria
criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 30, 0.001)
cbrow = 6
cbcol = 9
# prepare object points, like (0,0,0), (1,0,0), (2,0,0) ....,(6,5,0)
objp = np.zeros((cbrow*cbcol,3), np.float32)
objp[:,:2] = np.mgrid[0:cbcol,0:cbrow].T.reshape(-1,2)
# Arrays to store object points and image points from all the images.
objpoints = [] # 3d point in real world space
imgpoints = [] # 2d points in image plane.
images = glob.glob('C:\Users\Ender\Desktop\CalibrationPhotos\*.jpg')
for fname in images:
img = cv2.imread(fname)
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
# Find the chess board corners
ret, corners = cv2.findChessboardCorners(gray, (cbcol,cbrow),None)
# If found, add object points, image points (after refining them)
if ret == True:
print "%s: success" % fname
objpoints.append(objp)
cv2.cornerSubPix(gray,corners,(11,11),(-1,-1),criteria)
imgpoints.append(corners)
# Draw and display the corners
cv2.drawChessboardCorners(img, (cbcol,cbrow), corners,ret)
cv2.imshow('img',img)
cv2.waitKey(150)
else:
print "%s: failed" % fname
cv2.imshow('img',img)
cv2.waitKey(1)
cv2.destroyAllWindows()
ret, mtx, dist, rvecs, tvecs = cv2.calibrateCamera(objpoints, imgpoints, gray.shape[::-1],None,None)
print "mtx"
print mtx
print "dist"
print dist
#print "rvecs"
#print rvecs
#print "tvecs"
#print tvecs
np.savez("CalibData.npz" ,mtx=mtx, dist=dist, rvecs=rvecs, tvecs=tvecs)
#UNDISTROTION
img = cv2.imread('C:\Users\Ender\Desktop\Maze\Maze Images\Partial Maze Images-Raw\Raw7.jpg')
h, w = img.shape[:2]
newcameramtx, roi=cv2.getOptimalNewCameraMatrix(mtx,dist,(w,h),1,(w,h))
dst = cv2.undistort(img, mtx, dist, None, newcameramtx)
# crop the image
x,y,w,h = roi
dst = dst[y:y+h, x:x+w]
cv2.imwrite('calibresult.jpg',dst)
#Re-projection Errors
total_error = 0
for i in xrange(len(objpoints)):
imgpoints2, _ = cv2.projectPoints(objpoints[i], rvecs[i], tvecs[i], mtx, dist)
error = cv2.norm(imgpoints[i],imgpoints2, cv2.NORM_L2)/len(imgpoints2)
total_error += error
print "total error: ", total_error/len(objpoints)
这样做的方法是什么?
解决方案
推荐阅读
- java - Android Studio 4.2.1 不适用于“org.androidannotations:androidannotations-api:4.8.0”
- sql - 在多对多表中查询 AND
- javascript - 如何布局此 CSS 网格模板
- java - Java 反射:如何获取 Class 的实例
来自 ParameterizedType.getActualTypeArguments() 数组? - html - CSS Grid 在不同的行上重复不同的值
- kubernetes - 无法使用 kubectl cp 命令将数据从 POD 复制到本地
- python - 如何合并值
- python - 我第一次使用 python 进行网络抓取失败,通过 python 为每个人书
- azure - Azure 组件的自定义角色
- git - Git .gitignore 命令