pytorch下yolov8模型实现目标检测(全网最简洁快速,一眼懂)

最近研究了一个目标检测项目,需要对水稻进行检测,yolov8的模型官网都封装好了,官网地址:Home - Ultralytics YOLO Docs本文给急需目标检测的同学参考,非常急的那种,废话少说,下面是所有代码:

import os
import torch
from ultralytics import YOLO

os.environ['KMP_DUPLICATE_LIB_OK']='True'
def main():

    device = 'cuda' if torch.cuda.is_available() else 'cpu'
    print(device)

    model = YOLO('yolov8n.pt').to(device)

    model.train(data='safehat.yaml', epochs=100, device=device, workers=0,batch=2)

    model.val(device=device)

if __name__ == '__main__':
    main()

还需要一个yolov8n.pt的模型文件,这个官网可以下载我就不给了,下载后把官网文件中的yolov8n.pt拿出来和代码放到同一文件夹下面就可以了,记得安装ultralytics库,该代码搭配一个配置文件safehat.yaml(修改路径就可以使用,重要的只有那个路径):

train: C:\Users\Desktop\ricedata\train
val: C:\Users\Desktop\ricedata\valid
test: C:\Users\Desktop\ricedata\test

nc: 3
#name: [Hardhat,Mask,NO-Hardhat,NO-Mask,NO-Safety Vest,Person,Safety Cone,Safety Vest,machinery,vehicle]
classes: [rice,animal,other]

最后是数据集的路径格式,他会自动获取符合规范路径下的数据,所以记得写好路径(.cache文件运行后才有):

数据集都是我自己做的,标签名和图片名需要一致,推荐一个制作数据集的网站Newtab (makesense.ai),运行后会自动在目录下生产文件夹,包含训练完的模型和训练过程的数据:

使用模型:

训练完成后会生成runs文件夹,包含两个训练文件夹,在其中一个里面找到best.pt的模型,这就是训练最好的目标检测模型(似乎还有个训练最差的模型)

import matplotlib.pyplot as plt
from ultralytics import YOLO

#加载已经训练好的模型
model = YOLO('runs/detect/train/weights/best.pt')

#选择要测试的图像路径
image_path = 'ricedata/test/images/0292.jpg'

results = model(image_path)
print(type(results))
print(results[0].orig_img)

plt.imshow(results[0].orig_img)
plt.show()
if isinstance(results, list):
    for result in results:
        # 显示检测结果
        result.show()
else:
    # 显示检测结果
   results.show()

下一篇文章我会对模型进行onnx打包,后续部署到安卓app上面

pytorch下yolov8打包onnx模型并使用NMS对数据清洗(最后有完整代码)-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/qq_64809150/article/details/140436333?spm=1001.2014.3001.5501

  • 14
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

焚詩作薪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值