当前位置: 首页 > news >正文

调用yolov3模型进行目标检测

要调用已经训练好的YOLOv3模型对图片进行检测,需要完成以下几个步骤:

  1. 加载预训练模型:从预训练的权重文件中加载模型。
  2. 准备输入图片:将图片转换为模型所需的格式。
  3. 进行推理:使用模型对图片进行推理,得到检测结果。
  4. 处理输出结果:解析模型的输出,得到检测框、类别和置信度。

以下是一个使用PyTorch和OpenCV的示例代码,展示如何调用已经训练好的YOLOv3模型对图片进行检测:

1. 安装必要的库

确保已经安装了以下库:

pip install torch torchvision opencv-python

2. 加载预训练模型

假设已经有一个预训练的YOLOv3模型权重文件 yolov3.weights 和对应的配置文件 yolov3.cfg

import torch
import cv2
import numpy as np# 加载预训练模型
model = cv2.dnn.readNetFromDarknet("yolov3.cfg", "yolov3.weights")
model.setPreferableBackend(cv2.dnn.DNN_BACKEND_OPENCV)
model.setPreferableTarget(cv2.dnn.DNN_TARGET_CPU)

3. 准备输入图片

读取图片并将其转换为模型所需的格式。

# 读取图片
image = cv2.imread("test.jpg")
blob = cv2.dnn.blobFromImage(image, 1/255.0, (416, 416), swapRB=True, crop=False)
model.setInput(blob)

4. 进行推理

使用模型对图片进行推理,得到检测结果。

# 获取输出层的名称
layer_names = model.getLayerNames()
output_layers = [layer_names[i[0] - 1] for i in model.getUnconnectedOutLayers()]# 进行推理
outputs = model.forward(output_layers)

5. 处理输出结果

解析模型的输出,得到检测框、类别和置信度,并绘制检测结果。

class_ids = []
confidences = []
boxes = []
conf_threshold = 0.5
nms_threshold = 0.4# 解析输出
for output in outputs:for detection in output:scores = detection[5:]class_id = np.argmax(scores)confidence = scores[class_id]if confidence > conf_threshold:center_x = int(detection[0] * image.shape[1])center_y = int(detection[1] * image.shape[0])width = int(detection[2] * image.shape[1])height = int(detection[3] * image.shape[0])left = int(center_x - width / 2)top = int(center_y - height / 2)class_ids.append(class_id)confidences.append(float(confidence))boxes.append([left, top, width, height])# 非极大值抑制
indices = cv2.dnn.NMSBoxes(boxes, confidences, conf_threshold, nms_threshold)# 绘制检测结果
for i in indices:i = i[0]box = boxes[i]left = box[0]top = box[1]width = box[2]height = box[3]cv2.rectangle(image, (left, top), (left + width, top + height), (0, 255, 0), 2)label = f"{class_ids[i]} {confidences[i]:.2f}"cv2.putText(image, label, (left, top - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2)# 显示结果图片
cv2.imshow("Detection", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

http://www.lryc.cn/news/424478.html

相关文章:

  • linux文件——重定向原理——dup、重定向与execl、VFS
  • 【STM32 FreeRTOS】任务
  • Java面试--框架--Spring MVC
  • 土壤水分监测系统的工作原理
  • k8s学习--如何控制pod调度的位置
  • 基于mysqldump的MySQL数据库异地备份方案(含完整脚本和解释)
  • C语言中10个字符串函数详解
  • flume系列之:查询多个flume agent组是否有topic重复接入情况
  • Windows自动化1️⃣环境搭建WinAppDriver
  • 云服务器Docker内部署服务后,端口无法访问?
  • Unity将摄像机视角保存成Json文件方便读取使用
  • git是什么/基本指令
  • Linux 中的同步机制
  • Day17 枚举、typedef、位运算、堆空间的学习
  • Python爬虫与数据分析:中国大学排名的深度挖掘
  • 微软开源库 Detours 详细介绍与使用实例分享
  • js中的getElementById的使用方法
  • 设计模式 - 桥接模式
  • LeetCode530 二叉搜索树的最小绝对差
  • 【STM32 FreeRTOS】信号量与互斥锁
  • SP:eric 靶场复现【附代码】(权限提升)
  • SpringBoot项目启动直接结束--已解决
  • 【笔记】从零开始做一个精灵龙女-画贴图阶段(下)
  • React 学习——react项目中加入echarts图
  • 链表算法题一
  • Unity(2022.3.38LTS) - 基础概念
  • 无人机之飞手必看篇
  • 数据结构(11)——二叉搜索树
  • 如何使用和配置 AWS CLI 环境变量?
  • 七、流程控制