Ultralytics x SwanLab:可视化YOLO模型训练
Ultralytics是YOLO官方团队推出的CV训练与推理框架,不仅支持目标检测任务,还支持分割、姿态识别、分类等更多任务。
SwanLab是一个深度学习实验管理与训练可视化工具,由西安电子科技大学团队打造,融合了Weights & Biases与Tensorboard的特点,能够方便地进行 训练可视化、多实验对比、超参数记录、大型实验管理和团队协作,并支持用网页链接的方式分享你的实验。
你可以使用Ultralytics快速进行目标检测模型训练,同时使用SwanLab进行实验跟踪与可视化。可视化结果(可以在这里直接预览。)
集成SwanLab有两种方式:
- 使用
add_swanlab_callback
函数:无需修改源码,仅适用于单卡训练场景 - 使用
return_swanlab_callback
函数:需要修改源码,适用于单卡以及多卡DDP训练场景
下面将用一个yolo在coco128数据集上的训练,来介绍如何将Ultralytics与SwanLab配合起来。
1.1 引入add_swanlab_callback
python
复制代码from swanlab.integration.ultralytics import add_swanlab_callback
SwanLabCallback是适配于Transformers的日志记录类。
SwanLabCallback可以定义的参数有:
project、experiment_name、description 等与 swanlab.init 效果一致的参数, 用于SwanLab项目的初始化。 你也可以在外部通过swanlab.init
创建项目,集成会将实验记录到你在外部创建的项目中。
1.2 引入add_swanlab_callback
下面是使用yolov8n模型在coco数据集上的训练,只需将model传入add_swanlab_callback
函数,即可完成与SwanLab的集成。
python复制代码from ultralytics import YOLO
from swanlab.integration.ultralytics import add_swanlab_callback
if __name__ == "__main__":
model = YOLO("yolov8n.pt")
# 添加swanlab回调
add_swanlab_callback(model)
model.train(
data="./coco128.yaml",
epochs=3,
imgsz=320,
)
如果需要自定义SwanLab的项目、实验名等参数,则可以在add_swanlab_callback
中添加:
python复制代码add_swanlab_callback(
model,
project="YOLO_COCO128",
experiment_name="yolov8n",
description="yolov8n在coco128数据集上的训练。",
)
然后开始训练即可!
2.1 多卡训练/DDP训练
swanlab>=0.3.8
在Ultralytics多卡训练的场景下,由于启动训练的方式与单卡完全不同,所以需要用一种不同的方式接入SwanLab回调。
这是一个ultralytics开启DDP训练的样例代码:
python复制代码from ultralytics import YOLO
if __name__ == "__main__":
model = YOLO("yolov8n.pt")
model.train(
data="./coco128.yaml",
epochs=3,
imgsz=320,
# 开启DDP
device=[0,1],
)
我们需要修改ultralytics的源码,去到ultralytics/utils/callbacks/base.py
,找到add_integration_callbacks
函数,添加下面的三行代码:
python复制代码def add_integration_callbacks(instance):
...
# Load training callbacks
if "Trainer" in instance.__class__.__name__:
from .clearml import callbacks as clear_cb
from .comet import callbacks as comet_cb
from .dvc import callbacks as dvc_cb
from .mlflow import callbacks as mlflow_cb
from .neptune import callbacks as neptune_cb
from .raytune import callbacks as tune_cb
from .tensorboard import callbacks as tb_cb
from .wb import callbacks as wb_cb
from swanlab.integration.ultralytics import return_swanlab_callback
sw_cb = return_swanlab_callback()
callbacks_list.extend([..., sw_cb])
然后运行,就可以在ddp下正常跟踪实验了。
如果需要自定义SwanLab的项目、实验名等参数,则可以在return_swanlab_callback
中添加:
python复制代码return_swanlab_callback(
model,
project="ultralytics",
experiment_name="yolov8n",
description="yolov8n在coco128数据集上的训练。",
)
写入源码之后,之后运行就不需要在训练脚本中增加
add_swanlab_callback
了。
项目名也可以由model.train()
的project
参数定义,实验名由name
参数定义。
2.2 代码案例
python复制代码from ultralytics import YOLO
if __name__ == "__main__":
model = YOLO("yolov8n.pt")
model.train(
data="./coco128.yaml",
epochs=3,
imgsz=320,
# 开启DDP
device=[0,1,2,3],
# 可以通过project参数设置SwanLab的project,name参数设置SwanLab的experiment_name
project="YOLO_COCO128",
name="yolov8n"
)
3.训练演示
我们直接运行上面的代码,下面的是可视化结果(可以在这里直接预览。)
超参数和指标记录:
实验环境记录:
最后的最后
感谢你们的阅读和喜欢,我收藏了很多技术干货,可以共享给喜欢我文章的朋友们,如果你肯花时间沉下心去学习,它们一定能帮到你。
因为这个行业不同于其他行业,知识体系实在是过于庞大,知识更新也非常快。作为一个普通人,无法全部学完,所以我们在提升技术的时候,首先需要明确一个目标,然后制定好完整的计划,同时找到好的学习方法,这样才能更快的提升自己。
这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】
大模型知识脑图
为了成为更好的 AI大模型 开发者,这里为大家提供了总的路线图。它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
经典书籍阅读
阅读AI大模型经典书籍可以帮助读者提高技术水平,开拓视野,掌握核心技术,提高解决问题的能力,同时也可以借鉴他人的经验。对于想要深入学习AI大模型开发的读者来说,阅读经典书籍是非常有必要的。
实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
面试资料
我们学习AI大模型必然是想找到高薪的工作,下面这些面试题都是总结当前最新、最热、最高频的面试题,并且每道题都有详细的答案,面试前刷完这套面试题资料,小小offer,不在话下
640套AI大模型报告合集
这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。
这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】
更多推荐
所有评论(0)