Python+OpenCV實現(xiàn)相機標(biāo)定的方法詳解
opencv中內(nèi)置了張正友的棋盤格標(biāo)定法,通過一些姿態(tài)各異的棋盤格圖像,就能標(biāo)定相機的內(nèi)外參數(shù)。
角點檢測
第一步是角點檢測,首先需要讀取棋盤格圖像
import numpy as np import cv2 import os path = 'imgs' # 圖像文件夾;相對路徑 fs = os.listdir(path) grays = [] for f in fs: fName = os.path.join(path, f) img = cv2.imread(fName) gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 圖像轉(zhuǎn)灰度 grays.append(gray)
其中,grays中便是所有棋盤格灰度圖像,接下來,就要找到這些棋盤格的角點位置,主要用到函數(shù)findChessboardCorners,其輸入?yún)?shù)為棋盤格圖像、角點個數(shù)以及標(biāo)志位。
w, h = 11, 8 # 交點橫縱個數(shù) # 亞像素點的檢測條件 criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 30, 0.001) pImgs = [] for g in grays: # cs即位初步檢測的角點 ret, cs = cv2.findChessboardCorners(g, (w, h), None) # 亞像素角點檢測 pImg = cv2.cornerSubPix(g, cs.astype(np.float32), (5, 5), (-1, -1), criteria) pImgs.append(np.squeeze(pImg))
其中,pImg用于存放像素坐標(biāo)中的二維點。
查看角點
為了驗證角點檢測是否合理,可以將其畫出來,用opencv自帶的工具就像下面這樣就可以,
cv2.drawChessboardCorners(grays[0], (w, h), pImgs[0], None) cv2.imshow('findCorners', grays[0]) cv2.waitKey(1000)
但窗口縮放比較麻煩,所以更推薦用經(jīng)典的matplotlib來畫圖
import matplotlib.pyplot as plt pts = pImgs[0].squeeze().reshape(-1,2).T plt.imshow(grays[0]) plt.scatter(pts[0], pts[1], marker='*', c='red') plt.show()
效果如下
標(biāo)定
函數(shù)calibrateCamera可用于圖像標(biāo)定,只需將現(xiàn)實世界的點和相機坐標(biāo)系中的角點的一一對應(yīng)關(guān)系輸入,便能得到相應(yīng)的相機矩陣。其中,現(xiàn)實世界中哦的三維點,一般成為對象點,由于棋盤格中每個方塊都是等距的,故可直接建立為類似(1,0,0), (2,0,0)...即可
objp = np.zeros((6*7,3), np.float32) objp[:,:2] = np.mgrid[0:7,0:6].T.reshape(-1,2) pObj = np.zeros((w*h, 3), np.float32) pObj[:,:2] = np.mgrid[0:w, 0:h].T.reshape(-1,2) pObjs = [pObj for _ in range(len(pImgs))]
至此,萬事俱備,只需調(diào)用
size = grays[0].shape[::-1] # 圖像尺寸 ret, mtx, dist, rvecs, tvecs = cv2.calibrateCamera(pObjs, pImgs, size, None, None)
其中,rec為成功標(biāo)志,為True時表示標(biāo)定成功。
mtx為內(nèi)參矩陣,差不多是
dist為畸變參數(shù),最多有8個,分別表示k1,k2,p1,p2,k3,k4,k5,k6,本次標(biāo)定得到的結(jié)果為
>>> print(dist)
[[-8.36577030e-02 -1.68977185e-01 -1.12233478e-03 9.45685802e-04
-2.04246147e+01]]
這些畸變參數(shù)的物理意義如下
以上就是Python+OpenCV實現(xiàn)相機標(biāo)定的方法詳解的詳細內(nèi)容,更多關(guān)于Python OpenCV相機標(biāo)定的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python測試開發(fā)django之使用supervisord?后臺啟動celery?服務(wù)(worker/beat)
Supervisor是用Python開發(fā)的一個client/server服務(wù),是Linux/Unix系統(tǒng)下的一個進程管理工具,不支持Windows系統(tǒng),這篇文章主要介紹了python測試開發(fā)django之使用supervisord?后臺啟動celery?服務(wù)(worker/beat),需要的朋友可以參考下2022-07-07Python使用socket實現(xiàn)組播與發(fā)送二進制數(shù)據(jù)
在工作中經(jīng)常會用到socket傳輸數(shù)據(jù),例如客戶端給服務(wù)器發(fā)送數(shù)據(jù)(雙方約定了數(shù)據(jù)格式),本文主要介紹了Python使用socket實現(xiàn)組播與發(fā)送二進制數(shù)據(jù),感興趣的可以了解一下2021-06-06Django框架使用內(nèi)置方法實現(xiàn)登錄功能詳解
這篇文章主要介紹了Django框架使用內(nèi)置方法實現(xiàn)登錄功能,結(jié)合實例形式詳細分析了Django框架內(nèi)置方法實現(xiàn)登錄功能的相關(guān)操作技巧與使用注意事項,需要的朋友可以參考下2019-06-06Python中免驗證跳轉(zhuǎn)到內(nèi)容頁的實例代碼
在本篇文章里小編給大家整理的是一篇關(guān)于Python中免驗證跳轉(zhuǎn)到內(nèi)容頁的實例代碼,有興趣的朋友們可以學(xué)習(xí)分享下。2020-10-10