用训练好的模型在Yolov8上进行推理演示python代码,含图像检测,视频推理,实时摄像头检测。

一,图像检测

用已经训练好的模型进行图像推理检测,运行时注意修改图像和模型路径。

# 引入opencv
import cv2

# 引入YOLO模型
from ultralytics import YOLO

# 打开图像
img_path = "./img.jpg"  # 这里修改你图像保存路径

# 打开图像
img = cv2.imread(filename=img_path)

# 加载模型
model = YOLO(model="yolov8n.pt") # 这里修改你图像保存路径

# 正向推理
res = model(img)

# 绘制推理结果
annotated_img = res[0].plot()

# 显示图像
cv2.imshow(winname="YOLOV8", mat=annotated_img)

# 等待时间
cv2.waitKey(delay=10000)

# 绘制推理结果
cv2.imwrite(filename="jieguo.jpeg", img=annotated_img) 

二, 视频检测

用已经训练好的模型进行视频推理检测,运行时注意修改图像和模型路径。

import cv2

from ultralytics import YOLO

# 加载模型
model = YOLO(model="yolov8x.pt")

# 视频文件
video_path = "nanwangjinxiao.mp4"

# 打开视频
cap = cv2.VideoCapture(video_path)

while cap.isOpened():
    # 获取图像
    res, frame = cap.read()
    # 如果读取成功
    if res:
        # 正向推理
        results = model(frame)

        # 绘制结果
        annotated_frame = results[0].plot()

        # 显示图像
        cv2.imshow(winname="YOLOV8", mat=annotated_frame)

        # 按ESC退出
        if cv2.waitKey(1) == 27:
            break

    else:
        break

# 释放链接
cap.release()
# 销毁所有窗口
cv2.destroyAllWindows() 

三,实时摄像头检测

这里默认打开的是你电脑本地摄像头(编号0)

import cv2

from ultralytics import YOLO

# 加载模型
model = YOLO(model="yolov8n.pt")

# 摄像头编号
camera_no = 0

# 打开摄像头
cap = cv2.VideoCapture(camera_no)

while cap.isOpened():
    # 获取图像
    res, frame = cap.read()
    # 如果读取成功
    if res:
        # 正向推理
        results = model(frame)

        # 绘制结果
        annotated_frame = results[0].plot()

        # 显示图像
        CV2.imshow(winname="YOLOV8", mat=annotated_frame)

        # 按ESC退出
        if CV2.waitKey(1) == 27:
            break

    else:
        break

# 释放链接
cap.release()
# 销毁所有窗口
cv2.destroyAllWindows() 

你可能感兴趣的:(YOLO,python,计算机视觉)