跳至主要內容

4.模型训练

言午日尧耳总大约 3 分钟AIPython视频游戏YOLO

4.模型训练

目标

  • pip安装依赖
  • (可选)安装GPU版pytorch
  • 自定义训练配置,模型训练

文档

pip安装依赖

# 安装依赖
pip install ultralytics

# 耗时有点长,可以使用国内镜像安装
pip install -i https://mirrors.aliyun.com/pypi/simple/ ultralytics 
  • 测试效果
    • 随便搜索下载一张猫或狗的图片,把路径作为source参数
  • "yolov8n.pt"是官方预训练好的模型,第一次使用会自动从Github上下载
    • 国内访问Github网络不稳定,如果失败多重试几次,或自己下载放到根目录中
yolo predict model=yolov8n.pt source='dog.jpg'

(可选)重装GPU版pytorch

  • ultralytics默认安装的是cpu版pytorch
    • 导致使用英伟达显卡并安装了CUDA和cuDNN,但训练时依然是CPU
  • 运行下面的python文件,查看打印内容就可以看出来
import torch

# 判断cuda是否生效
print(torch.cuda.is_available())

# 查看torch版本
print(torch.__version__)
# 卸载cpu版本的pytorch
pip uninstall torch torchvision torchaudio

# 重新安装gpu版本(cuda11.7)
pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu117
  • 重新运行上面的python文件,看到版本从"2.0.1+cpu"变为"2.0.1+cu117"

自定义训练配置

  • 参考ultralytics项目的coco128.yaml训练配置open in new window,编写自定义训练配置
  • 将训练集根目录设置为上一期视频,从标注平台导出的目录
  • 并将train、val路径设置为images(标注档会自动识别为"labels")
  • 示例如下:game.yml
path: E:\ai-play-game\project-1-at-2023-09-13-17-05-6275bec0  # dataset root dir
train: images  # train images (relative to 'path') 128 images
val: images  # val images (relative to 'path') 128 images

# Classes,最好使用英文,opencv支持中文比较麻烦
names:
  0: hellhound  # 地狱犬
  1: samurais   # 武士
  2: player     # 玩家
  3: fireflies  # 萤火虫

训练

  • 详细训练参数看官网ultralytics - trainopen in new window
    • data: 指定训练配置路径
    • model: 使用"yolo8n.yaml"模型(定义模型网络,"yolov8n.yaml"是内置yolov8n网络结构)
    • batch: 批大小,数值太大电脑扛不住
    • epoches: 训练轮次,游戏元素比较简单,训练一两百次就有不错的效果了
yolo detect train data=game.yml model=yolov8n.yaml batch=4 epochs=200

训练结果验证

  • 训练时,自动在根目录创建runs/detect/train目录,可以看到各种训练数据
  • 训练结束后,"runs/detect/train/weights/"目录里是模型结果
    • best.pt,是本轮训练中效果最好的模型
    • last.pt,是最后一次训练的模型
  • 使用任意游戏截图测试效果
yolo predict model=runs/detect/train/weights/best.pt  source='E:/project-e8d01b35/images/xxx.jpg'
上次编辑于:
贡献者: 许晓聪