실시간 추적, 간소화된 협업, 향상된 재현성 등 울트라리틱스와 Comet이 어떻게 울트라리틱스 YOLOv5 모델 최적화를 위해 협력하는지 알아보세요.

실시간 추적, 간소화된 협업, 향상된 재현성 등 울트라리틱스와 Comet이 어떻게 울트라리틱스 YOLOv5 모델 최적화를 위해 협력하는지 알아보세요.
저희는 다른 스타트업과 상업적 파트너십을 맺고 YOLOv5와 같은 멋진 오픈 소스 도구의 연구 및 개발 자금을 지원하여 모든 사람이 무료로 사용할 수 있도록 하고 있습니다. 이 문서에는 해당 파트너의 제휴 링크가 포함되어 있을 수 있습니다.
최신 파트너인 Comet은 데이터 과학자, 엔지니어, 팀 리더가 머신러닝 및 딥러닝 모델을 가속화하고 최적화하는 데 도움이 되는 도구를 구축합니다.
Comet은 모델, 데이터 세트, 메트릭을 추적할 수 있는 강력한 도구입니다. 심지어 시스템 및 환경 변수를 기록하여 모든 실행에 대한 재현성과 원활한 디버깅을 보장합니다. 마치 어떤 메모를 남겨야 하는지 마법처럼 알아서 기억해 주는 가상 비서가 있는 것과 같습니다. 실시간으로 모델 메트릭을 추적 및 시각화하고, 하이퍼파라미터, 데이터 세트 및 모델 체크포인트를 저장하고, Comet 사용자 지정 패널로 모델 예측을 시각화할 수 있습니다!
또한 Comet을 사용하면 작업 내용을 놓치지 않고 모든 규모의 팀에서 결과를 쉽게 공유하고 협업할 수 있습니다!
YOLOv5는 컴퓨터 비전 여정을 위한 훌륭한 출발점입니다. 모델의 성능을 개선하고 프로덕션에 사용할 수 있도록 하려면 Comet과 같은 실험 추적 도구에 결과를 기록해야 합니다.
Comet과 YOLOv5의 통합은 3가지 주요 기능을 제공합니다:
이 가이드에서는 Comet에서 YOLOv5를 사용하는 방법에 대해 설명합니다.
실험을 실시간으로 추적할 준비가 되셨나요? 이제 시작해보세요!
Pip 설치 comet_ml
YOLOv5로 Comet을 구성하는 방법에는 두 가지가 있습니다.
환경 변수를 통해 자격 증명을 설정하거나 작업 디렉터리에 .comet.config 파일을 생성하고 여기에 자격 증명을 설정할 수 있습니다.
export COMET_API_KEY=export COMET_PROJECT_NAME= # 기본값은 'yolov5'로 설정됩니다.
[comet] api_key= project_name=<Your Comet API Key># This will default to 'yolov5'
# 5개의 epoch에 대해 COCO128에서 YOLOv5s를 훈련합니다.py --img 640 --batch 16 --epochs 5 --data coco128.yaml --weights yolov5s.pt.
그거예요!
Comet은 하이퍼파라미터, 명령줄 인수, 트레이닝 및 유효성 검사 메트릭을 자동으로 기록합니다. Comet UI에서 실행을 시각화하고 분석할 수 있습니다.
기본적으로 Comet은 다음 항목을 기록합니다:
교육 스크립트 또는 환경 변수에 전달된 명령줄 플래그를 통해 추가 데이터를 기록하도록 Comet을 구성할 수 있습니다.
export COMET_MODE=online # Comet을 '온라인' 또는 '오프라인' 모드로 실행할지 여부를 설정합니다. 기본값은 온라인export COMET_MODEL_NAME= #저장된 모델의 이름을 설정합니다. 기본값은 yolov5export COMET_LOG_CONFUSION_MATRIX=false # 혜성 혼동 매트릭스 로깅을 비활성화하도록 설정합니다. 기본값은 trueexport COMET_MAX_IMAGE_UPLOADS= # 혜성에 기록할 총 이미지 예측 수량을 제어합니다. 기본값은 100입니다.export COMET_LOG_PER_CLASS_METRICS=true # 학습 종료 시 탐지된 각 클래스에 대한 평가 메트릭을 기록하도록 설정합니다. 기본값은 falseexport COMET_DEFAULT_CHECKPOINT_FILENAME= # 다른 체크포인트에서 훈련을 다시 시작하려면 이 값을 설정합니다. 기본값은 'last.pt'export COMET_LOG_BATCH_LEVEL_METRICS=true # 배치 수준에서 훈련 지표를 기록하려면 이 옵션을 설정합니다. 기본값은 false.export COMET_LOG_PREDICTIONS=true # 모델 예측 로깅을 비활성화하려면 false로 설정합니다.
Comet에 모델 로깅은 기본적으로 비활성화되어 있습니다. 활성화하려면 훈련 스크립트에 save-period 인수를 전달하세요.
python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--save-period 1
기본적으로 모델 예측(이미지, 기준값 레이블, 바운딩 박스)은 Comet에 기록됩니다. bbox_interval 명령줄 인수를 전달하여 기록된 예측 및 관련 이미지의 빈도를 제어할 수 있습니다. 예측은 Comet의 객체 감지 커스텀 패널을 사용하여 시각화할 수 있습니다. 이 빈도는 에포크당 N번째 데이터 배치에 해당합니다. 아래 예시에서는 각 에포크에 대해 두 번째 데이터 배치마다 로깅하고 있습니다.
참고: YOLOv5 유효성 검사 데이터 로더는 기본적으로 배치 크기가 32로 설정되므로 그에 따라 로깅 빈도를 설정해야 합니다.
다음은 패널을 사용하는 프로젝트의 예시입니다.
python train.py \--이미지 640 \--배치 16 \--에포크 5 \--데이터 코코128.yaml \--가중치 yolov5s.pt \--bbox_interval 2
YOLOv5에서 예측을 기록할 때 Comet은 각 예측 세트와 관련된 이미지를 기록합니다. 기본적으로 최대 100개의 유효성 검사 이미지가 기록됩니다. COMET_MAX_IMAGE_UPLOADS 환경 변수를 사용하여 이 수를 늘리거나 줄일 수 있습니다.
env COMET_MAX_IMAGE_UPLOADS=200python train.py \--img 640 \--batch 16 \--epochs 5 \--data coco128.yaml \--weights yolov5s.pt \--bbox_interval 1
각 클래스에 대한 mAP, 정밀도, 리콜 및 f1을 기록하려면 COMET_LOG_PER_CLASS_METRICS 환경 변수를 사용합니다.
환경 COMET_LOG_PER_CLASS_METRICS=true python train.py \--이미지 640 \--배치 16 \--에포크 5 \--데이터 코코128.yaml \--가중치 yolov5s.pt
혜성 아티팩트를 사용하여 데이터를 저장하려면 upload_dataset 플래그를 사용하여 저장할 수 있습니다.
데이터 세트는 YOLOv5 문서에 설명된 방식으로 구성됩니다. 데이터 세트 구성 yaml 파일은 coco128.yaml 파일과 동일한 형식을 따라야 합니다.
python train.py \--이미지 640 \--배치 16 \--에포크 5 \--데이터 코코128.yaml \--가중치 yolov5s.pt \--업로드_데이터세트
업로드된 데이터 세트는 Comet 워크스페이스의 아티팩트 탭에서 찾을 수 있습니다.
Comet UI에서 바로 데이터를 미리 볼 수 있습니다.
아티팩트는 버전이 관리되며 데이터 세트에 대한 메타데이터 추가도 지원합니다. Comet은 데이터 세트 yaml 파일에서 메타데이터를 자동으로 기록합니다.
Comet 아티팩트의 데이터 세트를 사용하려면 데이터 세트 yaml 파일에서 경로 변수가 다음 아티팩트 리소스 URL을 가리키도록 설정하세요.
artifact.yaml 파일 경로의 # 내용: "comet:///:"
그런 다음 다음과 같은 방법으로 이 파일을 교육 스크립트에 전달합니다:
python train.py \--이미지 640 \--배치 16 \--에포크 5 \--데이터 아티팩트.yaml \--웨이트 yolov5s.pt
아티팩트를 사용하면 실험 워크플로우를 통해 데이터의 계보를 추적할 수도 있습니다. 여기에서 업로드한 데이터 집합을 사용한 모든 실험을 보여주는 그래프를 볼 수 있습니다.
인터넷 연결이 끊기는 등의 이유로 훈련 달리기가 중단된 경우, 재개 플래그와 혜성 달리기 경로를 사용하여 달리기를 재개할 수 있습니다.
실행 경로의 형식은 comet:////.
이렇게 하면 중단 전 상태로 실행이 복원되며, 여기에는 체크포인트에서 모델 복원, 모든 하이퍼파라미터 및 훈련 인수 복원, 원래 실행에 사용된 경우 Comet 데이터 세트 아티팩트 다운로드가 포함됩니다. 재개된 실행은 Comet UI의 기존 실험에 계속 로깅됩니다.
python train.py \--resume "comet://"
또한 YOLOv5는 Comet의 옵티마이저와 통합되어 Comet UI에서 하이퍼파라미터 스윕을 간편하게 시각화할 수 있습니다.
혜성 옵티마이저를 구성하려면 스윕에 대한 정보가 포함된 JSON 파일을 만들어야 합니다.
예제 파일이 제공되었습니다:
utils/loggers/comet/optimizer_config.json python utils/loggers/comet/hpo.py \--comet_optimizer_config "utils/loggers/comet/optimizer_config.json"
hpo.py 스크립트는 train.py와 동일한 인수를 허용합니다. 스윕에 추가 인수를 전달하려면 스크립트 뒤에 인수를 추가하기만 하면 됩니다.
python utils/loggers/comet/hpo.py \--comet_optimizer_config "utils/loggers/comet/optimizer_config.json" \--save-period 1 \--bbox_interval 1
comet optimizer -j utils/loggers/comet/hpo.py \utils/loggers/comet/optimizer_config.json"
Comet은 스윕 결과를 시각화할 수 있는 다양한 방법을 제공합니다. 여기에서 스윕이 완료된 프로젝트를 살펴보세요:
Comet과의 통합을 통해 교육 실행부터 프로덕션 모니터링에 이르기까지 YOLOv5 모델을 관리, 시각화 및 최적화할 수 있습니다.
물론, YOLOv5 교육, 검증 및 배포에 대해 질문하고 팁을 공유할 수 있는 공간인 Ultralytics 커뮤니티에 가입하세요.