python opencv单目测距 小孔成像原理

小孔成像原理

一 用相似三角形计算物体或者目标到相机的距离

我们将使用相似三角形来计算相机到一个已知的物体或者目标的距离。

相似三角形就是这么一回事:假设我们有一个宽度为 W 的目标或者物体。然后我们将这个目标放在距离我们的相机为 D 的位置。我们用相机对物体进行拍照并且测量物体的像素宽度 P 。这样我们就得出了相机焦距的公式:

F = (P x D) / W

举个例子,假设我在离相机距离 D = 24 英寸的地方放一张标准的 8.5 x 11 英寸的 A4 纸(横着放;W = 11)并且拍下一张照片。我测量出照片中 A4 纸的像素宽度为 P = 249 像素。

因此我的焦距 F 是:

F = (248px x 24in) / 11in = 543.45

当我继续将我的相机移动靠近或者离远物体或者目标时,我可以用相似三角形来计算出物体离相机的距离:

D’ = (W x F) / P

为了更具体,我们再举个例子,假设我将相机移到距离目标 3 英尺(或者说 36 英寸)的地方并且拍下上述的 A4 纸。通过自动的图形处理我可以获得图片中 A4 纸的像素距离为 170 像素。将这个代入公式得:

D’ = (11in x 543.45) / 170 = 35 英寸

或者约 36 英寸,合 3 英尺。

从以上的解释中,我们可以看到,要想得到距离,我们就要知道摄像头的焦距和目标物体的尺寸大小,这两个已知条件根据公式:

D’ = (W x F) / P

得出目标到摄像机的距离D,其中P是指像素距离,W是A4纸的宽度,F是摄像机焦距。

代码 opencv>3.x

#!usr/bin/python

# -*- coding: utf-8 -*-

#定义编码,中文注释

#import the necessary packages

import numpy as np

import cv2

# 找到目标函数

def find_marker(image):

# convert the image to grayscale, blur it, and detect edges

gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

gray = cv2.GaussianBlur(gray, (5, 5), 0)

edged = cv2.Canny(gray, 35, 125)

# find the contours in the edged image and keep the largest one;

# we'll assume that this is our piece of paper in the image

(cnts, _) = cv2.findContours(edged.copy(), cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)

# 求最大面积

c = max(cnts, key = cv2.contourArea)

# compute the bounding box of the of the paper region and return it

# cv2.minAreaRect() c代表点集,返回rect[0]是最小外接矩形中心点坐标,

# rect[1][0]是width,rect[1][1]是height,rect[2]是角度

return cv2.minAreaRect(c)

# 距离计算函数

def distance_to_camera(knownWidth, focalLength, perWidth):

# compute and return the distance from the maker to the camera

return (knownWidth * focalLength) / perWidth

# initialize the known distance from the camera to the object, which

# in this case is 24 inches

KNOWN_DISTANCE = 24.0

# initialize the known object width, which in this case, the piece of

# paper is 11 inches wide

# A4纸的长和宽(单位:inches)

KNOWN_WIDTH = 11.69

KNOWN_HEIGHT = 8.27

# initialize the list of images that we'll be using

IMAGE_PATHS = ["1.jpg", "2.jpg", "1.jpg"]

# load the furst image that contains an object that is KNOWN TO BE 2 feet

# from our camera, then find the paper marker in the image, and initialize

# the focal length

#读入第一张图,通过已知距离计算相机焦距

image = cv2.imread(IMAGE_PATHS[0])

marker = find_marker(image)

focalLength = (marker[1][0] * KNOWN_DISTANCE) / KNOWN_WIDTH

#通过摄像头标定获取的像素焦距

#focalLength = 811.82

print('focalLength = ',focalLength)

#打开摄像头

camera = cv2.VideoCapture(0)

while camera.isOpened():

# get a frame

(grabbed, frame) = camera.read()

marker = find_marker(frame)

if marker == 0:

print(marker)

continue

inches = distance_to_camera(KNOWN_WIDTH, focalLength, marker[1][0])

# draw a bounding box around the image and display it

box = np.int0(cv2.boxPoints(marker))

cv2.drawContours(frame, [box], -1, (0, 255, 0), 2)

# inches 转换为 cm

cv2.putText(frame, "%.2fcm" % (inches *30.48/ 12),

(frame.shape[1] - 200, frame.shape[0] - 20), cv2.FONT_HERSHEY_SIMPLEX,

2.0, (0, 255, 0), 3)

# show a frame

cv2.imshow("capture", frame)

if cv2.waitKey(1) & 0xFF == ord('q'):

break

camera.release()

cv2.destroyAllWindows()

有问题添加QQ群:686070107

python手机摄像头投测距_python opencv单目测距 小孔成像原理相关推荐

  1. pythonopencv测距_python opencv单目测距 小孔成像原理

    有问题添加QQ群:686070107 小孔成像原理 一 用相似三角形计算物体或者目标到相机的距离 我们将使用相似三角形来计算相机到一个已知的物体或者目标的距离. 相似三角形就是这么一回事:假设我们有一 ...

  2. python opencv单目测距 小孔成像原理

    python opencv单目测距 小孔成像原理 小孔成像原理 代码 opencv>3.x 小孔成像原理 一 用相似三角形计算物体或者目标到相机的距离 我们将使用相似三角形来计算相机到一个已知的 ...

  3. OpenCV 单目测距实现

    最近要做一个小项目,要完成相机的测距实现,最先考虑的是三角激光测距,但是实现起来太麻烦了,基本要搭一个简易的激光测距雷达...然后是双目测距,然而一个便宜的双目工业相机也要四五百,而且以前也没接触过双 ...

  4. yolo 车辆测距+车辆识别+单目测距(双目测距)

    基于yolo目标检测算法实现的车前道路中的车辆和行人检测,并且可以估测出目标与本车之间的距离 一.视频展示 yolo车距1 订阅专栏获得源码(提供完整代码,无需看下文) 二.单目测距原理 图中有一个车 ...

  5. python调用摄像头录制视频_Python OpenCV使用摄像头捕获视频

    我们知道,OpenCV是一款强大的跨平台的计算机视觉库,使用它能完成我们对于图像和视频处理的很多功能,今天,我们使用OpenCV来捕获计算机摄像头的视频. 使用OpenCV捕获摄像头视频 我们知道,视 ...

  6. python测量镜头到目标距离_摄像头单目测距原理及实现

    摄像头单目测距原理及实现 一.测距原理 空间的深度或距离等数据的摄像头. 人的眼睛长在头部的前方,两只眼的视野范围重叠,两眼同时看某一物体时,产生的视觉称为双眼视觉. 双眼视觉的优点是可以弥补单眼视野 ...

  7. 如何用摄像头来测距(opencv)

     如何用摄像头来测距(opencv) 作者:郭世龙 最近一直忙着找工作,blog都长草了,今天把以前作的一个东西放上来充充门面吧.记得在哪看到过老外做的这个东西,觉得很好玩,就自己也做了一个.在摄像头 ...

  8. 【自动驾驶】摄像头单目测距原理及实现

    原文链接:摄像头单目测距原理及实现 可以观看这个视频,了解针孔相机和透镜. 摄像头单目测距原理及实现 一.测距原理 空间的深度或距离等数据的摄像头. 人的眼睛长在头部的前方,两只眼的视野范围重叠,两眼 ...

  9. python 人脸检测、单目测距以及人脸打码

    最近想写博客但是下班后完全提不起兴趣,今天周末刚好闲下心来,想了想把在github发现的一个人脸检测项目调试了下,发现挺不错的,准确率跟速度都挺适合低配版设备使用,所以过几天想自己训练一下检测车牌,试 ...

最新文章

  1. 装饰者模式 将子类当做构造器参数传递进去 ,并重写子类的方法同时增加子类的功能 调用调用重写的子类的方法...
  2. python新手入门教程-终于知晓python新手练习教程
  3. 图像分割(Image Segmentation)
  4. malloc与new的区别
  5. WINCE6.0添加特定的软件键盘
  6. java中main方法返回类型是6_[单选] Java application中的主类需包含main方法,main方法的返回类型是什么()。...
  7. 10.2. Incron - cron-like daemon which handles filesystem events
  8. 看我72变:解决Entity Framework中枚举类型与tinyint的映射问题
  9. 《高可用架构·中国初创故事(第3期)》一2.5 指导
  10. Python排序算法---快速排序
  11. Lingo18.0安装教程(超级详细,不会可以问博主)
  12. 累次积分怎么计算_【高等数学】二重积分化累次积分方法
  13. PayPal如何提现人民币?PayPal提现到国内银行的最新教程!
  14. 【Pyqt5】实现小学三年级口算题生成器
  15. mysql aix版本查看_AIX 查看aio状态
  16. 饮料自动售货机模拟(小项目)
  17. 网上报修系统java源码_网上报修系统管理软件
  18. .php文件是病毒吗,php病毒
  19. 英语学习单词篇(15)
  20. 总有一句能触动你,总有那么一个人在等候你,生死看淡,不服就干

热门文章

  1. 区别:秒s、毫秒ms、微秒μs、纳秒ns、皮秒ps、飞秒fs每两级之间的换算以及之间的关系
  2. 第三次作业--团队展示(团队)
  3. java线程调度(优先级,休眠,让步,等待)
  4. PHP_微信公众号开发(1)
  5. Word技巧:在表格前添加空行
  6. 使用 Plotly 和 ChartJS 图形库创建 Flask 仪表板
  7. java实现登录验证机制的技术_基于token的登陆验证机制
  8. 关联数据赋能智能化业务
  9. scala学习之scala中一些集合的常用函数
  10. Java和开源GIS平台