在计算机视觉的世界中,越来越多的任务需要快速高效的处理,比如人体跟踪、分割、检测等。
今天为大家推荐一个开源的计算机视觉工具箱 Supervision,使用它你可以在你电脑上实现人体跟踪、分割、检测等一系列计算机视觉的场景。
Supervision 是一个针对于计算机视觉各种任务的框架工具,可作为Python语言的三方库直接调用,提供了便捷高效的视觉处理方法,可以轻松处理数据集或直观地展现检测结果。
还提供了统计特定区域内检测跟踪、越线数量统计、切片推理、轨迹平滑等不同计算机视觉任务的方法封装。可谓是在CV领域,有了它你可以少写很多展现和计算代码。
Supervision 在 GitHub 上赢得了超过 21K 颗星,成为了计算机视觉领域不可或缺的神器。
Supervision 不限于某个特定模型,用户可以轻松插入自己需要的分类、检测或分割模型,享受极高的灵活性。
Supervision 带有完整的数据处理能力,无论是从硬盘加载数据集,还是在图像或视频上绘制检测结果,亦或是将标签转换为不同格式,这个工具箱都能助你一臂之力。
Supervision 提供了一套工具,允许你在支持的格式中加载、分割、合并和保存数据集。
为了方便使用,可以使用最流行的库(如 Ultralytics、Transformers 或 MMDetection)创建连接器。
Supervision 还提供了多种视觉任务的封装,比如:
这些封装让你可以专注于核心算法,而不用花费过多精力在视觉结果的绘制和展示上。
由于supervision是纯Python语言开发的模块,所有直接使用pip安装即可。
pip install supervision
根据项目文档,选择你需要的视觉任务 API,加载模型和数据集,开始进行检测和处理。
import cv2
import supervision as sv
from ultralytics import YOLO
model = YOLO("yolov8n.pt")
image = cv2.imread('demo.png')
results = model(image)[0]
detections = sv.Detections.from_ultralytics(results)
box_annotator = sv.BoxAnnotator()
label_annotator = sv.LabelAnnotator()
labels = [
f"{class_name} {confidence:.2f}"
for class_name, confidence
in zip(detections['class_name'], detections.confidence)
]
# 标注识别框
annotated_image = box_annotator.annotate(scene=image, detections=detections)
# 标注识别标签和置信度
annotated_image = label_annotator.annotate(scene=annotated_image, detections=detections, labels=labels)
cv2.imwrite('demo01.png',annotated_image)
import cv2
import supervision as sv
from ultralytics import YOLO
model = YOLO("yolov8n-seg.pt")
image = cv2.imread('demo.png')
results = model(image)[0]
detections = sv.Detections.from_ultralytics(results)
mask_annotator = sv.MaskAnnotator()
label_annotator = sv.LabelAnnotator(text_position=sv.Position.CENTER_OF_MASS)
annotated_image = mask_annotator.annotate(scene=image, detections=detections)
annotated_image = label_annotator.annotate(scene=annotated_image, detections=detections)
cv2.imwrite('demo01.png', annotated_image)
Supervision 是一个强大且灵活的计算机视觉工具箱,能够显著提升开发效率,并提供多样化的视觉任务处理方案。
它不仅支持常见的计算机视觉功能,如检测、分割和跟踪,还提供了丰富的数据处理和展示工具,让开发者可以轻松应对复杂的视觉任务。
如果你在寻找一个功能全面且易用的工具来实现计算机视觉任务,Supervision 无疑是值得一试的选择。
开源地址:https://github.com/roboflow/supervision