当前位置:   article > 正文

yolov8实战第一天——yolov8部署并训练自己的数据集(保姆式教程)_error loading "d:\anaconda\envs\yolov8\lib\site-pa

error loading "d:\anaconda\envs\yolov8\lib\site-packages\torch\lib\cublas64_

​​​​​​yolov8实战第二天——yolov8训练结果分析(保姆式解读)-CSDN博客

YOLOv8是一种基于深度神经网络的目标检测算法,它是YOLO(You Only Look Once)系列目标检测算法的最新版本。YOLOv8的主要改进包括:

  1. 更高的检测精度:通过引入更深的卷积神经网络和更多的特征层,YOLOv8可以在保持实时性的同时提高检测精度。

  2. 更快的检测速度:通过对模型进行优化,YOLOv8可以在不降低检测精度的情况下提高检测速度。

  3. 支持更多的检测任务:除了传统的物体检测任务之外,YOLOv8还支持人脸检测、车辆检测等更多的检测任务。

  4. 更易于训练和部署:YOLOv8采用了更加简单的网络结构和训练策略,使得它更易于训练和部署。

YOLOv8是一个非常强大的目标检测算法,它在准确性、速度和易用性方面都具有很大的优势,因此在工业界和学术界都受到了广泛的关注和应用。

一、yolov8部署

说明:请严格安装部署步骤。

第一步、显卡驱动查看 nvidia-smi 


第二步、yolo8代码下载

https://github.com/ultralytics/ultralytics 


第三步、cuda及cudnn安装

  1. https://developer.nvidia.com/cuda-toolkit-archive 
  2. https://developer.nvidia.com/rdp/cudnn-archive 


第四步、安装anaconda

https://www.anaconda.com/download

环境变量设置(安装在哪里就找那个路径):


第五步、创建python环境

conda create -n yolo python==3.11 

conda环境操作指南:

  1. 查看现有环境 conda env list  
  2. 激活失败 conda init cmd.exe
  3. 删除环境 conda env remove -n yolo 


第六步、激活环境

一定要选择命令提示符。

activate yolo

以后每次使用都要激活该环境。


第七步、安装pytorch

https://pytorch.org/

我是cuda12.0,所以安装cuda11.8版本。 

  1. conda install pytorch torchvision torchaudio pytorch-cuda=11.8 -c pytorch -c nvidia
  2. 或:
  3. pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118


第八步、安装库

pip install ultralytics -i https://pypi.tuna.tsinghua.edu.cn/simple


第九步、推理检测

yolo predict model=yolov8n.pt source=bus.jpg

图片名自己设置,自动下载模型yolov8n.pt,结果在runs文件夹中。

第十步、训练

yolo train data=coco128.yaml model=yolov8n.pt epochs=10 lr0=0.01

自动训练下载数据集datasets,报错:

  1. OSError: [WinError 1455] 页面文件太小,无法完成操作。 Error loading "E:\Anaconda3\envs\yolov8\lib\site-packages\torch\lib\nvfuser_codegen.dll" or one of its dependencies.
  2. Traceback (most recent call last):
  3. File "<string>", line 1, in <module>
  4. File "E:\Anaconda3\envs\yolov8\lib\multiprocessing\spawn.py", line 116, in spawn_main
  5. exitcode = _main(fd, parent_sentinel)
  6. File "E:\Anaconda3\envs\yolov8\lib\multiprocessing\spawn.py", line 126, in _main
  7. self = reduction.pickle.load(from_parent)
  8. File "E:\Anaconda3\envs\yolov8\lib\site-packages\torch\__init__.py", line 128, in <module>
  9. raise err
  10. OSError: [WinError 1455] 页面文件太小,无法完成操作。 Error loading "E:\Anaconda3\envs\yolov8\lib\site-packages\torch\lib\nvfuser_codegen.dll" or one of its dependencies.

设置安装anaconda所在盘的虚拟内存。

二、yolov8训练自己的数据集

第一步、数据准备

在yolov8中建立datasets文件夹,然后建立数据集文件夹mydata。

mydata中是imges图片文件和label标注后的Annotations xml文件夹和imageSets。 

其中使用makeTxt.py,给数据分类trian val test。

  1. import os
  2. import random
  3. trainval_percent = 0.1
  4. train_percent = 0.9
  5. xmlfilepath = './Annotations'
  6. txtsavepath = './ImageSets'
  7. total_xml = os.listdir(xmlfilepath)
  8. num = len(total_xml)
  9. list = range(num)
  10. tv = int(num * trainval_percent)
  11. tr = int(tv * train_percent)
  12. trainval = random.sample(list, tv)
  13. train = random.sample(trainval, tr)
  14. ftrainval = open('./ImageSets/trainval.txt', 'w')
  15. ftest = open('./ImageSets/test.txt', 'w')
  16. ftrain = open('./ImageSets/train.txt', 'w')
  17. fval = open('./ImageSets/val.txt', 'w')
  18. for i in list:
  19. name = total_xml[i][:-4] + '\n'
  20. if i in trainval:
  21. ftrainval.write(name)
  22. if i in train:
  23. ftest.write(name)
  24. else:
  25. fval.write(name)
  26. else:
  27. ftrain.write(name)
  28. ftrainval.close()
  29. ftrain.close()
  30. fval.close()
  31. ftest.close()

运行后ImageSets文件夹生成四个txt。 

再使用voc_label.py,将数据转换成label格式。修改自己的类,逗号隔开,我训练的就一个“老鼠”类。

  1. import xml.etree.ElementTree as ET
  2. import pickle
  3. import os
  4. from os import listdir, getcwd
  5. from os.path import join
  6. sets=[('train'), ('test'),('val')]
  7. classes = ["mouse"]
  8. def convert(size, box):
  9. dw = 1./(size[0])
  10. dh = 1./(size[1])
  11. x = (box[0] + box[1])/2.0 - 1
  12. y = (box[2] + box[3])/2.0 - 1
  13. w = box[1] - box[0]
  14. h = box[3] - box[2]
  15. x = x*dw
  16. w = w*dw
  17. y = y*dh
  18. h = h*dh
  19. return (x,y,w,h)
  20. def convert_annotation(image_id):
  21. in_file = open('Annotations/%s.xml'%(image_id))
  22. out_file = open('labels/%s.txt'%( image_id), 'w')
  23. tree=ET.parse(in_file)
  24. root = tree.getroot()
  25. size = root.find('size')
  26. w = int(size.find('width').text)
  27. h = int(size.find('height').text)
  28. for obj in root.iter('object'):
  29. # difficult = obj.find('difficult').text
  30. cls = obj.find('name').text
  31. # if cls not in classes or int(difficult)==1:
  32. if cls not in classes:
  33. continue
  34. cls_id = classes.index(cls)
  35. xmlbox = obj.find('bndbox')
  36. b = (float(xmlbox.find('xmin').text), float(xmlbox.find('xmax').text), float(xmlbox.find('ymin').text), float(xmlbox.find('ymax').text))
  37. bb = convert((w,h), b)
  38. out_file.write(str(cls_id) + " " + " ".join([str(a) for a in bb]) + '\n')
  39. wd = getcwd()
  40. for image_set in sets:
  41. if not os.path.exists('labels/'):
  42. os.makedirs('labels/')
  43. image_ids = open('ImageSets/%s.txt'%(image_set)).read().strip().split()
  44. list_file = open('%s.txt'%(image_set), 'w')
  45. for image_id in image_ids:
  46. list_file.write('%s/images/%s.jpg\n'%(wd,image_id))
  47. convert_annotation(image_id)
  48. list_file.close()
  49. #os.system("cat 2008_train.txt > train.txt")
  50. #os.system("cat 2008_train.txt 2008_val.txt > train.txt")
  51. #os.system("cat 2008_train.txt 2008_val.txt 2008_test.txt> train.txt")
  52. #os.system("cat 2014_train.txt 2014_val.txt 2012_train.txt 2012_val.txt > train.txt")
  53. #os.system("cat 2007_train.txt 2007_val.txt 2007_test.txt 2012_train.txt 2012_val.txt > train.all.txt")

运行后生成labels文件夹和三个txt。

至此数据准备工作完成,开始训练。 

第二步、训练

建立一个yaml文件

shu.yaml

  1. train: E:/ultralytics-main/datasets/mydata/train.txt
  2. val: E:/ultralytics-main/datasets/mydata/val.txt
  3. # Classes
  4. names:
  5. 0: mouse

训练指令:

yolo train data=shu.yaml model=yolov8n.pt epochs=100 lr0=0.01 

至此训练完成。 在runs中生成训练结果和训练模型。

训练结果分析:yolov8实战第二天——yolov8训练结果分析(保姆式解读)-CSDN博客

第三步、测试 

使用训练后的模型进行测试。

测试指令:

yolo predict model=runs/detect/train12/weights/best.pt source=datasets/mydata/images/mouse-4-6-0004.jpg

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/article/detail/44767
推荐阅读
相关标签
  

闽ICP备14008679号