Ultralytics'in Ultralytics YOLOv5 model optimizasyonu için Comet ile nasıl iş birliği yaptığını keşfedin: gerçek zamanlı izleme, kolaylaştırılmış iş birliği ve gelişmiş tekrarlanabilirlik.

Ultralytics'in Ultralytics YOLOv5 model optimizasyonu için Comet ile nasıl iş birliği yaptığını keşfedin: gerçek zamanlı izleme, kolaylaştırılmış iş birliği ve gelişmiş tekrarlanabilirlik.
Ultralytics'te, YOLOv5 gibi harika açık kaynaklı araçlarımızın araştırma ve geliştirmesini finanse etmemize yardımcı olmak ve bunları herkes için ücretsiz tutmak için ticari olarak diğer girişimlerle ortaklık yapıyoruz. Bu makale, bu ortaklara bağlı bağlantılar içerebilir.
En yeni iş ortağımız Comet, veri bilimcilerin, mühendislerin ve ekip liderlerinin makine öğrenimi ve derin öğrenme modellerini hızlandırmasına ve optimize etmesine yardımcı olan araçlar geliştiriyor.
Comet, modellerinizi, veri kümelerinizi ve metriklerinizi izlemek için güçlü bir araçtır. Her çalıştırmada tekrarlanabilirlik ve sorunsuz hata ayıklama sağlamak için sisteminizi ve ortam değişkenlerinizi bile günlüğe kaydeder. Hangi notları tutması gerektiğini sihirli bir şekilde bilen sanal bir asistana sahip olmak gibi. Model metriklerini gerçek zamanlı olarak takip edin ve görselleştirin, hiperparametrelerinizi, veri kümelerinizi ve model kontrol noktalarınızı kaydedin ve Comet Özel Panelleri ile model tahminlerinizi görselleştirin!
Ayrıca Comet, çalışmalarınızın kaydını asla kaybetmemenizi sağlar ve sonuçları paylaşmayı ve her büyüklükteki ekipler arasında işbirliği yapmayı kolaylaştırır!
YOLOv5, bilgisayarla görme yolculuğunuz için harika bir başlangıç noktasıdır. Modelinizin performansını iyileştirmek ve üretime hazır hale getirmek için sonuçları Comet gibi bir deney izleme aracında kaydetmeniz gerekir.
Comet ve YOLOv5 entegrasyonu 3 ana özellik sunmaktadır:
Bu kılavuz, YOLOv5'in Comet ile nasıl kullanılacağını ele alacaktır.
Peki, deneylerinizi gerçek zamanlı olarak takip etmeye hazır mısınız? Hadi başlayalım!
Pip comet_ml yükleyin
Comet'i YOLOv5 ile yapılandırmanın iki yolu vardır.
Kimlik bilgilerinizi ortam değişkenleri aracılığıyla ayarlayabilir ya da çalışma dizininizde bir .comet.config dosyası oluşturabilir ve kimlik bilgilerinizi burada ayarlayabilirsiniz.
export COMET_API_KEY=export COMET_PROJECT_NAME= # Bu varsayılan olarak 'yolov5' olacaktır
[comet] api_key= project_name=<Your Comet API Key># This will default to 'yolov5'
# Train YOLOv5s on COCO128 for 5 epochspython train.py --img 640 --batch 16 --epochs 5 --data coco128.yaml --weights yolov5s.pt
Bu kadar!
Comet hiperparametrelerinizi, komut satırı argümanlarınızı, eğitim ve doğrulama metriklerinizi otomatik olarak günlüğe kaydeder. Çalışmalarınızı Comet kullanıcı arayüzünde görselleştirebilir ve analiz edebilirsiniz.
Tamamlanmış bir çalışma örneğine buradan göz atın.
Ya da daha iyisi, bu Colab Notebook'ta kendiniz deneyin.
Varsayılan olarak, Comet aşağıdaki öğeleri günlüğe kaydeder:
Comet, eğitim komut dosyasına aktarılan komut satırı bayrakları veya ortam değişkenleri aracılığıyla ek verileri günlüğe kaydedecek şekilde yapılandırılabilir.
export COMET_MODE=online # Comet'in 'çevrimiçi' veya 'çevrimdışı' modda çalıştırılıp çalıştırılmayacağını ayarlayın. Defaults to onlineexport COMET_MODEL_NAME= #Kaydedilen modelin adını ayarlayın. Defaults to yolov5export COMET_LOG_CONFUSION_MATRIX=false # Comet Karışıklık Matrisini günlüğe kaydetmeyi devre dışı bırakmak için ayarlayın. Defaults to trueexport COMET_MAX_IMAGE_UPLOADS= # Comet'e kaç tane toplam görüntü tahmini kaydedileceğini kontrol eder. Defaults to 100.export COMET_LOG_PER_CLASS_METRICS=true # Eğitimin sonunda tespit edilen her sınıf için değerlendirme metriklerini günlüğe kaydetmek üzere ayarlanır. Defaults to falseexport COMET_DEFAULT_CHECKPOINT_FILENAME= # Eğitime farklı bir kontrol noktasından devam etmek istiyorsanız bunu ayarlayın. Defaults to 'last.pt'export COMET_LOG_BATCH_LEVEL_METRICS=true # Eğitim ölçümlerini toplu iş düzeyinde günlüğe kaydetmek istiyorsanız bunu ayarlayın. Varsayılan değer false.export COMET_LOG_PREDICTIONS=true # Model tahminlerini günlüğe kaydetmeyi devre dışı bırakmak için bunu false olarak ayarlayın
Modelleri Comet'e kaydetme varsayılan olarak devre dışıdır. Bunu etkinleştirmek için eğitim betiğine save-period argümanını iletin. Bu, kaydedilen kontrol noktalarını save-period tarafından sağlanan aralık değerine göre Comet'e kaydedecektir.
python train.py \
--img 640 \
--batch 16 \
--epochs 5 \
--data coco128.yaml \
--weights yolov5s.pt \
--save-period 1
Varsayılan olarak, model tahminleri (görüntüler, temel gerçek etiketleri ve sınırlayıcı kutular) Comet'e kaydedilecektir. Günlüğe kaydedilen tahminlerin ve ilişkili görüntülerin sıklığını bbox_interval komut satırı bağımsız değişkenini geçerek kontrol edebilirsiniz. Tahminler Comet'in Nesne Algılama Özel Paneli kullanılarak görselleştirilebilir. Bu sıklık, dönem başına her N'inci veri grubuna karşılık gelir. Aşağıdaki örnekte, her dönem için her 2. veri grubunu günlüğe kaydediyoruz.
Not: YOLOv5 doğrulama veri yükleyicisi varsayılan olarak 32'lik bir yığın boyutuna sahip olacaktır, bu nedenle günlük kaydı sıklığını buna göre ayarlamanız gerekecektir.
İşte Panel'i kullanan örnek bir proje.
python train.py \--img 640 \--batch 16 \--epochs 5 \--data coco128.yaml \--weights yolov5s.pt \--bbox_interval 2
YOLOv5'ten tahminleri günlüğe kaydederken, Comet her bir tahmin setiyle ilişkili görüntüleri günlüğe kaydeder. Varsayılan olarak, en fazla 100 doğrulama görüntüsü günlüğe kaydedilir. COMET_MAX_IMAGE_UPLOADS ortam değişkenini kullanarak bu sayıyı artırabilir veya azaltabilirsiniz.
env COMET_MAX_IMAGE_UPLOADS=200python train.py \--img 640 \--batch 16 \--epochs 5 \--data coco128.yaml \--weights yolov5s.pt \--bbox_interval 1
Her sınıf için mAP, precision, recall ve f1 değerlerini günlüğe kaydetmek için COMET_LOG_PER_CLASS_METRICS ortam değişkenini kullanın.
env COMET_LOG_PER_CLASS_METRICS=true python train.py \--img 640 \--batch 16 \--epochs 5 \--data coco128.yaml \--weights yolov5s.pt
Verilerinizi Comet Artifacts kullanarak saklamak isterseniz, bunu upload_dataset bayrağını kullanarak yapabilirsiniz.
Veri kümesi, YOLOv5 belgelerinde açıklanan şekilde düzenlenir. Veri kümesi yapılandırma yaml dosyası coco128.yaml dosyasıyla aynı biçimi izlemelidir.
python train.py \--img 640 \--batch 16 \--epochs 5 \--data coco128.yaml \--weights yolov5s.pt \--upload_dataset
Yüklenen veri kümesini Comet Çalışma Alanınızdaki Eserler sekmesinde bulabilirsiniz
Verileri doğrudan Comet kullanıcı arayüzünde önizleyebilirsiniz.
Eserler sürümlendirilir ve ayrıca veri kümesi hakkında meta veri eklemeyi destekler. Comet, veri kümesi yaml dosyanızdaki meta verileri otomatik olarak günlüğe kaydedecektir.
Comet Artifacts'ten bir veri kümesi kullanmak istiyorsanız, veri kümesi yaml dosyanızdaki yol değişkenini aşağıdaki Artifact kaynak URL'sine işaret edecek şekilde ayarlayın.
# artifact.yaml dosyasının içeriği yol: "comet:///:"
Daha sonra bu dosyayı eğitim betiğinize aşağıdaki şekilde aktarın:
python train.py \--img 640 \--batch 16 \--epochs 5 \--data artifact.yaml \--weights yolov5s.pt
Eserler aynı zamanda Deneme iş akışınız boyunca akan veri akışını izlemenize de olanak tanır. Burada, yüklediğiniz veri kümesini kullanan tüm deneyleri gösteren bir grafik görebilirsiniz.
Eğitim koşunuz herhangi bir nedenle kesintiye uğrarsa, örneğin internet bağlantınız kesilirse, devam bayrağını ve Comet Run Path'i kullanarak koşuya devam edebilirsiniz.
Çalışma Yolu aşağıdaki biçime sahiptir comet:////.
Bu, modeli bir kontrol noktasından geri yüklemeyi, tüm hiperparametreleri ve eğitim argümanlarını geri yüklemeyi ve orijinal çalışmada kullanılmışlarsa Comet veri kümesi Artefaktlarını indirmeyi içeren çalışmayı kesintiden önceki durumuna geri yükleyecektir. Yeniden başlatılan çalıştırma, Comet kullanıcı arayüzündeki mevcut Deneye günlük tutmaya devam edecektir.
python train.py \--resume "comet://"
YOLOv5 ayrıca Comet'in Optimizer'ı ile entegre edilmiştir ve Comet kullanıcı arayüzünde hiperparametre taramalarını görselleştirmeyi kolaylaştırır.
Comet Optimizer'ı yapılandırmak için, tarama ile ilgili bilgileri içeren bir JSON dosyası oluşturmanız gerekecektir.
Örnek bir dosya şurada verilmiştir:
utils/loggers/comet/optimizer_config.json python utils/loggers/comet/hpo.py \--comet_optimizer_config "utils/loggers/comet/optimizer_config.json"
hpo.py betiği train.py ile aynı argümanları kabul eder. Süpürme işleminize ek argümanlar aktarmak isterseniz bunları betikten sonra eklemeniz yeterlidir.
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, taramanızın sonuçlarını görselleştirmek için birçok yol sunar. Tamamlanmış bir taramaya sahip bir projeye buradan göz atın:
Eğitim çalışmalarından üretim izlemeye kadar YOLOv5 modellerinizi yönetmek, görselleştirmek ve optimize etmek için Comet ile entegrasyonumuzu kullanmaya başlayın.
Ve elbette, YOLOv5 eğitimi, doğrulaması ve dağıtımı hakkında sorular sorabileceğiniz ve ipuçları paylaşabileceğiniz Ultralytics Topluluğuna katılın.