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

OpenCV實(shí)現(xiàn)單目攝像頭對(duì)圖像目標(biāo)測(cè)距

 更新時(shí)間:2022年08月01日 09:12:17   作者:奶茶不加冰  
這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)單目攝像頭對(duì)圖像目標(biāo)測(cè)距,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

使用opencv對(duì)單目攝像頭中的目標(biāo)實(shí)現(xiàn)測(cè)量距離(python實(shí)現(xiàn)),供大家參考,具體內(nèi)容如下

1.方法介紹:

根據(jù)相似三角形的方法:

F = P×D / W , 其中W為物體的實(shí)際寬度,D為物體平面與相機(jī)平面的距離,照片上物體的像素寬度為P,相機(jī)焦距為F
D = F×W / P ,這樣知道相機(jī)的內(nèi)參焦距就可以求得物體平面與相機(jī)平面的距離D

2.代碼:

import cv2
import imutils
import numpy as np
from imutils import paths


# 獲取目標(biāo)的輪廓信息
def find_marker(image):

? ? gray = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) ?# 顏色空間轉(zhuǎn)換函數(shù),RGB和BGR顏色空間轉(zhuǎn)換 opencv默認(rèn)的顏色空間是BGR
? ? gray = cv2.GaussianBlur(gray, (5, 5), 0) ?# 高斯濾波,對(duì)圖像進(jìn)行濾波操作 ,(5,5)表示高斯核的大小 ,0 表示標(biāo)準(zhǔn)差取0
? ? edged = cv2.Canny(gray, 35, 125) ?# canny 算子 邊緣檢測(cè) 35是閾值1, 125是閾值2,大的閾值用于檢測(cè)圖像中的明顯邊緣,小的閾值用于將不明顯的邊緣檢測(cè)連接起來(lái)

? ? cnts = cv2.findContours(edged.copy(), cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE) ?# 找到詳細(xì)的輪廓點(diǎn), RETR_LIST 以列表的形式輸出輪廓信息
? ? # CHAIN_APPROX_SIMPLE: 壓縮水平方向,垂直方向,對(duì)角線方向的元素,只保留該方向的終點(diǎn)坐標(biāo)

? ? cnts = imutils.grab_contours(cnts) ?# 尋找圖像的輪廓信息,輸入圖像為一個(gè)二值圖像

? ? c = max(cnts, key=cv2.contourArea) ?# 輪廓點(diǎn)的面積計(jì)算
? ? # return edged
? ? return cv2.minAreaRect(c) ?# 求出在 C點(diǎn)集下的像素點(diǎn)的面積


def get_F(W, D):

? ? P = find_marker(image)[1][0] / 118.11 ?# 300dim ?1cm = 118.11像素值

? ? return (P*D) / W ?# F = get_F(2, 126) ?# 輸出的值為cm f=24.003cm 焦距


def distance_to_camera(F, P, W):

? ? return (F*W) / P ?# F 為相機(jī)的焦距,w為物體的寬度,P為物體在照片中的像素寬度,需要轉(zhuǎn)換為cm


W = 2 ?# 需要手動(dòng)測(cè)量目標(biāo)的寬度,單位為cm
F = 24.00304 ?# 根據(jù)get_F求出 ,get_F()函數(shù)是為了求得相機(jī)的焦距,需要通過(guò)測(cè)試圖像中的目標(biāo)距離來(lái)求出

image = cv2.imread('065_5.jpg')
marker = find_marker(image)
P = marker[1][0] / 118.11 ?# 300dim 1cm = 118.11像素值 ,300dim指300分辨率,有1080分辨率,像素值的㎝轉(zhuǎn)換是不同
inches = distance_to_camera(F, P, W) #
print('距離為:%.2f cm' % inches) ?# 單位為cm

# draw a bounding box around the image and display it
box = cv2.cv.BoxPoints(marker) if imutils.is_cv2() else cv2.boxPoints(marker)
box = np.int0(box)
cv2.drawContours(image, [box], -1, (0, 255, 0), 2)
cv2.putText(image, "%.2fft" % inches,
? ? ? ? ? ? (image.shape[1] - 200, image.shape[0] - 20), cv2.FONT_HERSHEY_SIMPLEX,
? ? ? ? ? ? 2.0, (0, 255, 0), 3)
cv2.imshow("image", image)

cv2.waitKey(0)
cv2.destroyAllWindows()

3.效果驗(yàn)證

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python騷操作完美實(shí)現(xiàn)短視頻偽原創(chuàng)

    Python騷操作完美實(shí)現(xiàn)短視頻偽原創(chuàng)

    剪輯的視頻上傳到某平臺(tái)碰到降權(quán)怎么辦?視頻平臺(tái)都有一套自己的鑒別算法,專(zhuān)門(mén)用于處理視頻的二次剪輯,本篇我們來(lái)用python做一些特殊處理
    2022-02-02
  • 13個(gè)你可能未使用過(guò)的Python特性分享

    13個(gè)你可能未使用過(guò)的Python特性分享

    Python?是頂級(jí)編程語(yǔ)言之一,它具有許多程序員從未使用過(guò)的許多隱藏功能。在這篇博客中,將和大家分享一下你可能從未使用過(guò)的13?個(gè)?Python?特性,感興趣的可以學(xué)習(xí)一下
    2022-11-11
  • pandas高效讀取大文件的示例詳解

    pandas高效讀取大文件的示例詳解

    使用?pandas?進(jìn)行數(shù)據(jù)分析時(shí),第一步就是讀取文件,所以這篇文章主要來(lái)和大家討論一下pandas如何高效讀取大文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下
    2024-01-01
  • PyTorch 中的傅里葉卷積實(shí)現(xiàn)示例

    PyTorch 中的傅里葉卷積實(shí)現(xiàn)示例

    這篇文章主要介紹了PyTorch 中的傅里葉卷積實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Python高級(jí)編程之繼承問(wèn)題詳解(super與mro)

    Python高級(jí)編程之繼承問(wèn)題詳解(super與mro)

    這篇文章主要介紹了Python高級(jí)編程之繼承問(wèn)題,結(jié)合實(shí)例形式詳細(xì)分析了Python多繼承、MRO順序及super調(diào)用父類(lèi)等相關(guān)操作技巧,需要的朋友可以參考下
    2019-11-11
  • Python面試不修改數(shù)組找出重復(fù)的數(shù)字

    Python面試不修改數(shù)組找出重復(fù)的數(shù)字

    這篇文章主要為大家介紹了不修改數(shù)組找出重復(fù)的數(shù)字Python實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Python中numpy數(shù)組真值判斷的實(shí)現(xiàn)

    Python中numpy數(shù)組真值判斷的實(shí)現(xiàn)

    在Python編程中,經(jīng)常需要對(duì)數(shù)組進(jìn)行真值判斷,本文就來(lái)介紹一下Python中numpy數(shù)組真值判斷的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • python+pygame實(shí)現(xiàn)代碼雨(黑客帝國(guó)既視感)

    python+pygame實(shí)現(xiàn)代碼雨(黑客帝國(guó)既視感)

    這篇文章主要介紹了python+pygame實(shí)現(xiàn)代碼雨(黑客帝國(guó)既視感),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 利用Python寫(xiě)個(gè)簡(jiǎn)易版星空大戰(zhàn)游戲

    利用Python寫(xiě)個(gè)簡(jiǎn)易版星空大戰(zhàn)游戲

    通過(guò)小編觀察,大家好像對(duì)劃水摸魚(yú)是情有獨(dú)鐘啊。所以本文給大家?guī)?lái)了一個(gè)用Python編寫(xiě)的簡(jiǎn)單版的星空大戰(zhàn)小游戲,感興趣的小伙伴可以動(dòng)手試一試
    2022-03-03
  • Python之random.sample()和numpy.random.choice()的優(yōu)缺點(diǎn)說(shuō)明

    Python之random.sample()和numpy.random.choice()的優(yōu)缺點(diǎn)說(shuō)明

    這篇文章主要介紹了Python之random.sample()和numpy.random.choice()的優(yōu)缺點(diǎn)說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06

最新評(píng)論