Ultralytics 简介

Ultralytics 简介#

Ultralytics YOLO11 提供 YOLO 系列的模型,并引入了新功能和改进以进一步提升性能和灵活性。YOLO11 被设计得快速、准确且易于使用,是进行广泛对象检测和跟踪、实例分割、图像分类和姿态估计任务的理想选择。

安装:

pip install ultralytics

或者

conda install -c conda-forge ultralytics

亦或者克隆源码:

git clone git@github.com:xinetzone/ultralytics.git
pip install -e .[dev]
from ultralytics import YOLO

YOLO CLI#

YOLO 可以直接在命令行接口(CLI)中使用 yolo 命令:

yolo predict model=yolo11n.pt source='https://ultralytics.com/images/bus.jpg'

yolo 可以用于各种任务和模式,并接受额外参数,例如 imgsz=640。请参阅 YOLO CLI 文档 以获取示例。

Python API#

YOLO 也可以直接在 Python 环境中使用,并接受与上述 CLI 示例中相同的参数

from ultralytics import YOLO

# 加载模型
model = YOLO("yolo11n.pt")
Downloading https://github.com/ultralytics/assets/releases/download/v8.3.0/yolo11n.pt to 'yolo11n.pt'...
100%|██████████| 5.35M/5.35M [00:00<00:00, 10.2MB/s]

训练模式用于在自定义数据集上训练 YOLOv11 模型。在此模式下,模型使用指定的数据集和超参数进行训练。训练过程涉及优化模型的参数,以便它能准确预测图像中对象的类别和位置。

# model = YOLO("yolo11n.pt")
# results = model.train(epochs=5)
train_results = model.train(
    data="coco8.yaml",  # 数据集 YAML 路径
    epochs=100,  # 训练轮次
    imgsz=640,  # 训练图像尺寸
    device="cpu",  # 运行设备,例如 device=0 或 device=0,1,2,3 或 device=cpu
)

Val 模式用于在训练完成后验证 YOLOv11 模型。在此模式下,模型会在验证集上进行评估,以衡量其准确性和泛化性能。此模式可以用于调整模型的超参数,以提高其性能。

metrics = model.val()

预测模式用于使用经过训练的 YOLO 模型对新的图像或视频进行预测。在此模式下,模型从检查点文件加载,用户可提供图像或视频以进行推断。模型将预测输入图像或视频中物体的类别和位置。

import cv2
from PIL import Image

from ultralytics import YOLO

model = YOLO("model.pt")
# accepts all formats - image/dir/Path/URL/video/PIL/ndarray. 0 for webcam
results = model.predict(source="0")
results = model.predict(source="folder", show=True)  # Display preds. Accepts all YOLO predict arguments

# from PIL
im1 = Image.open("bus.jpg")
results = model.predict(source=im1, save=True)  # save plotted images

# from ndarray
im2 = cv2.imread("bus.jpg")
results = model.predict(source=im2, save=True, save_txt=True)  # save predictions as labels

# from list of PIL/ndarray
results = model.predict(source=[im1, im2])
from PIL import Image
# "https://ultralytics.com/images/bus.jpg"
results = model("images/bus.jpg")
# results[0].show()
res_plotted = results[0].plot(pil=True)
Image.fromarray(res_plotted[:, :, ::-1])
image 1/1 /media/pc/data/lxw/ai/torch-book/doc/ecosystem/ultralytics/images/bus.jpg: 640x480 4 persons, 1 bus, 368.9ms
Speed: 96.7ms preprocess, 368.9ms inference, 1264.4ms postprocess per image at shape (1, 3, 640, 480)
../../_images/4cc5cdf76bf2adda58b52d11f019064d180ad81e108daa1eeb483998c733297d.png

将模型导出为 ONNX 格式:

path = model.export(format="onnx")  # 返回导出模型的路径
Hide code cell output
Ultralytics 8.3.58 🚀 Python-3.12.2 torch-2.5.1 CPU (Intel Xeon E5-2678 v3 2.50GHz)

PyTorch: starting from 'yolo11n.pt' with input shape (1, 3, 640, 640) BCHW and output shape(s) (1, 84, 8400) (5.4 MB)
requirements: Ultralytics requirement ['onnxslim'] not found, attempting AutoUpdate...
DEPRECATION: Loading egg at /media/pc/data/lxw/envs/anaconda3a/envs/ai/lib/python3.12/site-packages/mmcv-2.2.0-py3.12-linux-x86_64.egg is deprecated. pip 24.3 will enforce this behaviour change. A possible replacement is to use pip for package installation. Discussion can be found at https://github.com/pypa/pip/issues/12330

Collecting onnxslim
  Downloading onnxslim-0.1.46-py3-none-any.whl.metadata (4.4 kB)
Requirement already satisfied: onnx in /media/pc/data/lxw/envs/anaconda3a/envs/ai/lib/python3.12/site-packages (from onnxslim) (1.17.0)
Requirement already satisfied: sympy in /media/pc/data/lxw/envs/anaconda3a/envs/ai/lib/python3.12/site-packages (from onnxslim) (1.13.1)
Requirement already satisfied: packaging in /media/pc/data/lxw/envs/anaconda3a/envs/ai/lib/python3.12/site-packages (from onnxslim) (24.1)
Requirement already satisfied: numpy>=1.20 in /media/pc/data/lxw/envs/anaconda3a/envs/ai/lib/python3.12/site-packages (from onnx->onnxslim) (1.26.4)
Requirement already satisfied: protobuf>=3.20.2 in /media/pc/data/lxw/envs/anaconda3a/envs/ai/lib/python3.12/site-packages (from onnx->onnxslim) (4.25.5)
Requirement already satisfied: mpmath<1.4,>=1.1.0 in /media/pc/data/lxw/envs/anaconda3a/envs/ai/lib/python3.12/site-packages (from sympy->onnxslim) (1.3.0)
Downloading onnxslim-0.1.46-py3-none-any.whl (142 kB)
Installing collected packages: onnxslim
Successfully installed onnxslim-0.1.46

requirements: AutoUpdate success ✅ 3.7s, installed 1 package: ['onnxslim']
requirements: ⚠️ Restart runtime or rerun command for updates to take effect


ONNX: starting export with onnx 1.17.0 opset 19...
ONNX: slimming with onnxslim 0.1.46...
ONNX: export success ✅ 7.2s, saved as 'yolo11n.onnx' (10.2 MB)

Export complete (8.8s)
Results saved to /media/pc/data/lxw/ai/torch-book/doc/ecosystem/ultralytics
Predict:         yolo predict task=detect model=yolo11n.onnx imgsz=640  
Validate:        yolo val task=detect model=yolo11n.onnx imgsz=640 data=/usr/src/ultralytics/ultralytics/cfg/datasets/coco.yaml  
Visualize:       https://netron.app

追踪模式利用 YOLO 模型实时跟踪目标。在此模式下,模型会从检查点文件中载入,用户可以提供实时视频流以执行实时对象追踪。该模式对于监控系统或自动驾驶汽车等应用非常有用。

from ultralytics import YOLO

# Load a model
model = YOLO("yolo11n.pt")  # load an official detection model
model = YOLO("yolo11n-seg.pt")  # load an official segmentation model
model = YOLO("path/to/best.pt")  # load a custom model

# Track with the model
results = model.track(source="https://youtu.be/LNwODJXcvt4", show=True)
results = model.track(source="https://youtu.be/LNwODJXcvt4", show=True, tracker="bytetrack.yaml")

基准模式用于评估 YOLOv不同导出格式的速度和准确性。这些基准提供了有关导出格式大小、其 mAP50-95指标(针对目标检测和分割)或top5准确率指标(针对分类),以及各种导出格式(如ONNX、OpenVINO、TensorRT等)的每张图像推理时间(毫秒)。这些信息可以帮助用户根据他们对速度和准确性的需求,为其特定用例选择最佳的导出格式。

from ultralytics.utils.benchmarks import benchmark

# Benchmark
benchmark(model="yolo11n.pt", data="coco8.yaml", imgsz=640, half=False, device=0)

ultralytics.YOLO 模型类是在 Trainer 类上的高级封装。每个 YOLO 任务都有自己独特的训练器,这些训练器继承自 ultralytics.engine.predictor.BaseTrainer 类。

from ultralytics.models.yolo import DetectionPredictor, DetectionTrainer, DetectionValidator

# trainer
trainer = DetectionTrainer(overrides={})
trainer.train()
trained_model = trainer.best

# Validator
val = DetectionValidator(args=...)
val(model=trained_model)

# predictor
pred = DetectionPredictor(overrides={})
pred(source=SOURCE, model=trained_model)

# resume from last weight
overrides["resume"] = trainer.last
trainer = detect.DetectionTrainer(overrides=overrides)

您可以轻松定制训练器以支持自定义任务或探索研发想法。

请参阅 YOLO Python 文档 以获取更多示例。

Ultralytics 设置#

Ultralytics 库提供了功能强大的设置管理系统,允许用户对实验进行精细控制。通过使用 ultralytics.utils 模块中的 SettingsManager,用户可以方便地访问和修改他们的设置。这些设置被保存在环境用户配置目录中的 JSON 文件中,可以在 Python 环境中直接查看或修改,也可以通过命令行界面(CLI)进行操作。

可以使用 Python 查看您的设置:

from ultralytics import settings

# View all settings
print(settings)

# 返回指定的设置
value = settings["runs_dir"]
Hide code cell output
JSONDict("/home/ai/.config/Ultralytics/settings.json"):
{
  "settings_version": "0.0.6",
  "datasets_dir": "/media/pc/data/lxw/datasets",
  "weights_dir": ".temp/weights",
  "runs_dir": "runs",
  "uuid": "9fd63931e6590b010c81dc35b92434fe1e31233c0b297639b2b06da201ab4a9a",
  "sync": true,
  "api_key": "",
  "openai_api_key": "",
  "clearml": true,
  "comet": true,
  "dvc": true,
  "hub": true,
  "mlflow": true,
  "neptune": true,
  "raytune": true,
  "tensorboard": true,
  "wandb": true,
  "vscode_msg": true
}

调用 update() 来更改设置:

from ultralytics import settings

# 修改单个设置
settings.update({"runs_dir": "/path/to/runs"})

# 修改多个设置
settings.update({"runs_dir": "/path/to/runs", "tensorboard": False})

# 恢复默认设置
settings.reset()

下表概述了 Ultralytics 中可供调整的设置。每项设置都附有示例值、数据类型和简要说明。

名称

示例值

数据类型

说明

settings_version

'0.0.4'

str

Ultralytics settings 版本(与 Ultralytics pip 版本不同)

datasets_dir

'/path/to/datasets'

str

存储数据集的目录

weights_dir

'/path/to/weights'

str

存储权重的目录

runs_dir

'/path/to/runs'

str

存储实验运行的目录

uuid

'a1b2c3d4'

str

当前 settings 的唯一标识符

sync

True

bool

是否将分析和崩溃同步到 HUB

api_key

''

str

Ultralytics HUB API Key

clearml

True

bool

是否使用 ClearML 日志

comet

True

bool

是否使用 Comet ML 进行实验跟踪和可视化

dvc

True

bool

是否使用 DVC 进行实验跟踪 和版本控制

hub

True

bool

是否使用 Ultralytics HUB 集成

mlflow

True

bool

是否使用 MLFlow 进行实验跟踪

neptune

True

bool

是否使用 Neptune 进行实验跟踪

raytune

True

bool

是否使用 Ray Tune 进行 参数调优

tensorboard

True

bool

是否使用 TensorBoard 可视化

wandb

True

bool

是否使用 Weights & Biases 记录日志

vscode_msg

True

bool

当 VS Code 终端检测到时,会提示下载 Ultralytics-Snippets 扩展