Ultralytics YOLO دليل ضبط المعلمات الفائقة
مقدمة
ضبط المعلمات الفائقة ليس مجرد إعداد لمرة واحدة ولكنه عملية تكرارية تهدف إلى تحسين مقاييس أداء نموذج التعلم الآلي ، مثل الدقة والدقة والاستدعاء. في سياق Ultralytics YOLO، يمكن أن تتراوح هذه المعلمات الفائقة من معدل التعلم إلى التفاصيل المعمارية، مثل عدد الطبقات أو أنواع وظائف التنشيط المستخدمة.
ما هي المعلمات الفائقة؟
المعلمات الفائقة هي إعدادات هيكلية عالية المستوى للخوارزمية. يتم تعيينها قبل مرحلة التدريب وتبقى ثابتة أثناءها. فيما يلي بعض المعلمات الفائقة التي يتم ضبطها بشكل شائع في Ultralytics YOLO:
- معدل التعلم
lr0
يحدد حجم الخطوة في كل تكرار أثناء التحرك نحو الحد الأدنى في دالة الخسارة.: - حجم الدفعة
batch
عدد الصور التي تتم معالجتها في وقت واحد في تمريرة أمامية.: - عدد الحقب
epochs
الحقبة هي تمريرة واحدة كاملة للأمام والخلف لجميع أمثلة التدريب.: - تفاصيل الهندسة المعمارية: مثل عدد القنوات وعدد الطبقات وأنواع وظائف التنشيط وما إلى ذلك.
للحصول على قائمة كاملة بالمعلمات الفائقة للزيادة المستخدمة في YOLOv8 يرجى الرجوع إلى صفحة التكوينات.
التطور الجيني والطفرات
Ultralytics YOLO يستخدم الخوارزميات الجينية لتحسين المعلمات الفائقة. الخوارزميات الجينية مستوحاة من آلية الانتقاء الطبيعي وعلم الوراثة.
- الطفرة: في سياق Ultralytics YOLO، تساعد الطفرة في البحث محليا في مساحة المعلمات الفائقة من خلال تطبيق تغييرات صغيرة وعشوائية على المعلمات الفائقة الحالية ، مما ينتج عنه مرشحون جدد للتقييم.
- كروس أوفر: على الرغم من أن التقاطع هو تقنية خوارزمية جينية شائعة ، إلا أنه لا يستخدم حاليا في Ultralytics YOLO لضبط المعلمات الفائقة. ينصب التركيز بشكل أساسي على الطفرة لتوليد مجموعات معلمات فائقة جديدة.
التحضير لضبط المعلمات الفائقة
قبل البدء في عملية الضبط، من المهم:
- تحديد المقاييس: حدد المقاييس التي ستستخدمها لتقييم أداء النموذج. قد يكون هذا AP50 أو F1-score أو غيرها.
- تعيين ميزانية الضبط: حدد مقدار الموارد الحسابية التي ترغب في تخصيصها. يمكن أن يكون ضبط المعلمات الفائقة مكثفا من الناحية الحسابية.
الخطوات المتبعة
تهيئة المعلمات الفائقة
ابدأ بمجموعة معقولة من المعلمات الفائقة الأولية. يمكن أن يكون هذا إما المعلمات الفائقة الافتراضية التي تم تعيينها بواسطة Ultralytics YOLO أو شيء يعتمد على معرفتك بالمجال أو التجارب السابقة.
تحور المعلمات الفائقة
استخدم الزر _mutate
طريقة لإنتاج مجموعة جديدة من المعلمات الفائقة بناء على المجموعة الحالية.
نموذج القطار
يتم تنفيذ التدريب باستخدام مجموعة متحورة من المعلمات الفائقة. ثم يتم تقييم أداء التدريب.
تقييم النموذج
استخدم مقاييس مثل AP50 أو F1-score أو المقاييس المخصصة لتقييم أداء النموذج.
تسجيل النتائج
من الأهمية بمكان تسجيل كل من مقاييس الأداء والمعلمات الفائقة المقابلة للرجوع إليها في المستقبل.
كرر
تتكرر العملية حتى يتم الوصول إلى العدد المحدد من التكرارات أو يكون مقياس الأداء مرضيا.
مثال على الاستخدام
إليك كيفية استخدام model.tune()
طريقة لاستخدام Tuner
فئة لضبط المعلمات الفائقة YOLOv8n على COCO8 لمدة 30 حقبة مع محسن AdamW وتخطي التخطيط والتحقق والتحقق من الصحة بخلاف الحقبة النهائية لضبط أسرع.
مثل
النتائج
بعد إكمال عملية ضبط المعلمات الفائقة بنجاح ، ستحصل على العديد من الملفات والدلائل التي تغلف نتائج الضبط. وفيما يلي وصف لكل منها:
هيكل الملف
إليك ما ستبدو عليه بنية دليل النتائج. أدلة التدريب مثل train1/
تحتوي على تكرارات ضبط فردية ، أي نموذج واحد مدرب بمجموعة واحدة من المعلمات الفائقة. ال tune/
يحتوي الدليل على نتائج ضبط من جميع التدريبات النموذجية الفردية:
runs/
└── detect/
├── train1/
├── train2/
├── ...
└── tune/
├── best_hyperparameters.yaml
├── best_fitness.png
├── tune_results.csv
├── tune_scatter_plots.png
└── weights/
├── last.pt
└── best.pt
أوصاف الملفات
best_hyperparameters.yaml
هذا YAML ملف يحتوي على أفضل أداء المعلمات الفائقة التي وجدت أثناء عملية ضبط. يمكنك استخدام هذا الملف لتهيئة التدريبات المستقبلية باستخدام هذه الإعدادات المحسنة.
- التنسيق: YAML
- إستعمال: نتائج المعلمات الفائقة
- مثل:
# 558/900 iterations complete ✅ (45536.81s) # Results saved to /usr/src/ultralytics/runs/detect/tune # Best fitness=0.64297 observed at iteration 498 # Best fitness metrics are {'metrics/precision(B)': 0.87247, 'metrics/recall(B)': 0.71387, 'metrics/mAP50(B)': 0.79106, 'metrics/mAP50-95(B)': 0.62651, 'val/box_loss': 2.79884, 'val/cls_loss': 2.72386, 'val/dfl_loss': 0.68503, 'fitness': 0.64297} # Best fitness model is /usr/src/ultralytics/runs/detect/train498 # Best fitness hyperparameters are printed below. lr0: 0.00269 lrf: 0.00288 momentum: 0.73375 weight_decay: 0.00015 warmup_epochs: 1.22935 warmup_momentum: 0.1525 box: 18.27875 cls: 1.32899 dfl: 0.56016 hsv_h: 0.01148 hsv_s: 0.53554 hsv_v: 0.13636 degrees: 0.0 translate: 0.12431 scale: 0.07643 shear: 0.0 perspective: 0.0 flipud: 0.0 fliplr: 0.08631 mosaic: 0.42551 mixup: 0.0 copy_paste: 0.0
best_fitness.png
هذا مخطط يعرض اللياقة البدنية (عادة مقياس أداء مثل AP50) مقابل عدد التكرارات. يساعدك على تصور مدى جودة أداء الخوارزمية الجينية بمرور الوقت.
- تنسيق الملف : PNG
- إستعمال: تصور الأداء
tune_results.csv
ملف CSV يحتوي على نتائج مفصلة لكل تكرار أثناء الضبط. يمثل كل صف في الملف تكرارا واحدا ، ويتضمن مقاييس مثل درجة اللياقة البدنية والدقة والاستدعاء بالإضافة إلى المعلمات الفائقة المستخدمة.
- التنسيق: CSV
- الاستخدام: تتبع نتائج التكرار.
- مثل:
fitness,lr0,lrf,momentum,weight_decay,warmup_epochs,warmup_momentum,box,cls,dfl,hsv_h,hsv_s,hsv_v,degrees,translate,scale,shear,perspective,flipud,fliplr,mosaic,mixup,copy_paste 0.05021,0.01,0.01,0.937,0.0005,3.0,0.8,7.5,0.5,1.5,0.015,0.7,0.4,0.0,0.1,0.5,0.0,0.0,0.0,0.5,1.0,0.0,0.0 0.07217,0.01003,0.00967,0.93897,0.00049,2.79757,0.81075,7.5,0.50746,1.44826,0.01503,0.72948,0.40658,0.0,0.0987,0.4922,0.0,0.0,0.0,0.49729,1.0,0.0,0.0 0.06584,0.01003,0.00855,0.91009,0.00073,3.42176,0.95,8.64301,0.54594,1.72261,0.01503,0.59179,0.40658,0.0,0.0987,0.46955,0.0,0.0,0.0,0.49729,0.80187,0.0,0.0
tune_scatter_plots.png
يحتوي هذا الملف على مخططات مبعثرة تم إنشاؤها من tune_results.csv
، مما يساعدك على تصور العلاقات بين المعلمات الفائقة المختلفة ومقاييس الأداء. لاحظ أنه لن يتم ضبط المعلمات الفائقة التي تمت تهيئتها إلى 0 ، مثل degrees
و shear
ادناه.
- تنسيق الملف : PNG
- إستعمال: تحليل البيانات الاستكشافية
اثقال/
يحتوي هذا الدليل على ملف PyTorch نماذج لآخر وأفضل التكرارات أثناء عملية ضبط المعلمات الفائقة.
last.pt
last.pt هي الأوزان من الحقبة الأخيرة من التدريب.:best.pt
الأوزان best.pt للتكرار الذي حقق أفضل درجة لياقة.:
باستخدام هذه النتائج ، يمكنك اتخاذ قرارات أكثر استنارة لتدريبات وتحليلات النموذج المستقبلية. لا تتردد في الرجوع إلى هذه القطع الأثرية لفهم مدى جودة أداء نموذجك وكيف يمكنك تحسينه بشكل أكبر.
استنتاج
عملية ضبط المعلمات الفائقة في Ultralytics YOLO مبسطة لكنها قوية ، وذلك بفضل نهجها القائم على الخوارزمية الجينية الذي يركز على الطفرة. سيساعدك اتباع الخطوات الموضحة في هذا الدليل في ضبط نموذجك بشكل منهجي لتحقيق أداء أفضل.
قراءة متعمقة
- تحسين المعلمات الفائقة في ويكيبيديا
- YOLOv5 دليل تطور المعلمات الفائقة
- ضبط المعلمات الفائقة الفعال باستخدام Ray Tune و YOLOv8
للحصول على رؤى أعمق، يمكنك استكشاف Tuner
كود مصدر الفصل والوثائق المصاحبة. إذا كانت لديك أي أسئلة أو طلبات ميزات أو كنت بحاجة إلى مزيد من المساعدة ، فلا تتردد في التواصل معنا على جيثب أو الخلاف.