简单的单目测距实验

一、原理
简单的单目测距方法,假设相机平面和物体平面平行,相机正对着物体表面拍摄,则可以利用相似三角形法。

用相似三角形计算物体或者目标到相机的距离,将使用相似三角形来计算相机到一个已知的物体或者目标的距离。
在这里插入图片描述

假设有一个宽度/高度为 W 的目标或者物体。然后将这个目标放在距离的相机为 D 的位置。用相机对物体进行拍照并且测量物体的像素宽度/高度 P。

这样就得出了相机焦距的公式:

F = (P x D) / W

当继续将的相机移动靠近或者离远物体或者目标时,可以用相似三角形来计算出物体离相机的距离:
D’ = (W x F) / P。
二、实验过程
以下操作均有误差:

实验采用的直接是笔记本摄像头,直接拍摄图像测试,忽略了相机标定和相机校正过程,如果想要更加准确的结果还是要操作一下。

拍摄的实际图像目标区域的大小:宽:9cm,高:4.8cm,测试的实际距离为24cm,用的时候单位要换算为英尺。
拍摄的图像如下图所示:
在这里插入图片描述
代码:


# -*- coding: utf-8 -*-
import cv2 # 导入Opencv库

KNOWN_DISTANCE = 9.45 # 这个距离自己实际测量一下

KNOWN_WIDTH = 3.54 # A4纸的宽度

KNOWN_HEIGHT = 1.89

IMAGE_PATHS = ["0001.jpg", "0002.jpg", "0003.jpg","0004.jpg","0005.jpg","0006.jpg"] # 将用到的图片放到了一个列表中

# 定义目标函数

def find_marker(image):

    gray_img = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 将彩色图转化为灰度图

    gray_img = cv2.GaussianBlur(gray_img, (5, 5), 0) # 高斯平滑去噪

    edged_img = cv2.Canny(gray_img, 35, 125) # Canny算子阈值化

    #cv2.imshow("降噪效果图", edged_img) # 显示降噪后的图片

    # 获取纸张的轮廓数据

    countours, hierarchy = cv2.findContours(edged_img.copy(), cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)

    # print(len(countours))

    c = max(countours, key=cv2.contourArea) # 获取最大面积对应的点集

    #rect = cv2.minAreaRect(c) # 最小外接矩形
    rect = cv2.boundingRect(c)  # 最小外接矩形
    return rect

# 定义距离函数

def distance_to_camera(knownWidth, focalLength, perWidth):

    return (knownWidth * focalLength) / perWidth

def true_width(knownWidth, focalLength, perWidth):

    return (knownWidth * perWidth) / focalLength
# 计算摄像头的焦距(内参)

def calculate_focalDistance(img_path):

    first_image = cv2.imread(img_path) # 这里根据准备的第一张图片,计算焦距

# cv2.imshow('first image', first_image)

    marker = find_marker(first_image) # 获取矩形的中心点坐标,长度,宽度和旋转角度

    #focalLength = (marker[1][0] * KNOWN_DISTANCE) / KNOWN_WIDTH # 获取摄像头的焦距
    focalLength = (marker[2] * KNOWN_DISTANCE) / KNOWN_WIDTH  # 获取摄像头的焦距
# print(marker[1][0])

    print('焦距(focalLength) = ', focalLength) # 打印焦距的值

    return focalLength

# 计算摄像头到物体的距离

def calculate_Distance(image_path, focalLength_value):
    image = cv2.imread(image_path)

    # cv2.imshow("原图", image)

    marker = find_marker(image)  # 获取矩形的中心点坐标,长度,宽度和旋转角度, marke[1][0]代表宽度

    # distance_inches = true_with(KNOWN_DISTANCE, focalLength_value, marker[1][0])
    distance_inches = distance_to_camera(KNOWN_WIDTH, focalLength_value, marker[2])
    # box = cv2.boxPoints(marker)
    #
    # # print("Box = ", box)
    #
    # box = np.int0(box)
    #
    # print("Box = ", box)

    # cv2.drawContours(image, [box], -1, (0, 255, 0), 2) # 绘制物体轮廓
    cv2.rectangle(image, (marker[0], marker[1]), (marker[0] + marker[2], marker[1] + marker[3]), (0, 255, 0),
                  2)  # green
    cv2.putText(image, "%.2fcm" % (distance_inches * 2.54), (image.shape[1] - 300, image.shape[0] - 20),

                cv2.FONT_HERSHEY_SIMPLEX, 2.0, (0, 255, 0), 3)

    cv2.imshow("result", image)

if __name__ == "__main__":

    img_path = "0001.jpg"

    focalLength = calculate_focalDistance(img_path)

    for image_path in IMAGE_PATHS:

        calculate_Distance(image_path, focalLength)

        cv2.waitKey(0)

        cv2.destroyAllWindows()

测试效果:
在这里插入图片描述
实验条件比较简陋,这种方式的鲁棒性也比较差,当有角度偏差时测量就不那么准确了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/9975.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

执行数学的运算

数学是计算机编程的重要能力。遗憾的是,对shell脚本来说,这个处理过程比较麻烦。在shell脚本中两种途径来进行数学运算。 expr命令 最开始,Bourne shell提供了一个特别的命令用来处理数学表达式。expr命令允许在命令行上处理数学数学表达式。…

算法学习day59

算法学习day591.力扣503.下一个更大元素II1.1 题目描述1.2 分析1.3代码2.力扣42. 接雨水2.1 题目描述2.2 分析2.3 代码3.参考资料1.力扣503.下一个更大元素II 1.1 题目描述 题目描述: 给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素&a…

【Java 并发编程】一文了解线程间有哪些通信方式?

一文了解线程间有哪些通信方式?1. synchronized 内置锁2. volatile 关键字3. 等待/通知机制3.1 等待wait()wait(long)wait(long, int)等待方需遵循如下原则3.2 通知notify()notifyAll()通知方需遵循如下原则notify() 和 notifyAll() 应该用谁?4. 管道输入…

BusterNet网络Python模型实现学习笔记一

实在是无力吐槽了,心力交瘁。作者Github仓库给了错误的 USCISI-CMFD-Small 数据集。自己捣鼓了半天,发现原来是压缩之后数据集,也就是 LMDB 文件格式出错了。实在是误人子弟,自己已经气急败坏了现在… 但是既然论文都花那么长时间…

数据分析之Pandas 基础入门

一、初始Pandas pandas 是数据分析三大件之一,是Python的核心分析库,它提供了快捷、灵活、明确的数据结构,它能够简单、直观、快速的处理各种类型的数据结构。 pandas 支持的数据结构如下: SQL 或Excel 类似的数据有序或无序的…

【学习笔记】unity脚本学习(三)(向量 Vector3)

目录向量复习高中向量基础【数学】向量的四则运算、点积、叉积、正交基叉乘公式叉乘运算定理向量、坐标系点积叉积Vector3 三维向量静态变量变量变量normalized 与 Normalize() 方法静态方法ClampMagnitudeCrossDistanceDotMoveTowards其他变换类似Lerp 在两个点之间进行线性插…

实现一个简单但有趣的AR效果(Web)

有人说:一个人从1岁活到80岁很平凡,但如果从80岁倒着活,那么一半以上的人都可能不凡。 生活没有捷径,我们踩过的坑都成为了生活的经验,这些经验越早知道,你要走的弯路就会越少。

MySQL 库操作

目录 创建数据库 语法 案例 字符集和校验规则(建数据库/建表用) 查看系统默认字符集以及校验规则 db.opt 更改 查看数据库支持的字符集 查看数据库支持的字符集校验规则 校验规则对数据库的影响 排升序 操纵数据库 查看数据库 显示创建语…

洛谷P2822:组合数问题 ←(帕斯卡法则+取模+前缀和)

【题目来源】https://www.luogu.com.cn/problem/P2822https://www.acwing.com/problem/content/525/【题目描述】 组合数​表示的是从n个物品中选出m个物品的方案数。举个例子:从(1,2,3)三个物品中选择两个物品可以有(1,2),(1,3),(2,3) 这三种…

MySQl_1

一.相关概念 数据库:存放数据的仓库 数据库管理系统:操作和管理数据库的大型软件,如mysql SQL:一种操作 关系型数据库管理系统的语言,定义了一套操作关系型数据库管理系统的统一标准。 关系型数据库:有多…

客户案例 | 迎接智能化浪潮,传统水厂数字化势在必行

关键发现 客户痛点:传统水厂业务离散,无法实现数据实时同步,为收集和分析处理数据并辅助决策带来障碍。需要智能化管理系统帮助水厂提升管理效率,优化管理流程,实现数字化、智能化的目标。 解决方案:天津腾…

PyTorch深度学习实战 | 基于ResNet的人脸关键点检测

人脸关键点检测指的是用于标定人脸五官和轮廓位置的一系列特征点的检测,是对于人脸形状的稀疏表示。关键点的精确定位可以为后续应用提供十分丰富的信息。因此,人脸关键点检测是人脸分析领域的基础技术之一。许多应用场景(如人脸识别、人脸三维重塑、表情…

Mariadb10.5基于同服务器多实例主从配置

本次部署环境:Centos8stream 本次部署mariadb版本: mariadb:10.5 本次部署方式:rpm包直接安装,并通过systemd直接托管 可以参考 /usr/lib/systemd/system/mariadb.service 该文件 # Multi instance version of mariadb. For i…

python wannier90 基于wannier90的*_hr.dat文件选取截断hopping绘制能带图

我们知道wannier90可以根据选取TMDs的轨道信息生成详细的hopping energy *_hr.dat文件,选取所有的hopping绘制起来的时候比较简单,但是我们发现取几圈的近似hopping也可以将band表示出来,类似的思想有Pybinding的三带近似(DOI: 10…

初中级Android工程师如何快速成长寻求突破

前言 写这篇文章的初衷是看到很多同学在一家公司工作了三五年,因为技术没有得到提升而随着年龄的增长导致不敢提出涨薪和跳槽找工作。希望这篇文章能够给这些还是初中级Android工程师的朋友一些启发。 快速成长 我们在向领导提出加薪申请或者是准备跳槽到更大的平…

【论文阅读】On clustering using random walks

《On clustering using random walks》阅读笔记 1. 问题建模 1.1 问题描述 let G(V,E,ω)G(V,E,\omega)G(V,E,ω) be a weighted graph, VVV is the set of nodes, EEE is the edge between nodes in VVV, ω\omegaω is the function ω:E→Rn\omega&#xff1a…

初识掌控板2.0、官方拓展板和配套编程软件mpython

不是广告!!不是广告!! 一、掌控板2.0概览 掌控板又名掌上联网计算机,是一款为青少年学习Python编程和创意制造,特别是物联网应用而设计的开源硬件。内置microPython开源嵌入式Python运行环境,可…

快排非递归 归并排序

递归深度太深会栈溢出 程序是对的&#xff0c;但是递归个10000层就是栈溢出 int fun(int n) {if (n < 1){return n;}return fun(n - 1) n; }所以需要非递归来搞快排和归并&#xff0c;在效率方面没什么影响&#xff0c;只是解决递归深度太深的栈溢出问题 有的能直接改&am…

快速尝鲜Oracle 23c免费开发者版,惊喜多多

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

Matplotlib数据可视化

Matplotlib是⼀个Python 2D&#xff0c;3D绘图库&#xff0c;它以多种硬拷⻉格式和跨平台的交互式环境⽣成出版物质量的图形。 MatplotlibMatplotlib中文网、Matplotlib官方中文文档。https://www.matplotlib.org.cn/ 1.模块导⼊ import matplotlib.pyplot as plt #使⽤py…