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)
将模型导出为 ONNX 格式:
path = model.export(format="onnx") # 返回导出模型的路径
Show 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"]
Show 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 中可供调整的设置。每项设置都附有示例值、数据类型和简要说明。
名称 |
示例值 |
数据类型 |
说明 |
---|---|---|---|
|
|
|
Ultralytics |
|
|
|
存储数据集的目录 |
|
|
|
存储权重的目录 |
|
|
|
存储实验运行的目录 |
|
|
|
当前 |
|
|
|
是否将分析和崩溃同步到 HUB |
|
|
|
Ultralytics HUB API Key |
|
|
|
是否使用 ClearML 日志 |
|
|
|
是否使用 Comet ML 进行实验跟踪和可视化 |
|
|
|
是否使用 DVC 进行实验跟踪 和版本控制 |
|
|
|
是否使用 Ultralytics HUB 集成 |
|
|
|
是否使用 MLFlow 进行实验跟踪 |
|
|
|
是否使用 Neptune 进行实验跟踪 |
|
|
|
|
|
|
|
是否使用 TensorBoard 可视化 |
|
|
|
是否使用 Weights & Biases 记录日志 |
|
|
|
当 VS Code 终端检测到时,会提示下载 Ultralytics-Snippets 扩展 |