Mac YOLO V9推理测试(基于ultralytics)

环境:

Mac M1 (MacOS Sonoma 14.3.1)

Python 3.11+PyTorch 2.1.2

一、准备工作

使用YOLO一般都会接触ultralytics这个框架,今天来试试用该框架进行YOLO V9模型的推理。

YOLOv9目前提供了四种模型下载:yolov9-c.ptyolov9-e.ptgelan-c.ptgelan-e.pt

bash 复制代码
wget -P /Users/zhujiahui/Local/model/yolov9 -q https://github.com/WongKinYiu/yolov9/releases/download/v0.1/yolov9-c.pt
wget -P /Users/zhujiahui/Local/model/yolov9 -q https://github.com/WongKinYiu/yolov9/releases/download/v0.1/yolov9-e.pt
wget -P /Users/zhujiahui/Local/model/yolov9 -q https://github.com/WongKinYiu/yolov9/releases/download/v0.1/gelan-c.pt
wget -P /Users/zhujiahui/Local/model/yolov9 -q https://github.com/WongKinYiu/yolov9/releases/download/v0.1/gelan-e.pt

将下载好的模型放到指定的位置(实际发现这一步不用做,白费了)。

下载示例图片(也可手动下载放置),放到指定位置下:

bash 复制代码
wget -P /Users/zhujiahui/Local/dataset -q https://media.roboflow.com/notebooks/examples/dog.jpeg

安装Python依赖

bash 复制代码
pip install opencv-python
pip install ultralytics

二、推理

编写以下代码:

python 复制代码
from ultralytics import YOLO


def yolov9_inference():
    yolo_model = YOLO("/Users/zhujiahui/Local/model/yolov9/yolov9-e.pt")
    yolo_model.info()


if __name__ == '__main__':
    yolov9_inference()

直接运行,发现报错:

TypeError: ERROR ❌️ /Users/zhujiahui/Local/model/yolov9/yolov9-e.pt appears to be an Ultralytics YOLOv5 model originally trained with https://github.com/ultralytics/yolov5.

This model is NOT forwards compatible with YOLOv8 at https://github.com/ultralytics/ultralytics.

Recommend fixes are to train a new model using the latest 'ultralytics' package or to run a command with an official YOLOv8 model, i.e. 'yolo predict model=yolov8n.pt'

意思是说从https://github.com/WongKinYiu/yolov9下载的模型yolov9-e.pt与本训练推理框架(ultralytics)不match,必须使用经过ultralytics训练的模型。

于是改动如下,选用ultralytics提供的YOLO V9模型:

python 复制代码
from ultralytics import YOLO


def yolov9_inference():
    yolo_model = YOLO("yolov9e.pt")
    yolo_model.info()


if __name__ == '__main__':
    yolov9_inference()

首次运行会下载模型到当前代码所在的文件夹下

对示例图片进行检测:

python 复制代码
from ultralytics import YOLO


def yolov9_inference():
    yolo_model = YOLO("yolov9e.pt")
    yolo_model.info()
    results = yolo_model.predict(source='/Users/zhujiahui/Local/dataset/dog.jpeg', save=True, save_txt=True)
    print(results)


if __name__ == '__main__':
    yolov9_inference()

结果如下:

具体检测后的结果图片在runs/detect/predict/dog.jpeg下,效果:

|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| | |
| 原图 | 检测结果 |

输入的图片也可以通过OpenCV读入:

python 复制代码
def yolov9_inference2():
    yolo_model = YOLO("yolov9e.pt")
    yolo_model.info()
    input_image = cv2.imread("/Users/zhujiahui/Local/dataset/dog.jpeg")
    results = yolo_model.predict(source=input_image, save=True, save_txt=True)
    print(results)
相关推荐
2201_754918416 小时前
YOLOv2 深度解析:目标检测领域的进阶之路
人工智能·yolo·目标检测·计算机视觉
layneyao18 小时前
计算机视觉入门:OpenCV与YOLO目标检测
opencv·yolo·计算机视觉
weixin_525911871 天前
【Opencv+Yolo】Day2_图像处理
图像处理·opencv·yolo
向哆哆1 天前
YOLOv8 实战指南:如何实现视频区域内的目标统计与计数
yolo·音视频·yolov8
kyle~1 天前
计算机视觉---YOLOv3
人工智能·yolo·计算机视觉
谢白羽1 天前
YOLOv8分割onnx实战及tensorRT部署
yolo·分割
kyle~2 天前
计算机视觉---YOLOv4
人工智能·yolo·计算机视觉
Thomas_Cai2 天前
yolov8分割任务的推理和后处理解析
人工智能·yolo·图像分割·语义分割·实例分割
mozun20202 天前
YOLOX 的动态标签分类(如 SimOTA)与 Anchor-free 机制解析2025.5.29
人工智能·算法·yolo·目标检测·计算机视觉·分类·数据挖掘
强盛小灵通专卖员2 天前
DL00924-基于深度学习YOLOv11的工程车辆目标检测含数据集
深度学习·yolo·目标检测