MCPcopy
hub / github.com/roboflow/supervision

github.com/roboflow/supervision @0.29.1 sqlite

repository ↗ · DeepWiki ↗ · release 0.29.1 ↗
1,987 symbols 7,949 edges 187 files 1,271 documented · 64%
README
<a align="center" href="https://supervision.roboflow.com" target="_blank">
  <img
    width="100%"
    src="https://media.roboflow.com/open-source/supervision/rf-supervision-banner.png?updatedAt=1678995927529"
  >
</a>

notebooks | inference | autodistill | maestro

version downloads license python-version codecov

snyk colab gradio discord

<a href="https://trendshift.io/repositories/124"  target="_blank"><img src="https://trendshift.io/api/badge/repositories/124" alt="roboflow%2Fsupervision | Trendshift" style="width: 250px; height: 55px;" width="250" height="55"/></a>

📑 Table of Contents

👋 Hello

We are your essential toolkit for computer vision. From data loading to real-time zone counting, we provide the building blocks so you can focus on building applications around your models. 🤝

💻 Install

Pip install the supervision package in a Python>=3.9 environment.

pip install supervision

Read more about conda, mamba, and installing from source in our guide.

🔥 Quickstart

Models

Supervision was designed to be model agnostic. Just plug in any classification, detection, or segmentation model. For your convenience, we have created connectors for the most popular libraries like Ultralytics, Transformers, MMDetection, or Inference. Other integrations, like rfdetr, already return sv.Detections directly.

Install the optional dependencies for this example with pip install pillow rfdetr.

import supervision as sv
from PIL import Image
from rfdetr import RFDETRSmall

image = Image.open("path/to/image.jpg")
model = RFDETRSmall()
detections = model.predict(image, threshold=0.5)

len(detections)
# 5

👉 more model connectors

  • inference

    Running with Inference requires a Roboflow API KEY.

    ```python import supervision as sv from PIL import Image from inference import get_model

    image = Image.open("path/to/image.jpg") model = get_model(model_id="rfdetr-small", api_key="ROBOFLOW_API_KEY") result = model.infer(image)[0] detections = sv.Detections.from_inference(result)

    len(detections)

    5

    ```

Annotators

Supervision offers a wide range of highly customizable annotators, allowing you to compose the perfect visualization for your use case.

import cv2
import supervision as sv

image = cv2.imread("path/to/image.jpg")
# Assuming detections are obtained from a model
detections = sv.Detections(...)

box_annotator = sv.BoxAnnotator()
annotated_frame = box_annotator.annotate(scene=image.copy(), detections=detections)

https://github.com/roboflow/supervision/assets/26109316/691e219c-0565-4403-9218-ab5644f39bce

Datasets

Supervision provides a set of utils that allow you to load, split, merge, and save datasets in one of the supported formats.

import supervision as sv
from roboflow import Roboflow

project = Roboflow().workspace("WORKSPACE_ID").project("PROJECT_ID")
dataset = project.version("PROJECT_VERSION").download("coco")

ds = sv.DetectionDataset.from_coco(
    images_directory_path=f"{dataset.location}/train",
    annotations_path=f"{dataset.location}/train/_annotations.coco.json",
)

path, image, annotation = ds[0]
# loads image on demand

for path, image, annotation in ds:
    # loads image on demand
    pass

👉 more dataset utils

  • load

    ```python dataset = sv.DetectionDataset.from_yolo( images_directory_path=..., annotations_directory_path=..., data_yaml_path=..., )

    dataset = sv.DetectionDataset.from_pascal_voc( images_directory_path=..., annotations_directory_path=..., )

    dataset = sv.DetectionDataset.from_coco( images_directory_path=..., annotations_path=..., ) ```

  • split

    ```python train_dataset, test_dataset = dataset.split(split_ratio=0.7) test_dataset, valid_dataset = test_dataset.split(split_ratio=0.5)

    len(train_dataset), len(test_dataset), len(valid_dataset)

    (700, 150, 150)

    ```

  • merge

    ```python ds_1 = sv.DetectionDataset(...) len(ds_1)

    100

    ds_1.classes

    ['dog', 'person']

    ds_2 = sv.DetectionDataset(...) len(ds_2)

    200

    ds_2.classes

    ['cat']

    ds_merged = sv.DetectionDataset.merge([ds_1, ds_2]) len(ds_merged)

    300

    ds_merged.classes

    ['cat', 'dog', 'person']

    ```

  • save

    ```python dataset.as_yolo( images_directory_path=..., annotations_directory_path=..., data_yaml_path=..., )

    dataset.as_pascal_voc( images_directory_path=..., annotations_directory_path=..., )

    dataset.as_coco( images_directory_path=..., annotations_path=..., ) ```

  • convert

    python sv.DetectionDataset.from_yolo( images_directory_path=..., annotations_directory_path=..., data_yaml_path=..., ).as_pascal_voc( images_directory_path=..., annotations_directory_path=..., )

🎬 Tutorials

Want to learn how to use Supervision? Explore our how-to guides, end-to-end examples, cheatsheet, and cookbooks!

Dwell Time Analysis with Computer Vision | Real-Time Stream Processing Dwell Time Analysis with Computer Vision | Real-Time Stream Processing

Created: 5 Apr 2024

Learn how to use computer vision to analyze wait times and optimize processes. This tutorial covers object detection, tracking, and calculating time spent in designated zones. Use these techniques to improve customer experience in retail, traffic management, or other scenarios.

Speed Estimation & Vehicle Tracking | Computer Vision | Open Source Speed Estimation & Vehicle Tracking | Computer Vision | Open Source

Created: 11 Jan 2024

Learn how to track and estimate the speed of vehicles using YOLO, ByteTrack, and Roboflow Inference. This comprehensive tutorial covers object detection, multi-object tracking, filtering detections, perspective transformation, speed estimation, visualization improvements, and more.

💜 Built with Supervision

Did you build something cool using supervision? Let us know!

https://user-images.githubusercontent.com/26109316/207858600-ee862b22-0353-440b-ad85-caa0c4777904.mp4

https://github.com/roboflow/supervision/assets/26109316/c9436828-9fbf-4c25-ae8c-60e9c81b3900

https://github.com/roboflow/supervision/assets/26109316/3ac6982f-4943-4108-9b7f-51787ef1a69f

📚 Documentation

Visit our documentation page to learn how supervision can help you build computer vision applications faster and more reliably.

🏆 Contribution

We love your input! Please see our contributing guide to get started. Thank you 🙏 to all our contributors!

<a href="https://github.com/roboflow/supervision/graphs/contributors">
  <img src="https://contrib.rocks/image?repo=roboflow/supervision" />
</a>











  <a href="https://youtube.com/roboflow">
      <img
        src="https://media.roboflow.com/notebooks/template/icons/purple/youtube.png?ik-sdk-version=javascript-1.4.3&updatedAt=1672949634652"
        width="3%"
      />
  </a>
  <img src="https://raw.githubusercontent.com/ultralytics/assets/main/social/logo-transparent.png" width="3%"/>
  <a href="https://roboflow.com">
      <img
        src="https://media.roboflow.com/notebooks/template/icons/purple/roboflow-app.png?ik-sdk-version=javascript-1.4.3&updatedAt=1672949746649"
        width="3%"
      />
  </a>
  <img src="https://raw.githubusercontent.com/ultralytics/assets/main/social/logo-transparent.png" width="3%"/>
  <a href="https://www.linkedin.com/company/roboflow-ai/">
      <img
        src="https://media.roboflow.com/notebooks/template/icons/purple/linkedin.png?ik-sdk-version=javascript-1.4.3&updatedAt=1672949633691"
        width="3%"
      />
  </a>
  <img src="https://raw.githubusercontent.com/ultralytics/assets/main/social/logo-transparent.png" width="3%"/>
  <a href="https://docs.roboflow.com">
      <img
        src="https://media.roboflow.com/notebooks/template/icons/purple/knowledge.png?ik-sdk-version=javascript-1.4.3&updatedAt=1672949634511"
        width="3%"
      />
  </a>
  <img src="https://raw.githubusercontent.com/ultralytics/assets/main/social/logo-transparent.png" width="3%"/>
  <a href="https://discuss.roboflow.com">
      <img
        src="https://media.roboflow.com/notebooks/template/icons/purple/forum.png?ik-sdk-version=javascript-1.4.3&updatedAt=1672949633584"
        width="3%"
      />
  </a>
  <img src="https://raw.githubusercontent.com/ultralytics/assets/main/social/logo-transparent.png" width="3%"/>
  <a href="https://blog.roboflow.com">
      <img
        src="https://media.roboflow.com/notebooks/template/icons/purple/blog.png?ik-sdk-version=javascript-1.4.3&updatedAt=1672949633605"
        width="3%"
      />
  </a>

Core symbols most depended-on inside this repo

append
called by 278
src/supervision/detection/tools/csv_sink.py
empty
called by 164
src/supervision/detection/core.py
_create_detections
called by 72
tests/helpers.py
sum
called by 68
src/supervision/detection/compact_mask.py
get
called by 56
src/supervision/annotators/utils.py
from_dense
called by 51
src/supervision/detection/compact_mask.py
as_bgr
called by 50
src/supervision/draw/color.py
from_hex
called by 49
src/supervision/draw/color.py

Shape

Method 955
Function 759
Class 220
Route 53

Languages

Python99%
TypeScript1%

Modules by API surface

tests/detection/test_compact_mask.py105 symbols
tests/annotators/test_core.py100 symbols
src/supervision/annotators/core.py93 symbols
tests/dataset/formats/test_coco.py54 symbols
tests/detection/utils/test_iou_and_nms.py46 symbols
src/supervision/detection/core.py42 symbols
tests/key_points/test_core.py40 symbols
src/supervision/validators/__init__.py38 symbols
src/supervision/metrics/mean_average_precision.py38 symbols
examples/compact_mask/benchmark.py38 symbols
tests/detection/test_core.py37 symbols
tests/key_points/test_annotators.py35 symbols

Dependencies from manifests, versioned

defusedxml0.7.1 · 1×
matplotlib3.6 · 1×
numpy1.21.2 · 1×
opencv-python4.5.5.64 · 1×
pillow9.4 · 1×
pyyaml5.3 · 1×
requests2.26 · 1×
scipy1.10 · 1×
super-gradients3.5.0 · 1×
tqdm4.62.3 · 1×

For agents

$ claude mcp add supervision \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact