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

yolov8模型推理测试代码(pt/onnx)

🦖yolov8训练出来的模型,不使用detect.py代码进行模型测试🦖

pt格式模型测试

import cv2
import os
from ultralytics import YOLO
# 定义输入和输出文件夹路径
input_folder = '/input/folder'  # 输入文件夹
output_folder = '/output/folder'  # 输出文件夹
# 确认输出文件夹存在
if not os.path.exists(output_folder):os.makedirs(output_folder)
# 加载YOLO模型
model = YOLO('yolov8.pt')
# 遍历输入文件夹中的所有文件
for filename in os.listdir(input_folder):# 仅处理图片文件,确保扩展名为 .jpg, .png 等if filename.endswith(('.jpg', '.png','.bmp')):# 加载图像image_path = os.path.join(input_folder, filename)image = cv2.imread(image_path)if image is None:print(f"图像加载失败: {image_path}")continue# 进行预测results = model(image,device='1')# 获取结果中的标注信息annotated_frame = results[0].plot()  # 将检测结果绘制在图像上# 保存结果图像到输出文件夹save_path = os.path.join(output_folder, f'result_{filename}')save_status = cv2.imwrite(save_path, annotated_frame)if save_status:print(f"检测结果保存到: {save_path}")else:print(f"保存图像失败: {save_path}")

onnx模型测试结果

import cv2
import os
import onnxruntime as ort
import numpy as np
# 定义输入和输出文件夹路径
input_folder = '/input/folder'  # 输入文件夹
output_folder = '/output/folder'  # 输出文件夹
# 确认输出文件夹存在
if not os.path.exists(output_folder):os.makedirs(output_folder)
# 加载 ONNX 模型
onnx_model_path = 'yolov8.onnx'
session = ort.InferenceSession(onnx_model_path, providers=['CUDAExecutionProvider'])
# 设置模型输入的尺寸
input_width, input_height = 640, 640  # 根据模型的输入尺寸
# 遍历输入文件夹中的所有文件
for filename in os.listdir(input_folder):# 仅处理图片文件,确保扩展名为 .jpg, .png 等if filename.endswith(('.jpg', '.png', '.bmp')):# 加载图像image_path = os.path.join(input_folder, filename)image = cv2.imread(image_path)if image is None:print(f"图像加载失败: {image_path}")continue# 调整图像大小并进行预处理input_image = cv2.resize(image, (input_width, input_height))input_image = cv2.cvtColor(input_image, cv2.COLOR_BGR2RGB)blob = np.expand_dims(input_image.astype(np.float32) / 255.0, axis=0).transpose(0, 3, 1, 2)# 设置输入input_name = session.get_inputs()[0].nameoutputs = session.run(None, {input_name: blob})# 解析预测结果并绘制检测框for detection in outputs[0][0]:  # 根据模型的输出格式解析score = float(detection[4])  # 假设第5个值是置信度if score > 0.5:  # 置信度阈值,取决于具体任务x_center, y_center, width, height = detection[:4]left = int((x_center - width / 2) * image.shape[1])top = int((y_center - height / 2) * image.shape[0])right = int((x_center + width / 2) * image.shape[1])bottom = int((y_center + height / 2) * image.shape[0])# 绘制检测框cv2.rectangle(image, (left, top), (right, bottom), (0, 255, 0), 2)label = f"{score:.2f}"cv2.putText(image, label, (left, top - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2)# 保存结果图像到输出文件夹save_path = os.path.join(output_folder, f'result_{filename}')save_status = cv2.imwrite(save_path, image)if save_status:print(f"检测结果保存到: {save_path}")else:print(f"保存图像失败: {save_path}")
http://www.lryc.cn/news/477322.html

相关文章:

  • 二叉树 最大深度(递归)
  • C++详细笔记(五)
  • 简易CPU设计入门:译码模块(一)
  • 力扣题目解析--三数之和
  • qt QTabWidget详解
  • linux shell脚本学习(1):shell脚本基本概念与操作
  • Savitzky-Golay(SG)滤波器
  • Webserver(2.7)共享内存
  • 【网安案例学习】凭证填充Credential Stuffing
  • 网站建设公司怎么选?网站制作公司怎么选才不会出错?
  • 19. 架构重要需求
  • iOS 再谈KVC、 KVO
  • java、excel表格合并、指定单元格查找、合并文件夹
  • 最基础版编译运行Java(纯小白)
  • 六西格玛项目助力,手术机器人零部件国产化稳中求胜——张驰咨询
  • Python爬虫系列(一)
  • # vim那些事...... vim删除文件全部内容
  • Selinux及防火墙
  • 业绩代码查询实战——php
  • 内网穿透技术选型PPTP(点对点隧道协议)和 FRP(Fast Reverse Proxy)
  • 信号与噪声分析——第三节:随机过程的统计特征
  • nginx(四):如何在 Nginx 中配置以保留真实 IP 地址
  • docker对nginx.conf进行修改后页面无变化或页面报错
  • SpringCloudGateway — 网关路由
  • docker pull 拉取镜像失败,使用Docker离线包
  • 轻松理解操作系统 - 轻松了解 inode 是如何管理文件的
  • go中Println和Printf的区别
  • C++现代教程七之模块
  • AVLTree
  • Java面向对象 C语言字符串常量