基于YOLO算法的单目相机2D测量(工件尺寸和物体尺寸)三

news/2024/7/11 0:02:09 标签: YOLO, 算法, 数码相机

1.简介

1.1 2D测量技术

基于单目相机的2D测量技术在许多领域中具有重要的背景和意义。

工业制造:在工业制造过程中,精确测量是确保产品质量和一致性的关键。基于单目相机的2D测量技术可以用于检测和测量零件尺寸、位置、形状等参数,进而实现自动化生产和质量控制。通过实时监测并反馈测量结果,可以快速发现和纠正生产中的偏差,提高产品的一致性和合格率。

计算机视觉:单目相机作为计算机视觉的传感器之一,能够捕捉并记录场景中的图像信息。基于单目相机的2D测量技术可以通过对图像进行处理和分析来提取目标物体的特征和参数。这种技术在目标检测、物体跟踪、姿态估计等计算机视觉任务中起着至关重要的作用。

地理测绘和导航:基于单目相机的2D测量技术可以应用于地理测绘和导航领域。通过获取地面或航空图像,并利用图像处理和计算机视觉算法,可以实现地表特征的提取、地形建模、数字地图的生成等工作。这对于城市规划、农业管理、导航系统等方面具有重要的应用价值。

医学影像:在医学领域,基于单目相机的2D测量技术可以用于医学影像的分析和测量。通过对医学图像进行处理和分析,可以提取器官、病灶的形状、大小、位置等信息,辅助医生进行诊断和治疗决策。这种技术在影像学、放射学、眼科等医学专业中得到广泛应用。

综上所述,基于单目相机的2D测量技术在工业制造、计算机视觉、地理测绘和导航、医学影像等领域都有着重要的背景和意义。它可以提高生产效率、产品质量,推动科学研究和医学进步,为各个领域带来更多的机遇和挑战。

1.2 yolo算法

YOLO(You Only Look Once)是一种实时目标检测算法,它的主要思想是将目标检测问题转化为一个回归问题。相较于传统的目标检测算法YOLO具有更快的处理速度和较高的准确性。

YOLO算法的基本原理如下:

将输入图像划分为一个固定大小的网格。每个网格负责预测该网格中是否包含目标以及目标的边界框。

每个网格预测多个边界框(一般为5个)以适应不同形状的目标。

每个边界框预测目标类别的概率。

对每个边界框的位置和类别进行综合预测。

使用非极大值抑制(NMS)处理重叠的边界框,以获取最终的目标检测结果。

YOLO算法相较于其他目标检测算法的优势在于其端到端的设计,能够实现实时目标检测,并且减少了检测过程中的多次重复计算。然而,由于YOLO将图像划分为网格,对于小尺寸目标和密集目标的检测效果可能会稍差。

此外,YOLO还有不同版本的改进,如YOLOv2、YOLOv3和YOLOv4等,这些改进版本在准确性和速度方面有所提升,同时也引入了一些新的技术和网络结构,如多尺度预测、锚框、Darknet-19等。

 2.功能实现 

今天在上一章的项目测量上加入了新的功能。具体直接看视频

甲方给的场地视频,因为没有参照物,所以无法测量尺寸。

基于YOLO算法的单目相机2D测量(工件尺寸和物体尺寸)二_哔哩哔哩_bilibili

 代码暂不开源,贴上来大家讨论讨论。顺便记录一下项目。

主函数

import utlis
from ours import *

import cv2
import time



onnx_path = 'yolov5s.onnx'
model = Yolov5ONNX(onnx_path)

cap = cv2.VideoCapture('./3.mp4')
pTime = 0
while True:
    success, img = cap.read()

    # top_coords = (0, int(img.shape[0] / 2))
    # bottom_coords = (img.shape[1], int(img.shape[0] / 2))
    bottom_coordsleft = (800, int(img.shape[0] / 2)+100)
    top_coordsleft = (800, int(img.shape[0] / 2)-500)
    bottom_coordsright = (img.shape[1]-600, int(img.shape[0] / 2)+100)
    top_coordsright = (img.shape[1]-600, int(img.shape[0] / 2)-500)


    img1 = img.copy()
    # 画出线
    # cv2.line(img1, top_coords, bottom_coords, (0, 255, 0), thickness=2)
    cv2.rectangle(img1, (800, int(img.shape[0] / 2)+100), (img.shape[1]-700, int(img.shape[0] / 2)-500), (0, 255, 0), 3)
    # cv2.line(img1, top_coordsleft, top_coordsright, (255, 0, 0), thickness=3)  # 蓝色

    or_img, box_coords = model.detect(img)


    img2 = utlis.judgeshow_zong(img1, box_coords, top_coordsleft, bottom_coordsright)

    cTime = time.time()
    fps = 1 / (cTime - pTime)
    pTime = cTime
    cv2.putText(img2, str(int(fps)), (10, 70), cv2.FONT_HERSHEY_PLAIN, 3, (255, 0, 255), 3)

    # 在窗口中显示目标检测结果
    cv2.imshow('result', img2)
    # 等待用户按键,如果按下 'q' 键或者 Esc 键,则退出循环
    c = cv2.waitKey(1) & 0xFF
    if c == 27 or c == ord('q'):
        break

# 释放视频对象并关闭窗口
cap.release()
cv2.destroyAllWindows()


http://www.niftyadmin.cn/n/5083664.html

相关文章

TSINGSEE青犀智慧城市数字基座解决方案,助力城市数字化转型

一、行业背景 我国“十四五”规划纲要中提出,分级分类推进新型智慧城市建设,将物联网感知设施、通信系统等纳入公共基础设施统一规划建设,推进市政公用设施、建筑等物联网应用和智能化改造。完善城市信息模型平台和运行管理服务平台&#xf…

CCF CSP认证历年题目自练Day28

题目一 试题编号: 202109-1 试题名称: 数组推导 时间限制: 1.0s 内存限制: 512.0MB 样例1输入 6 0 0 5 5 10 10 样例1输出 30 15 样例2输入 7 10 20 30 40 50 60 75 样例2输出 285 285 题目分析(个人理解&#…

用 Python 算法识别股价支撑位和阻力位

一、简介 支撑位和阻力位是交易领域的基本概念,是做出明智决策的关键路标。这些水平有助于交易者预测未来的突破或崩溃情景。交易者通常通过手动观察和图表来识别这些水平,但是,利用现代算法技术,交易者现在可以以更高的精度和速度识别这些关键水平。本文的目的是向您介绍 …

【vue3】watch监听器

主要结构 import {ref, reactive,watch} from vue watch([监听值1,监听2,...],(newVal,oldVal)>{... },{deep:true, //ref需要手动开启,reactive则不用主动开启 源码中是默认开启的immediate:true, //默认一进来就开启执行一次flush:pre //pre-组件更新之前调用…

小程序+阿里Oss上传临时文件

以 Taro 框架为例(微信小程序可以直接将 Taro 替换为 wx)。 首先获取图片 Taro.chooseImage({count: 1,sizeType: [original, compressed],success: (result) > {// 上传图片文件的具体代码useTaroUploadFile(result.tempFilePaths[0]).then(res>…

asp.net售后维修管理系统VS开发sqlserver数据库web结构c#编程Microsoft Visual Studio

一、源码特点 asp.net 售后维修管理系统 是一套完善的web设计管理系统,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为vs2010,数据库为sqlserver2008,使用c#语 言开发 asp.net售后维修管理系统1 二、…

ChatGLM:向量化构建本地知识库原理

一、概念 1.向量:是有大小和方向的量,可以使用带箭头的线段表示,箭头指向即为向量的方向,线段的长度表示向量的大小。 2.向量化:将语言模型的数据转化为向量。这通常通过嵌入模型(embedding models&#…

机器人制作开源方案 | 双轮提升搬运小车

1. 功能描述 双轮提升搬运小车是一种用于搬运和移动物体的机械设备,它通常采用双轮驱动和提升装置。一般具备以下特点: ① 双轮驱动:该小车配备两个驱动轮,通过电动机或其它动力源驱动,提供足够的动力和扭矩&#xff0…