عمليات الاستدعاء
عمليات الاستدعاء
Ultralytics يدعم إطار العمل عمليات رد النداء كنقاط دخول في المراحل الاستراتيجية لأوضاع القطار، و val، والتصدير، والتنبؤ. كل رد استدعاء يقبل Trainer
, Validator
أو Predictor
بناءً على نوع العملية. يمكن العثور على جميع خصائص هذه الكائنات في القسم المرجعي من المستندات.
شاهد: إتقان Ultralytics YOLO : عمليات الاسترداد : عمليات الاسترداد
أمثلة
إرجاع معلومات إضافية مع التنبؤ
في هذا المثال، نريد إرجاع الإطار الأصلي مع كل كائن نتيجة. إليك كيفية القيام بذلك
from ultralytics import YOLO
def on_predict_batch_end(predictor):
"""Handle prediction batch end by combining results with corresponding frames; modifies predictor results."""
_, image, _, _ = predictor.batch
# Ensure that image is a list
image = image if isinstance(image, list) else [image]
# Combine the prediction results with the corresponding frames
predictor.results = zip(predictor.results, image)
# Create a YOLO model instance
model = YOLO("yolo11n.pt")
# Add the custom callback to the model
model.add_callback("on_predict_batch_end", on_predict_batch_end)
# Iterate through the results and frames
for result, frame in model.predict(): # or model.track()
pass
جميع عمليات الاستدعاء
فيما يلي جميع عمليات الاستدعاء المدعومة. انظر التعليمات البرمجية المصدرية لردود النداء للحصول على تفاصيل إضافية.
استدعاءات المدربين
معاودة الاتصال | الوصف |
---|---|
on_pretrain_routine_start |
يتم تشغيله في بداية روتين ما قبل التدريب |
on_pretrain_routine_end |
يتم تشغيله في نهاية روتين ما قبل التدريب |
on_train_start |
يتم تشغيله عند بدء التدريب |
on_train_epoch_start |
يتم تشغيله في بداية كل حقبة تدريبية |
on_train_batch_start |
يتم تشغيله في بداية كل دفعة تدريبية |
optimizer_step |
يتم تشغيله أثناء خطوة المُحسِّن |
on_before_zero_grad |
يتم تشغيله قبل تصفير التدرجات |
on_train_batch_end |
يتم تشغيله في نهاية كل دفعة تدريبية |
on_train_epoch_end |
يتم تشغيله في نهاية كل حقبة تدريبية |
on_fit_epoch_end |
يتم تشغيله في نهاية كل حقبة زمنية ملائمة |
on_model_save |
يتم تشغيله عند حفظ النموذج |
on_train_end |
يتم تشغيله عند انتهاء عملية التدريب |
on_params_update |
يتم تشغيله عند تحديث معلمات النموذج |
teardown |
يتم تشغيلها عندما يتم تنظيف عملية التدريب |
استدعاءات المصادقة
معاودة الاتصال | الوصف |
---|---|
on_val_start |
يتم تشغيله عند بدء التحقق من الصحة |
on_val_batch_start |
يتم تشغيله في بداية كل دفعة تحقق من الصحة |
on_val_batch_end |
يتم تشغيله في نهاية كل دفعة تحقق من الصحة |
on_val_end |
يتم تشغيله عند انتهاء التحقق من الصحة |
عمليات استدعاء المتنبئ
معاودة الاتصال | الوصف |
---|---|
on_predict_start |
يتم تشغيله عند بدء عملية التنبؤ |
on_predict_batch_start |
يتم تشغيله في بداية كل دفعة تنبؤات |
on_predict_postprocess_end |
يتم تشغيله في نهاية المعالجة اللاحقة للتنبؤ |
on_predict_batch_end |
يتم تشغيله في نهاية كل دفعة تنبؤات |
on_predict_end |
يتم تشغيله عند انتهاء عملية التنبؤ |
عمليات استدعاء المصدرين
معاودة الاتصال | الوصف |
---|---|
on_export_start |
يتم تشغيله عند بدء عملية التصدير |
on_export_end |
يتم تشغيله عند انتهاء عملية التصدير |
الأسئلة الشائعة
ما هي عمليات الاسترجاع Ultralytics وكيف يمكنني استخدامها؟
Ultralytics عمليات الاستدعاء هي نقاط دخول متخصصة يتم تشغيلها أثناء المراحل الرئيسية لعمليات النموذج مثل التدريب والتحقق من الصحة والتصدير والتنبؤ. تسمح عمليات الاستدعاء هذه بوظائف مخصصة في نقاط محددة في العملية، مما يتيح إجراء تحسينات وتعديلات على سير العمل. يقبل كل رد استدعاء Trainer
, Validator
أو Predictor
بناءً على نوع العملية. للاطلاع على الخصائص التفصيلية لهذه الكائنات، ارجع إلى القسم المرجعي.
لاستخدام رد الاستدعاء، يمكنك تحديد دالة ثم إضافتها إلى النموذج باستخدام add_callback
الطريقة. إليك مثال على كيفية إرجاع معلومات إضافية أثناء التنبؤ:
from ultralytics import YOLO
def on_predict_batch_end(predictor):
"""Handle prediction batch end by combining results with corresponding frames; modifies predictor results."""
_, image, _, _ = predictor.batch
image = image if isinstance(image, list) else [image]
predictor.results = zip(predictor.results, image)
model = YOLO("yolo11n.pt")
model.add_callback("on_predict_batch_end", on_predict_batch_end)
for result, frame in model.predict():
pass
كيف يمكنني تخصيص روتين التدريب Ultralytics باستخدام عمليات الاسترجاع؟
لتخصيص روتين التدريب Ultralytics الخاص بك باستخدام عمليات الاستدعاء، يمكنك حقن منطقك في مراحل محددة من عملية التدريب. Ultralytics YOLO يوفر مجموعة متنوعة من عمليات استدعاء التدريب مثل on_train_start
, on_train_end
و on_train_batch_end
. هذه تسمح لك بإضافة مقاييس مخصصة أو معالجة أو تسجيل.
Here's an example of how to freeze BatchNorm statistics when freezing layers with callbacks:
from ultralytics import YOLO
# Add a callback to put the frozen layers in eval mode to prevent BN values from changing
def put_in_eval_mode(trainer):
n_layers = trainer.args.freeze
if not isinstance(n_layers, int):
return
for i, (name, module) in enumerate(trainer.model.named_modules()):
if name.endswith("bn") and int(name.split(".")[1]) < n_layers:
module.eval()
module.track_running_stats = False
model = YOLO("yolo11n.pt")
model.add_callback("on_train_epoch_start", put_in_eval_mode)
model.train(data="coco.yaml", epochs=10)
ارجع إلى دليل التدريب للحصول على مزيد من التفاصيل حول كيفية استخدام عمليات رد الاستدعاء للتدريب بفعالية.
لماذا يجب استخدام عمليات الاسترجاع أثناء التحقق من الصحة في Ultralytics YOLO ؟
استخدام عمليات الاستدعاء أثناء التحقق من الصحة في Ultralytics YOLO تحسين تقييم النموذج من خلال السماح بمعالجة مخصصة أو تسجيل أو حساب المقاييس. عمليات الاستدعاء مثل on_val_start
, on_val_batch_end
و on_val_end
توفير نقاط دخول لإدخال منطق مخصص، مما يضمن عمليات تحقق مفصلة وشاملة.
For instance, you might want to plot all the validation batches, instead of just the first 3. Here's how you can do that:
import inspect
from ultralytics import YOLO
def plot_samples(validator):
frame = inspect.currentframe().f_back.f_back
v = frame.f_locals
validator.plot_val_samples(v["batch"], v["batch_i"])
validator.plot_predictions(v["batch"], v["preds"], v["batch_i"])
model = YOLO("yolo11n.pt")
model.add_callback("on_val_batch_end", plot_samples)
model.val(data="coco.yaml")
راجع دليل التحقق من الصحة للحصول على مزيد من الأفكار حول دمج عمليات الاسترجاع في عملية التحقق من الصحة.
كيف يمكنني إرفاق رد استدعاء مخصص لوضع التنبؤ في Ultralytics YOLO ؟
لإرفاق رد استدعاء مخصص لـ وضع التنبؤ في Ultralytics YOLO ، تقوم بتعريف دالة رد نداء وتسجيلها في عملية التنبؤ. تتضمن عمليات استدعاء التنبؤ الشائعة ما يلي on_predict_start
, on_predict_batch_end
و on_predict_end
. تسمح بتعديل مخرجات التنبؤ ودمج وظائف إضافية مثل تسجيل البيانات أو تحويل النتائج.
Here is an example where a custom callback is used to save predictions based on whether an object of a particular class is present:
from ultralytics import YOLO
model = YOLO("yolo11n.pt")
class_id = 2
def save_on_object(predictor):
r = predictor.results[0]
if class_id in r.boxes.cls:
predictor.args.save = True
else:
predictor.args.save = False
model.add_callback("on_predict_postprocess_end", save_on_object)
results = model("pedestrians.mp4", stream=True, save=True)
for results in results:
pass
لمزيد من الاستخدام الشامل، راجع دليل التنبؤ الذي يتضمن تعليمات مفصلة وخيارات تخصيص إضافية.
ما هي بعض الأمثلة العملية لاستخدام عمليات الاسترجاع في Ultralytics YOLO ؟
Ultralytics YOLO يدعم العديد من التطبيقات العملية لعمليات الاسترجاع لتحسين وتخصيص مراحل مختلفة مثل التدريب والتحقق من الصحة والتنبؤ. تتضمن بعض الأمثلة العملية ما يلي:
- تسجيل المقاييس المخصصة: تسجيل مقاييس إضافية في مراحل مختلفة، مثل نهاية مراحل التدريب أو التحقق من الصحة.
- زيادة البيانات: تنفيذ عمليات تحويل أو زيادة بيانات مخصصة أثناء التنبؤ أو دفعات التدريب.
- النتائج الوسيطة: احفظ النتائج الوسيطة مثل التنبؤات أو الإطارات لمزيد من التحليل أو التصور.
مثال: دمج الإطارات مع نتائج التنبؤ أثناء التنبؤ باستخدام on_predict_batch_end
:
from ultralytics import YOLO
def on_predict_batch_end(predictor):
"""Combine prediction results with frames."""
_, image, _, _ = predictor.batch
image = image if isinstance(image, list) else [image]
predictor.results = zip(predictor.results, image)
model = YOLO("yolo11n.pt")
model.add_callback("on_predict_batch_end", on_predict_batch_end)
for result, frame in model.predict():
pass
استكشف مرجع رد الاتصال الكامل للعثور على المزيد من الخيارات والأمثلة.