تخطي إلى المحتوى

Ultralytics YOLO دليلضبط البارامتر الفائق

مقدمة

إن ضبط المعلمات الفائقة ليس مجرد إعداد لمرة واحدة، بل هو عملية تكرارية تهدف إلى تحسين مقاييس أداء نموذج التعلم الآلي، مثل الدقة والدقة والاسترجاع. في سياق Ultralytics YOLO ، يمكن أن تتراوح هذه المعلمات الفائقة من معدل التعلم إلى التفاصيل المعمارية، مثل عدد الطبقات أو أنواع دوال التنشيط المستخدمة.



شاهد: How to Tune Hyperparameters for Better Model Performance 🚀

ما هي المعلمات الفائقة؟

المعلمات الفائقة هي إعدادات هيكلية عالية المستوى للخوارزمية. يتم تعيينها قبل مرحلة التدريب وتبقى ثابتة أثناءها. فيما يلي بعض المعلمات الفائقة التي يتم ضبطها بشكل شائع في Ultralytics YOLO :

  • معدل التعلم lr0: يحدد حجم الخطوة عند كل تكرار مع التحرك نحو الحد الأدنى في دالة الخسارة.
  • حجم الدفعة batch: عدد الصور التي تتم معالجتها في وقت واحد في تمرير أمامي.
  • عدد الحقب الزمنية epochs: الحقبة الزمنية هي تمريرة واحدة كاملة للأمام والخلف لجميع أمثلة التدريب.
  • تفاصيل البنية: مثل عدد القنوات، وعدد الطبقات، وأنواع دوال التفعيل، وما إلى ذلك.

الضبط المرئي لضبط المعلمة الفائقة

للاطلاع على القائمة الكاملة لمعاملات الزيادة المفرطة المستخدمة في YOLO11 يرجى الرجوع إلى صفحة التكوينات.

التطور الوراثي والطفرة

Ultralytics YOLO تستخدم الخوارزميات الجينية لتحسين المعلمات الفائقة. الخوارزميات الجينية مستوحاة من آلية الانتقاء الطبيعي وعلم الوراثة.

  • الطفرة: في سياق Ultralytics YOLO ، تساعد الطفرة في البحث محليًا في فضاء المعلمات الفائقة من خلال تطبيق تغييرات عشوائية صغيرة على المعلمات الفائقة الحالية، مما ينتج عنه مرشحين جدد للتقييم.
  • التقاطع: على الرغم من أن التقاطع هو تقنية خوارزمية جينية شائعة، إلا أنه لا يستخدم حاليًا في Ultralytics YOLO لضبط المعلمات الفائقة. ينصب التركيز بشكل أساسي على الطفرة لتوليد مجموعات جديدة من المعلمات الفائقة.

التحضير لضبط المعامل الفائق

قبل أن تبدأ عملية الضبط، من المهم أن:

  1. تحديد المقاييس: حدد المقاييس التي ستستخدمها لتقييم أداء النموذج. قد تكون هذه المقاييس هي AP50 أو F1-score أو غيرها.
  2. تعيين ميزانية الضبط: حدد مقدار الموارد الحاسوبية التي ترغب في تخصيصها. يمكن أن يكون ضبط المعلمة الفائقة مكثفاً من الناحية الحسابية.

الخطوات المتضمنة

تهيئة المعلمات الفائقة

ابدأ بمجموعة معقولة من المعلمات الفائقة الأولية. يمكن أن يكون هذا إما المعلمات التشعبية الافتراضية التي حددها Ultralytics YOLO أو شيء ما استنادًا إلى معرفتك بالمجال أو التجارب السابقة.

تحوير المعلمات الفائقة

استخدم _mutate لإنتاج مجموعة جديدة من المعلمات الفائقة بناءً على المجموعة الحالية.

نموذج القطار

يتم إجراء التدريب باستخدام مجموعة متغيرة من المعلمات الفائقة. ثم يتم تقييم أداء التدريب.

تقييم النموذج

استخدم مقاييس مثل AP50، أو درجة F1، أو مقاييس مخصصة لتقييم أداء النموذج.

نتائج السجل

من المهم تسجيل كل من مقاييس الأداء والمعلمات الفائقة المقابلة للرجوع إليها في المستقبل.

التكرار

يتم تكرار العملية حتى يتم الوصول إلى العدد المحدد من التكرارات أو يكون مقياس الأداء مُرضيًا.

وصف مساحة البحث الافتراضية

The following table lists the default search space parameters for hyperparameter tuning in YOLO11. Each parameter has a specific value range defined by a tuple (min, max).

المعلمة النوع نطاق القيمة الوصف
lr0 float (1e-5, 1e-1) Initial learning rate at the start of training. Lower values provide more stable training but slower convergence
lrf float (0.01, 1.0) Final learning rate factor as a fraction of lr0. Controls how much the learning rate decreases during training
momentum float (0.6, 0.98) SGD momentum factor. Higher values help maintain consistent gradient direction and can speed up convergence
weight_decay float (0.0, 0.001) L2 regularization factor to prevent overfitting. Larger values enforce stronger regularization
warmup_epochs float (0.0, 5.0) Number of epochs for linear learning rate warmup. Helps prevent early training instability
warmup_momentum float (0.0, 0.95) Initial momentum during warmup phase. Gradually increases to the final momentum value
box float (0.02, 0.2) Bounding box loss weight in the total loss function. Balances box regression vs classification
cls float (0.2, 4.0) Classification loss weight in the total loss function. Higher values emphasize correct class prediction
hsv_h float (0.0, 0.1) Random hue augmentation range in HSV color space. Helps model generalize across color variations
hsv_s float (0.0, 0.9) Random saturation augmentation range in HSV space. Simulates different lighting conditions
hsv_v float (0.0, 0.9) Random value (brightness) augmentation range. Helps model handle different exposure levels
degrees float (0.0, 45.0) Maximum rotation augmentation in degrees. Helps model become invariant to object orientation
translate float (0.0, 0.9) Maximum translation augmentation as fraction of image size. Improves robustness to object position
scale float (0.0, 0.9) Random scaling augmentation range. Helps model detect objects at different sizes
shear float (0.0, 10.0) Maximum shear augmentation in degrees. Adds perspective-like distortions to training images
perspective float (0.0, 0.001) Random perspective augmentation range. Simulates different viewing angles
flipud float (0.0, 1.0) Probability of vertical image flip during training. Useful for overhead/aerial imagery
fliplr float (0.0, 1.0) Probability of horizontal image flip. Helps model become invariant to object direction
mosaic float (0.0, 1.0) Probability of using mosaic augmentation, which combines 4 images. Especially useful for small object detection
mixup float (0.0, 1.0) Probability of using mixup augmentation, which blends two images. Can improve model robustness
copy_paste float (0.0, 1.0) Probability of using copy-paste augmentation. Helps improve instance segmentation performance

مثال على مساحة البحث المخصصة

Here's how to define a search space and use the model.tune() للاستفادة من طريقة Tuner فئة لضبط المعلمة الفائقة لـ YOLO11n على COCO8 لـ 30 حقبة باستخدام مُحسِّن AdamW وتخطي التخطيط ونقاط التحقق والتحقق من الصحة بخلاف الحقبة النهائية لضبط أسرع.

مثال على ذلك

from ultralytics import YOLO

# Initialize the YOLO model
model = YOLO("yolo11n.pt")

# Define search space
search_space = {
    "lr0": (1e-5, 1e-1),
    "degrees": (0.0, 45.0),
}

# Tune hyperparameters on COCO8 for 30 epochs
model.tune(
    data="coco8.yaml",
    epochs=30,
    iterations=300,
    optimizer="AdamW",
    space=search_space,
    plots=False,
    save=False,
    val=False,
)

النتائج

بعد الانتهاء بنجاح من عملية ضبط البارامتر الفائق، ستحصل على العديد من الملفات والدلائل التي تغلف نتائج الضبط. وفيما يلي وصف لكل منها:

بنية الملف

إليك الشكل الذي ستبدو عليه بنية دليل النتائج. دلائل التدريب مثل 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_scatter_plots.png

يحتوي هذا الملف على مخططات مبعثرة تم إنشاؤها من tune_results.csvمما يساعدك على تصور العلاقات بين المعلمات التشعبية المختلفة ومقاييس الأداء. لاحظ أنه لن يتم ضبط المعاملات التشعبية التي تمت تهيئتها إلى 0، مثل degrees و shear أدناه.

  • التنسيق: PNG
  • الاستخدام: تحليل البيانات الاستكشافية

مخططات مبعثرات ضبط المعامل الفائق التشتت

الأوزان/

يحتوي هذا الدليل على النماذج المحفوظة PyTorch المحفوظة لآخر وأفضل التكرارات أثناء عملية ضبط البارامتر الفائق.

  • last.pt: آخر.pt هي الأوزان من آخر حقبة من التدريب.
  • best.pt: أفضل أوزان التكرار الذي حقق أفضل درجة لياقة بدنية.

باستخدام هذه النتائج، يمكنك اتخاذ قرارات أكثر استنارة لتدريباتك وتحليلاتك المستقبلية للنموذج. لا تتردد في الرجوع إلى هذه القطع الأثرية لفهم مدى جودة أداء نموذجك وكيف يمكنك تحسينه أكثر.

الخاتمة

تتسم عملية ضبط المعلمات الفائقة في Ultralytics YOLO بالبساطة والقوة في آن واحد، وذلك بفضل نهجها القائم على الخوارزمية الجينية الذي يركز على الطفرات. سيساعدك اتباع الخطوات الموضحة في هذا الدليل في ضبط نموذجك بشكل منهجي لتحقيق أداء أفضل.

مزيد من القراءة

  1. تحسين المعامل الفائق في ويكيبيديا
  2. YOLOv5 دليل تطور البارامتر الفائق
  3. الضبط الفعال للمقياس الفائق الفعال مع راي تيون و YOLO11

للحصول على رؤى أعمق، يمكنك استكشاف Tuner كود مصدر الفئة والوثائق المصاحبة. إذا كان لديك أي أسئلة أو طلبات ميزات أو تحتاج إلى مزيد من المساعدة، فلا تتردد في التواصل معنا على جيثب أو الخلاف.

الأسئلة الشائعة

كيف يمكنني تحسين معدل التعلّم Ultralytics YOLO أثناء ضبط المعلمة الفائقة؟

لتحسين معدل التعلم Ultralytics YOLO ، ابدأ بتعيين معدل تعلم أولي باستخدام lr0 البارامتر. تتراوح القيم الشائعة من 0.001 إلى 0.01. أثناء عملية ضبط البارامتر الفائق، سيتم تغيير هذه القيمة للعثور على الإعداد الأمثل. يمكنك الاستفادة من model.tune() لأتمتة هذه العملية. على سبيل المثال:

مثال على ذلك

from ultralytics import YOLO

# Initialize the YOLO model
model = YOLO("yolo11n.pt")

# Tune hyperparameters on COCO8 for 30 epochs
model.tune(data="coco8.yaml", epochs=30, iterations=300, optimizer="AdamW", plots=False, save=False, val=False)

لمزيد من التفاصيل، راجع صفحة التكوينUltralytics YOLO .

ما هي فوائد استخدام الخوارزميات الوراثية لضبط المعامل الفائق في YOLO11 ؟

توفر الخوارزميات الجينية في Ultralytics YOLO11 طريقة قوية لاستكشاف حيز المعلمات الفائقة، مما يؤدي إلى تحسين أداء النموذج بدرجة كبيرة. تشمل الفوائد الرئيسية ما يلي:

  • بحث فعال: يمكن للخوارزميات الوراثية مثل الطفرة أن تستكشف بسرعة مجموعة كبيرة من المعلمات الفائقة.
  • تجنب الحد الأدنى المحلي: من خلال إدخال العشوائية، فإنها تساعد في تجنب الحد الأدنى المحلي، مما يضمن تحسينًا عالميًا أفضل.
  • مقاييس الأداء: تتكيف بناءً على مقاييس الأداء مثل AP50 ودرجة F1.

لمعرفة كيف يمكن للخوارزميات الوراثية تحسين المعلمات الفائقة، راجع دليل تطور المعلمات الفائقة.

ما المدة التي تستغرقها عملية ضبط المعامل الفائق Ultralytics YOLO ؟

يعتمد الوقت اللازم لضبط المعلمة الفائقة باستخدام Ultralytics YOLO إلى حد كبير على عدة عوامل مثل حجم مجموعة البيانات، وتعقيد بنية النموذج، وعدد التكرارات، والموارد الحاسوبية المتاحة. على سبيل المثال، قد يستغرق ضبط YOLO11n على مجموعة بيانات مثل COCO8 لمدة 30 حقبة زمنية من عدة ساعات إلى أيام، اعتمادًا على الأجهزة.

لإدارة وقت الضبط بفعالية، حدد ميزانية ضبط واضحة مسبقًا(رابط القسم الداخلي). يساعد ذلك في تحقيق التوازن بين تخصيص الموارد وأهداف التحسين.

ما هي المقاييس التي يجب أن أستخدمها لتقييم أداء النموذج أثناء ضبط المعامل الفائق في YOLO ؟

عند تقييم أداء النموذج أثناء ضبط المعامل الفائق في YOLO ، يمكنك استخدام عدة مقاييس رئيسية:

  • AP50: متوسط الدقة عند عتبة وحدة القياس الدولية 0.50.
  • النتيجة F1: المتوسط التوافقي للدقة والاستدعاء.
  • الدقة والاسترجاع: مقاييس فردية تشير إلى دقة النموذج في تحديد الإيجابيات الحقيقية مقابل الإيجابيات الخاطئة والسلبيات الخاطئة.

تساعدك هذه المقاييس على فهم الجوانب المختلفة لأداء نموذجك. راجع دليل مقاييس الأداءUltralytics YOLO للحصول على نظرة عامة شاملة.

هل يمكنني استخدام Ultralytics HUB لضبط المعامل الفائق لنماذج YOLO ؟

نعم، يمكنك استخدام Ultralytics HUB لضبط المعامل التشعبي لنماذج YOLO . يوفر HUB نظامًا أساسيًا بدون تعليمات برمجية لتحميل مجموعات البيانات بسهولة، وتدريب النماذج، وإجراء ضبط المعلمة الفائقة بكفاءة. ويوفر تتبعًا وتصورًا في الوقت الفعلي لتقدم الضبط والنتائج.

استكشف المزيد حول استخدام Ultralytics HUB لضبط المعامل الفائق في وثائق التدريب السحابيUltralytics HUB Cloud Training.

📅 تم إنشاؤها منذ 1 سنة مضت ✏️ تم التحديث منذ 23 يومًا

التعليقات