亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

OpenCV圖像識別之姿態(tài)估計Pose?Estimation學習

 更新時間:2023年05月06日 09:34:30   作者:uncle_ll  
這篇文章主要為大家介紹了OpenCV圖像識別之姿態(tài)估計Pose?Estimation學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

目標

在本章中,將學習

  • 利用calib3d模塊在圖像中創(chuàng)建一些3D效果

基礎

在上一節(jié)相機校準中,了解了相機矩陣、失真系數等。給定圖案圖像,可以利用以上信息來計算其姿勢或物體在空間中的位置,例如其旋轉方式, 對于平面物體,可以假設Z=0Z = 0Z=0,問題就變成了如何將相機放置在空間中以查看圖案圖像。 因此,如果知道對象在空間中的位置,可以在其中繪制一些2D圖來模擬3D效果。

問題是,想在棋盤的第一個角上繪制3D坐標軸(X,Y,Z)。 X軸為藍色,Y軸為綠色,Z軸為紅色。 因此,實際上Z軸應該感覺像它垂直于棋盤平面。

首先,從先前的校準結果中加載相機矩陣和失真系數

import cv2
import pickle
import glob
import numpy as np
# load previously save data
with open(r"cam_calib.p", "rb") as f:
    data = pickle.load(f)
    mtx = data['cam_matrix']
    dist = data['dist_coeffs']

現在創(chuàng)建一個繪制繪制,該函數將棋盤上的角(使用cv2.findChessboardCorners()獲得) 和軸點繪制為3D。

def draw(img, corners, imgpts):
    corner = tuple(corners[0].ravel())
    img = cv2.line(img, corner, tuple(imgpts[0].ravel()), (255, 0, 0), 5)
    img = cv2.line(img, corner, tuple(imgpts[1].ravel()), (0, 255, 0), 5)
    img = cv2.line(img, corner, tuple(imgpts[2].ravel()), (0, 0, 255), 5)
    return img

然后,與前面的情況一樣,創(chuàng)建終止條件,對象點(棋盤上角的3D點)和軸點。 軸點是3D空間中用于繪制軸的點。 繪制長度為3的軸(單位將根據基于該尺寸校準的棋子方形寸)。因此X軸從(0,0,0)繪制為(3,0,0),Y軸也同樣如此。 對于Z軸,從(0,0,0)繪制為(0,0,-3)。 負號表示它朝向相機繪制。

criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 30, 0.001)
objp = np.zeros((6*7, 3), np.float32)
objp[:,:2] = np.mgrid[0:7,0:6].T.reshape(-1,2)
axis = np.float32([[3,0,0], [0,3,0], [0,0,-3]]).reshape(-1,3)

現在,加載每個圖像,搜索7x6的網格圖像。如果找到,將使用子角像素對其進行優(yōu)化。然后使用函數cv2.solvePnPRansac()計算旋轉和平移。一旦有了這些變換矩陣,就可以使

用它們將軸點投影到圖像平面上。簡而言之,在圖像平面上找到與3D空間中(3,0,0),(0,3,0),

(0,0,3)中的每一個相對應的點。一旦獲得它們,就可以使用draw()函數從第一個角到這些點中的每個點繪制線條。

for fname in glob.glob('right*.jpg'):
    img = cv2.imread(fname)
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    ret, corners = cv2.findChessboardCorners(gray, (7, 6),None)
    if ret == True:
        corners2 = cv2.cornerSubPix(gray,corners,(11, 11), (-1, -1), criteria)
        # Find the rotation and translation vectors.
        ret,rvecs, tvecs = cv2.solvePnP(objp, corners2, mtx, dist)
        # project 3D points to image plane
        imgpts, jac = cv2.projectPoints(axis, rvecs, tvecs, mtx, dist)
        img = draw(img,corners2,imgpts)
        cv2.imshow('img',img)
        k = cv2.waitKey(0) & 0xFF
        if k == ord('s'):
            cv2.imwrite(fname[:6]+'.png', img)
cv2.destroyAllWindows()

每個軸長3個單位。

繪制立方體

如果要繪制立方體,修改draw()函數和軸點。 修改后的draw()函數:

def draw(img, corners, imgpts):
    imgpts = np.int32(imgpts).reshape(-1,2)
    # draw ground floor in green
    img = cv2.drawContours(img, [imgpts[:4]],-1,(0,255,0),-3)
    # draw pillars in blue color
    for i, j in zip(range(4),range(4,8)):
        img = cv2.line(img, tuple(imgpts[i]), tuple(imgpts[j]),(255),3)
    # draw top layer in red color
    img = cv2.drawContours(img, [imgpts[4:]],-1,(0,0,255),3)
    return img

修改的軸點。它們是3D空間中多維數據集的8個角:

axis = np.float32([[0,0,0], [0,3,0], [3,3,0], [3,0,0],
                   [0,0,-3],[0,3,-3],[3,3,-3],[3,0,-3] ])

如果對圖形,增強現實等感興趣,則可以使用OpenGL渲染更復雜的圖形(感謝毛星云大佬)。

附加資源

以上就是OpenCV圖像識別之姿態(tài)估計Pose Estimation學習的詳細內容,更多關于OpenCV圖像識別姿態(tài)估計的資料請關注腳本之家其它相關文章!

相關文章

  • Python BautifulSoup 節(jié)點信息

    Python BautifulSoup 節(jié)點信息

    這篇文章主要介紹了Python BautifulSoup 節(jié)點信息,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • OpenCV-Python實現腐蝕與膨脹的實例

    OpenCV-Python實現腐蝕與膨脹的實例

    形態(tài)學操作主要包含:腐蝕,膨脹,開運算,閉運算,形態(tài)學梯度運算,頂帽運算,黑帽運算等操作,本文主要介紹了腐蝕與膨脹,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 使用Python函數進行模塊化的實現

    使用Python函數進行模塊化的實現

    這篇文章主要介紹了使用Python函數進行模塊化的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • python內存管理分析

    python內存管理分析

    這篇文章主要介紹了python內存管理,較為詳細的分析了Python的內存管理機制,需要的朋友可以參考下
    2015-04-04
  • Numpy ndarray 多維數組對象的使用

    Numpy ndarray 多維數組對象的使用

    這篇文章主要介紹了Numpy ndarray 多維數組對象的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • django認證系統(tǒng)實現自定義權限管理的方法

    django認證系統(tǒng)實現自定義權限管理的方法

    今天小編就為大家分享一篇django認證系統(tǒng)實現自定義權限管理的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Python Scrapy圖片爬取原理及代碼實例

    Python Scrapy圖片爬取原理及代碼實例

    這篇文章主要介紹了Python Scrapy圖片爬取原理及代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • Python autoescape標簽用法解析

    Python autoescape標簽用法解析

    這篇文章主要介紹了Python autoescape標簽用法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-01-01
  • 使用python獲取csv文本的某行或某列數據的實例

    使用python獲取csv文本的某行或某列數據的實例

    下面小編就為大家分享一篇使用python獲取csv文本的某行或某列數據的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • python如何通過閉包實現計算器的功能

    python如何通過閉包實現計算器的功能

    這篇文章主要介紹了python如何通過閉包實現計算器的功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02

最新評論