Bỏ để qua phần nội dung

Comet

YOLOv5 với Comet

Hướng dẫn này sẽ bao gồm cách sử dụng YOLOv5 với Comet

Về Comet

Comet Xây dựng các công cụ giúp các nhà khoa học dữ liệu, kỹ sư và trưởng nhóm tăng tốc và tối ưu hóa các mô hình học máy và học sâu.

Theo dõi và trực quan hóa các chỉ số mô hình trong thời gian thực, lưu siêu tham số, tập dữ liệu và điểm kiểm tra mô hình, đồng thời trực quan hóa các dự đoán mô hình của bạn với Comet Bảng điều khiển tùy chỉnh! Comet Đảm bảo bạn không bao giờ mất dấu công việc của mình và giúp bạn dễ dàng chia sẻ kết quả và cộng tác giữa các nhóm thuộc mọi quy mô!

Bắt đầu

Cài đặt Comet

pip install comet_ml

Cấu hình Comet Ủy nhiệm

Có hai cách để cấu hình Comet với YOLOv5.

Bạn có thể đặt thông tin đăng nhập của mình thông qua các biến môi trường

Biến môi trường

export COMET_API_KEY=<Your Comet API Key>
export COMET_PROJECT_NAME=<Your Comet Project Name> # This will default to 'yolov5'

Hoặc tạo một .comet.config trong thư mục làm việc của bạn và đặt thông tin đăng nhập của bạn ở đó.

Comet Tệp cấu hình

[comet]
api_key=<Your Comet API Key>
project_name=<Your Comet Project Name> # This will default to 'yolov5'

Chạy tập lệnh đào tạo

# Train YOLOv5s on COCO128 for 5 epochs
python train.py --img 640 --batch 16 --epochs 5 --data coco128.yaml --weights yolov5s.pt

Đó là nó! Comet sẽ tự động ghi lại các siêu tham số, đối số dòng lệnh, số liệu đào tạo và xác thực của bạn. Bạn có thể hình dung và phân tích các hoạt động của mình trong Comet UI

yolo-Ui

Hãy thử một ví dụ!

Xem ví dụ về một lần chạy đã hoàn thành tại đây

Hoặc tốt hơn nữa, hãy tự mình thử nó trong Colab Notebook này

Mở trong Colab

Đăng nhập tự động

Theo mặc định, Comet sẽ ghi lại các mục sau

Metrics

  • Mất hộp, mất đối tượng, mất phân loại cho dữ liệu đào tạo và xác thực
  • mAP_0.5, mAP_0.5:0.95 số liệu cho dữ liệu xác thực.
  • Độ chính xác và Nhớ lại dữ liệu xác thực

Thông số

  • Mô hình siêu tham số
  • Tất cả các tham số được truyền qua các tùy chọn dòng lệnh

Visualizations

  • Ma trận nhầm lẫn của các dự đoán mô hình trên dữ liệu xác thực
  • Biểu đồ cho các đường cong PR và F1 trên tất cả các lớp
  • Correlogram của nhãn lớp

Cấu hình Comet Đăng nhập

Comet có thể được cấu hình để ghi dữ liệu bổ sung thông qua cờ dòng lệnh được chuyển đến tập lệnh đào tạo hoặc thông qua các biến môi trường.

export COMET_MODE=online # Set whether to run Comet in 'online' or 'offline' mode. Defaults to online
export COMET_MODEL_NAME=<your model name> #Set the name for the saved model. Defaults to yolov5
export COMET_LOG_CONFUSION_MATRIX=false # Set to disable logging a Comet Confusion Matrix. Defaults to true
export COMET_MAX_IMAGE_UPLOADS=<number of allowed images to upload to Comet> # Controls how many total image predictions to log to Comet. Defaults to 100.
export COMET_LOG_PER_CLASS_METRICS=true # Set to log evaluation metrics for each detected class at the end of training. Defaults to false
export COMET_DEFAULT_CHECKPOINT_FILENAME=<your checkpoint filename> # Set this if you would like to resume training from a different checkpoint. Defaults to 'last.pt'
export COMET_LOG_BATCH_LEVEL_METRICS=true # Set this if you would like to log training metrics at the batch level. Defaults to false.
export COMET_LOG_PREDICTIONS=true # Set this to false to disable logging model predictions

Ghi nhật ký các điểm kiểm tra với Comet

Mô hình ghi nhật ký để Comet bị tắt theo mặc định. Để kích hoạt nó, hãy vượt qua save-period lập luận cho kịch bản đào tạo. Thao tác này sẽ lưu các điểm kiểm tra đã đăng nhập vào Comet dựa trên giá trị khoảng thời gian được cung cấp bởi save-period

python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--save-period 1

Dự đoán mô hình ghi nhật ký

Theo mặc định, các dự đoán mô hình (hình ảnh, nhãn sự thật cơ bản và hộp giới hạn) sẽ được ghi vào Comet.

Bạn có thể kiểm soát tần suất dự đoán đã đăng nhập và các hình ảnh liên quan bằng cách chuyển bbox_interval đối số dòng lệnh. Dự đoán có thể được hình dung bằng cách sử dụng Comet'Bảng tùy chỉnh phát hiện đối tượng. Tần số này tương ứng với mỗi lô dữ liệu thứ N trên mỗi kỷ nguyên. Trong ví dụ dưới đây, chúng tôi đang ghi lại mỗi đợt dữ liệu thứ 2 cho mỗi kỷ nguyên.

Ghi: Các YOLOv5 Validation Dataloader sẽ mặc định là kích thước lô là 32, vì vậy bạn sẽ phải đặt tần suất ghi nhật ký cho phù hợp.

Dưới đây là một dự án ví dụ sử dụng Bảng điều khiển

python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--bbox_interval 2

Kiểm soát số lượng Hình ảnh dự đoán được ghi vào Comet

Khi ghi lại dự đoán từ YOLOv5, Comet sẽ ghi lại các hình ảnh liên quan đến từng bộ dự đoán. Theo mặc định, tối đa 100 hình ảnh xác thực được ghi lại. Bạn có thể tăng hoặc giảm số này bằng cách sử dụng COMET_MAX_IMAGE_UPLOADS biến môi trường.

env COMET_MAX_IMAGE_UPLOADS=200 python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--bbox_interval 1

Ghi nhật ký số liệu cấp lớp

Sử dụng COMET_LOG_PER_CLASS_METRICS biến môi trường để ghi mAP, độ chính xác, thu hồi, f1 cho mỗi lớp.

env COMET_LOG_PER_CLASS_METRICS=true python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt

Tải tập dữ liệu lên Comet Artifacts

Nếu bạn muốn lưu trữ dữ liệu của mình bằng cách sử dụng Comet Artifacts, bạn có thể làm như vậy bằng cách sử dụng upload_dataset cờ.

Tập dữ liệu được tổ chức theo cách được mô tả trong YOLOv5 tư liệu. Cấu hình tập dữ liệu yaml Tệp phải tuân theo cùng định dạng với định dạng của tệp coco128.yaml tệp.

python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--upload_dataset

Bạn có thể tìm thấy tập dữ liệu đã tải lên trong tab Cấu phần phần mềm trong Comet Workspace hiện vật-1

Bạn có thể xem trước dữ liệu trực tiếp trong Comet UI. hiện vật-2

Các thành phần lạ được lập phiên bản và cũng hỗ trợ thêm siêu dữ liệu về tập dữ liệu. Comet sẽ tự động ghi lại siêu dữ liệu từ tập dữ liệu của bạn yaml tệp hiện vật-3

Sử dụng thành phần lạ đã lưu

Nếu bạn muốn sử dụng tập dữ liệu từ Comet Hiện vật, đặt path biến trong tập dữ liệu của bạn yaml để trỏ đến URL tài nguyên cấu phần mềm sau.

# contents of artifact.yaml file
path: "comet://<workspace name>/<artifact name>:<artifact version or alias>"

Sau đó chuyển tệp này vào tập lệnh đào tạo của bạn theo cách sau

python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data artifact.yaml \
--weights yolov5s.pt

Thành phần lạ cũng cho phép bạn theo dõi dòng dữ liệu khi dữ liệu chảy qua quy trình làm việc Thử nghiệm của bạn. Tại đây, bạn có thể thấy biểu đồ hiển thị cho bạn tất cả các thử nghiệm đã sử dụng tập dữ liệu đã tải lên của bạn. hiện vật-4

Tiếp tục chạy đào tạo

Nếu quá trình đào tạo của bạn bị gián đoạn vì bất kỳ lý do gì, ví dụ: kết nối internet bị gián đoạn, bạn có thể tiếp tục chạy bằng cách sử dụng resume cờ và Comet Chạy đường dẫn.

Đường dẫn chạy có định dạng sau comet://<your workspace name>/<your project name>/<experiment id>.

Điều này sẽ khôi phục quá trình chạy về trạng thái trước khi bị gián đoạn, bao gồm khôi phục mô hình từ điểm kiểm tra, khôi phục tất cả các siêu tham số và đối số đào tạo và tải xuống Comet tập dữ liệu Artifacts nếu chúng được sử dụng trong lần chạy ban đầu. Quá trình chạy tiếp tục sẽ tiếp tục ghi vào Thử nghiệm hiện có trong Comet UI

python train.py \
--resume "comet://<your run path>"

Tìm kiếm siêu tham số với Comet Tối ưu hóa

YOLOv5 cũng được tích hợp với CometTrình tối ưu hóa của Optimizer, làm cho đơn giản để hình dung các lần quét siêu tham số trong Comet UI.

Định cấu hình quét trình tối ưu hóa

Để cấu hình Comet Trình tối ưu hóa, bạn sẽ phải tạo một tệp JSON với thông tin về việc quét. Một tệp ví dụ đã được cung cấp trong utils/loggers/comet/optimizer_config.json

python utils/loggers/comet/hpo.py \
  --comet_optimizer_config "utils/loggers/comet/optimizer_config.json"

Các hpo.py script chấp nhận các đối số tương tự như train.py. Nếu bạn muốn chuyển các đối số bổ sung vào quét của mình, chỉ cần thêm chúng sau tập lệnh.

python utils/loggers/comet/hpo.py \
  --comet_optimizer_config "utils/loggers/comet/optimizer_config.json" \
  --save-period 1 \
  --bbox_interval 1

Chạy quét song song

comet optimizer -j <set number of workers> utils/loggers/comet/hpo.py \
  utils/loggers/comet/optimizer_config.json"

Trực quan hóa kết quả

Comet Cung cấp một số cách để hình dung kết quả quét của bạn. Hãy xem một dự án với một quét hoàn thành ở đây

siêu tham số-yolo



Đã tạo 2023-11-12, Cập nhật 2024-01-07
Tác giả: glenn-jocher (3), RizwanMunawar (1)

Ý kiến