التحقق من صحة النموذج مع Ultralytics YOLO
مقدمة
يعد التحقق من الصحة خطوة حاسمة في مسار التعلم الآلي ، مما يسمح لك بتقييم جودة نماذجك المدربة. وضع فال في Ultralytics YOLOv8 يوفر مجموعة قوية من الأدوات والمقاييس لتقييم أداء نماذج اكتشاف الكائنات الخاصة بك. يعمل هذا الدليل كمورد كامل لفهم كيفية استخدام وضع Val بشكل فعال لضمان دقة نماذجك وموثوقيتها.
شاهد: Ultralytics وسائط البرنامج التعليمي: التحقق من الصحة
لماذا التحقق من الصحة مع Ultralytics YOLO?
إليك سبب استخدام YOLOv8وضع Val مفيد:
- دقة: احصل على مقاييس دقيقة مثل mAP50 وmAP75 وmAP50-95 لتقييم نموذجك بشكل شامل.
- مرفق: استخدم الميزات المضمنة التي تتذكر إعدادات التدريب ، مما يبسط عملية التحقق من الصحة.
- المرونه: تحقق من صحة النموذج الخاص بك بنفس مجموعات البيانات وأحجام الصور أو مختلفة.
- ضبط المعلمة الفائقة: استخدم مقاييس التحقق من الصحة لضبط نموذجك للحصول على أداء أفضل.
الميزات الرئيسية لوضع Val
هذه هي الوظائف البارزة التي تقدمها YOLOv8وضع فال:
- الإعدادات التلقائية: تتذكر النماذج تكوينات التدريب الخاصة بها للتحقق من صحتها بشكل مباشر.
- دعم متعدد المقاييس: قم بتقييم نموذجك بناء على مجموعة من مقاييس الدقة.
- CLI و Python واجهة برمجة التطبيقات: اختر من واجهة سطر الأوامر أو Python API بناء على تفضيلك للتحقق من الصحة.
- توافق البيانات: يعمل بسلاسة مع مجموعات البيانات المستخدمة أثناء مرحلة التدريب بالإضافة إلى مجموعات البيانات المخصصة.
بقشيش
- YOLOv8 تتذكر النماذج إعدادات التدريب الخاصة بها تلقائيا ، بحيث يمكنك التحقق من صحة نموذج بنفس حجم الصورة وعلى مجموعة البيانات الأصلية بسهولة باستخدام فقط
yolo val model=yolov8n.pt
أوmodel('yolov8n.pt').val()
أمثلة الاستخدام
التحقق من صحة المدربين YOLOv8n دقة النموذج على مجموعة بيانات COCO8. لا حاجة لتمرير أي حجة على أنها model
تحتفظ بتدريبها data
والحجج كسمات نموذجية. راجع قسم الوسيطات أدناه للحصول على قائمة كاملة بوسيطات التصدير.
مثل
from ultralytics import YOLO
# Load a model
model = YOLO("yolov8n.pt") # load an official model
model = YOLO("path/to/best.pt") # load a custom model
# Validate the model
metrics = model.val() # no arguments needed, dataset and settings remembered
metrics.box.map # map50-95
metrics.box.map50 # map50
metrics.box.map75 # map75
metrics.box.maps # a list contains map50-95 of each category
الحجج ل YOLO التحقق من صحة النموذج
عند التحقق من الصحة YOLO النماذج ، يمكن ضبط العديد من الحجج لتحسين عملية التقييم. تتحكم هذه الوسيطات في جوانب مثل حجم صورة الإدخال ومعالجة الدفعات وعتبات الأداء. فيما يلي تحليل مفصل لكل وسيطة لمساعدتك في تخصيص إعدادات التحقق من الصحة بشكل فعال.
جدال | نوع | افتراضي | وصف |
---|---|---|---|
data |
str |
None |
يحدد المسار إلى ملف تكوين مجموعة البيانات (على سبيل المثال، coco8.yaml ). يتضمن هذا الملف مسارات لبيانات التحقق من الصحة وأسماء الفئات وعدد الفئات. |
imgsz |
int |
640 |
يحدد حجم الصور المدخلة. يتم تغيير حجم جميع الصور إلى هذا البعد قبل المعالجة. |
batch |
int |
16 |
يضبط عدد الصور لكل دفعة. استخدام -1 للدفعات التلقائية، والتي يتم ضبطها تلقائيًا بناءً على توفر الذاكرة GPU . |
save_json |
bool |
False |
لو True ، يحفظ النتائج في ملف JSON لمزيد من التحليل أو التكامل مع الأدوات الأخرى. |
save_hybrid |
bool |
False |
لو True ، يحفظ إصدارا مختلطا من التسميات يجمع بين التعليقات التوضيحية الأصلية وتنبؤات النموذج الإضافية. |
conf |
float |
0.001 |
يعين الحد الأدنى للثقة للاكتشافات. يتم تجاهل الاكتشافات بثقة أقل من هذا الحد. |
iou |
float |
0.6 |
يضبط عتبة التقاطع عبر الاتحاد (IoU) للقمع غير الأقصى (NMS). يساعد في تقليل الاكتشافات المكررة. |
max_det |
int |
300 |
يحد من الحد الأقصى لعدد الاكتشافات لكل صورة. مفيد في المشاهد الكثيفة لمنع الاكتشافات المفرطة. |
half |
bool |
True |
يتيح الحوسبة بنصف الدقة (FP16) ، مما يقلل من استخدام الذاكرة ويحتمل أن يزيد السرعة بأقل تأثير على الدقة. |
device |
str |
None |
يحدد الجهاز للتحقق من صحته (cpu , cuda:0 إلخ). يتيح المرونة في استخدام الموارد CPU أو GPU . |
dnn |
bool |
False |
لو True ، يستخدم وحدة OpenCV DNN ل ONNX نموذج الاستدلال ، الذي يقدم بديلا ل PyTorch طرق الاستدلال. |
plots |
bool |
False |
عند الضبط على True ، يولد ويحفظ مخططات التنبؤات مقابل الحقيقة الأرضية للتقييم البصري لأداء النموذج. |
rect |
bool |
False |
لو True ، يستخدم الاستدلال المستطيل للتجميع وتقليل الحشو وربما زيادة السرعة والكفاءة. |
split |
str |
val |
يحدد تقسيم مجموعة البيانات المراد استخدامه للتحقق من الصحة (val , test أو train ). يتيح المرونة في اختيار شريحة البيانات لتقييم الأداء. |
يلعب كل من هذه الإعدادات دورا حيويا في عملية التحقق من الصحة ، مما يسمح بإجراء تقييم قابل للتخصيص وفعال ل YOLO نماذج. يمكن أن يساعد ضبط هذه المعلمات وفقا لاحتياجاتك ومواردك المحددة في تحقيق أفضل توازن بين الدقة والأداء.
مثال على التحقق من الصحة باستخدام الوسيطات
تعرض الأمثلة أدناه YOLO التحقق من صحة النموذج باستخدام وسيطات مخصصة في Python و CLI.
مثل
الأسئلة المتداولة
كيف يمكنني التحقق من صحة نموذج YOLOv8 الخاص بي باستخدام Ultralytics ؟
للتحقق من صحة نموذجك YOLOv8 ، يمكنك استخدام وضع Val الذي يوفره Ultralytics. على سبيل المثال، باستخدام واجهة برمجة التطبيقات Python ، يمكنك تحميل نموذج وتشغيل التحقق من الصحة باستخدام:
from ultralytics import YOLO
# Load a model
model = YOLO("yolov8n.pt")
# Validate the model
metrics = model.val()
print(metrics.box.map) # map50-95
بدلاً من ذلك، يمكنك استخدام واجهة سطر الأوامر (CLI):
لمزيد من التخصيص، يمكنك ضبط وسيطات مختلفة مثل imgsz
, batch
و conf
في الوضعين Python و CLI . تحقق من الحجج ل YOLO التحقق من صحة النموذج للاطلاع على القائمة الكاملة للمعلمات.
ما المقاييس التي يمكنني الحصول عليها من التحقق من صحة النموذج YOLOv8 ؟
YOLOv8 يوفر التحقق من صحة النموذج عدة مقاييس رئيسية لتقييم أداء النموذج. وتشمل هذه المقاييس ما يلي:
- mAP50 (متوسط متوسط الدقة عند عتبة وحدة القياس الدولية 0.5)
- mAP75 (متوسط متوسط الدقة عند عتبة وحدة القياس الدولية 0.75)
- mAP50-95 (متوسط متوسط الدقة عبر عتبات IoU المتعددة من 0.5 إلى 0.95)
باستخدام واجهة برمجة التطبيقات Python ، يمكنك الوصول إلى هذه المقاييس على النحو التالي:
metrics = model.val() # assumes `model` has been loaded
print(metrics.box.map) # mAP50-95
print(metrics.box.map50) # mAP50
print(metrics.box.map75) # mAP75
print(metrics.box.maps) # list of mAP50-95 for each category
للحصول على تقييم كامل للأداء، من الضروري مراجعة جميع هذه المقاييس. لمزيد من التفاصيل، راجع الميزات الرئيسية لوضع فال.
ما هي مزايا استخدام Ultralytics YOLO للتحقق من الصحة؟
يوفر استخدام Ultralytics YOLO للتحقق من الصحة عدة مزايا:
- الدقة: YOLOv8 تقدم مقاييس أداء دقيقة بما في ذلك mAP50 و mAP75 و mAP50-95.
- الملاءمة: تتذكر النماذج إعدادات التدريب الخاصة بها، مما يجعل التحقق من صحتها أمراً سهلاً ومباشراً.
- المرونة: يمكنك التحقق من الصحة مقابل نفس مجموعات البيانات وأحجام الصور أو مجموعات بيانات مختلفة.
- ضبط المقياس الفائق: تساعد مقاييس التحقق من الصحة في ضبط النماذج لتحسين الأداء.
تضمن هذه المزايا أن يتم تقييم النماذج الخاصة بك بدقة ويمكن تحسينها للحصول على نتائج فائقة. تعرف على المزيد حول هذه المزايا في قسم لماذا التحقق من الصحة باستخدام Ultralytics YOLO .
هل يمكنني التحقق من صحة نموذج YOLOv8 الخاص بي باستخدام مجموعة بيانات مخصصة؟
نعم، يمكنك التحقق من صحة نموذج YOLOv8 الخاص بك باستخدام مجموعة بيانات مخصصة. حدد data
مع المسار إلى ملف تكوين مجموعة البيانات الخاصة بك. يجب أن يتضمن هذا الملف مسارات بيانات التحقق من الصحة وأسماء الفئات والتفاصيل الأخرى ذات الصلة.
مثال في Python:
from ultralytics import YOLO
# Load a model
model = YOLO("yolov8n.pt")
# Validate with a custom dataset
metrics = model.val(data="path/to/your/custom_dataset.yaml")
print(metrics.box.map) # map50-95
مثال باستخدام CLI:
للمزيد من الخيارات القابلة للتخصيص أثناء التحقق من الصحة، راجع قسم مثال التحقق من الصحة بالحجج.
كيف يمكنني حفظ نتائج التحقق من الصحة في ملف JSON في YOLOv8 ؟
لحفظ نتائج التحقق من الصحة في ملف JSON، يمكنك تعيين save_json
حجة ل True
عند تشغيل التحقق من الصحة. يمكن القيام بذلك في كل من Python API و CLI.
مثال في Python:
from ultralytics import YOLO
# Load a model
model = YOLO("yolov8n.pt")
# Save validation results to JSON
metrics = model.val(save_json=True)
مثال باستخدام CLI:
هذه الوظيفة مفيدة بشكل خاص لمزيد من التحليل أو التكامل مع أدوات أخرى. راجع الحجج الخاصة بالتحقق من صحة النموذج YOLO لمزيد من التفاصيل.