انتقل إلى المحتوى

الاستدلال الآمن للخيط مع YOLO نماذج

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

فهم Python التخييط

Python مؤشرات الترابط هي شكل من أشكال التوازي الذي يسمح لبرنامجك بتشغيل عمليات متعددة في وقت واحد. لكن Pythonقفل المترجم العالمي (GIL) يعني أنه يمكن تنفيذ مؤشر ترابط واحد فقط Python رمز بايت في وقت واحد.

أمثلة فردية مقابل متعددة الخيوط

على الرغم من أن هذا يبدو وكأنه قيد ، إلا أنه لا يزال بإمكان مؤشرات الترابط توفير التزامن ، خاصة بالنسبة للعمليات المرتبطة بالإدخال / الإخراج أو عند استخدام العمليات التي تحرر GIL ، مثل تلك التي يتم إجراؤها بواسطة YOLOمكتبات C الأساسية.

خطر مثيلات النموذج المشترك

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

مثال غير آمن لمؤشر الترابط: مثيل نموذج واحد

عند استخدام المواضيع في Python، من المهم التعرف على الأنماط التي يمكن أن تؤدي إلى مشكلات التزامن. إليك ما يجب عليك تجنبه: مشاركة واحدة YOLO مثيل النموذج عبر سلاسل رسائل متعددة.

# Unsafe: Sharing a single model instance across threads
from threading import Thread

from ultralytics import YOLO

# Instantiate the model outside the thread
shared_model = YOLO("yolov8n.pt")


def predict(image_path):
    """Predicts objects in an image using a preloaded YOLO model, take path string to image as argument."""
    results = shared_model.predict(image_path)
    # Process results


# Starting threads that share the same model instance
Thread(target=predict, args=("image1.jpg",)).start()
Thread(target=predict, args=("image2.jpg",)).start()

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

مثال غير آمن لمؤشر الترابط: مثيلات نموذج متعددة

وبالمثل ، هنا نمط غير آمن مع متعددة YOLO مثيلات النموذج:

# Unsafe: Sharing multiple model instances across threads can still lead to issues
from threading import Thread

from ultralytics import YOLO

# Instantiate multiple models outside the thread
shared_model_1 = YOLO("yolov8n_1.pt")
shared_model_2 = YOLO("yolov8n_2.pt")


def predict(model, image_path):
    """Runs prediction on an image using a specified YOLO model, returning the results."""
    results = model.predict(image_path)
    # Process results


# Starting threads with individual model instances
Thread(target=predict, args=(shared_model_1, "image1.jpg")).start()
Thread(target=predict, args=(shared_model_2, "image2.jpg")).start()

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

الاستدلال الآمن للخيط

لإجراء استدلال آمن لمؤشر الترابط ، يجب إنشاء مثيل منفصل YOLO نموذج داخل كل موضوع. هذا يضمن أن كل مؤشر ترابط له مثيل نموذج معزول خاص به ، مما يلغي مخاطر ظروف العرق.

مثال على الخيط الآمن

فيما يلي كيفية إنشاء مثيل ل YOLO نموذج داخل كل مؤشر ترابط للاستدلال المتوازي الآمن:

# Safe: Instantiating a single model inside each thread
from threading import Thread

from ultralytics import YOLO


def thread_safe_predict(image_path):
    """Predict on an image using a new YOLO model instance in a thread-safe manner; takes image path as input."""
    local_model = YOLO("yolov8n.pt")
    results = local_model.predict(image_path)
    # Process results


# Starting threads that each have their own model instance
Thread(target=thread_safe_predict, args=("image1.jpg",)).start()
Thread(target=thread_safe_predict, args=("image2.jpg",)).start()

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

استنتاج

عند استخدام YOLO نماذج مع Python's threading، قم دائما بإنشاء مثيل للنماذج الخاصة بك داخل مؤشر الترابط الذي سيستخدمها لضمان سلامة مؤشر الترابط. تتجنب هذه الممارسة ظروف السباق وتتأكد من أن مهام الاستدلال الخاصة بك تعمل بشكل موثوق.

لمزيد من السيناريوهات المتقدمة ولزيادة تحسين أداء الاستدلال متعدد مؤشرات الترابط ، ضع في اعتبارك استخدام التوازي المستند إلى العملية مع multiprocessing أو الاستفادة من قائمة انتظار المهام مع عمليات العمال المخصصة.

الأسئلة المتداولة

كيف يمكنني تجنب حالات السباق عند استخدام نماذج YOLO في بيئة Python متعددة الخيوط؟

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

مثل:

from threading import Thread

from ultralytics import YOLO


def thread_safe_predict(image_path):
    """Predict on an image in a thread-safe manner."""
    local_model = YOLO("yolov8n.pt")
    results = local_model.predict(image_path)
    # Process results


Thread(target=thread_safe_predict, args=("image1.jpg",)).start()
Thread(target=thread_safe_predict, args=("image2.jpg",)).start()

لمزيد من المعلومات حول ضمان سلامة الخيط، قم بزيارة الاستدلال الآمن للخيوط باستخدام نماذج YOLO .

ما هي أفضل الممارسات لتشغيل استدلال نموذج YOLO متعدد الخيوط في Python ؟

لتشغيل استدلال نموذج YOLO متعدد الخيوط بأمان في Python ، اتبع أفضل الممارسات التالية:

  1. قم بتثبيت النماذج YOLO داخل كل مؤشر ترابط بدلاً من مشاركة مثيل نموذج واحد عبر مؤشرات الترابط.
  2. استخدم Python multiprocessing وحدة للمعالجة المتوازية لتجنب المشكلات المتعلقة بالقفل العالمي للمترجم الفوري (GIL).
  3. حرر GIL باستخدام العمليات التي تقوم بها مكتبات C الأساسية YOLO.

مثال على إنشاء النموذج الآمن من الخيط:

from threading import Thread

from ultralytics import YOLO


def thread_safe_predict(image_path):
    """Runs inference in a thread-safe manner with a new YOLO model instance."""
    model = YOLO("yolov8n.pt")
    results = model.predict(image_path)
    # Process results


# Initiate multiple threads
Thread(target=thread_safe_predict, args=("image1.jpg",)).start()
Thread(target=thread_safe_predict, args=("image2.jpg",)).start()

للحصول على سياق إضافي، ارجع إلى القسم الخاص بالاستدلال الآمن الترابطي.

لماذا يجب أن يكون لكل مؤشر ترابط مثيل نموذج YOLO خاص به؟

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

للحصول على إرشادات مفصّلة، راجع المثال غير الآمن للتسلسل اللولبي: قسم المثال أحادي النموذج وقسم المثال الآمن الخيطي.

كيف يؤثر قفل المفسر العالمي (GIL) Python على الاستدلال على نموذج YOLO ؟

Pythonيسمح القفل العالمي للمترجم التفسيري (GIL) لمؤشر ترابط واحد فقط بتنفيذ التعليمات البرمجية Python في كل مرة، مما قد يحد من أداء المهام متعددة الخيوط المرتبطة بالإدخال/الإخراج CPU. ومع ذلك، بالنسبة للعمليات المرتبطة بالإدخال/الإخراج أو العمليات التي تستخدم مكتبات تحرر GIL، مثل مكتبات C YOLO ، لا يزال بإمكانك تحقيق التزامن. لتحسين الأداء، ضع في اعتبارك استخدام التوازي القائم على المعالجة مع Python's multiprocessing الوحدة النمطية.

لمزيد من المعلومات حول الترابط في Python ، راجع قسم فهم الترابط Python .

هل من الآمن استخدام التوازي القائم على المعالجة بدلاً من الترابط لاستدلال نموذج YOLO ؟

نعم، باستخدام Python multiprocessing أكثر أمانًا وأكثر كفاءة في كثير من الأحيان لتشغيل استنتاج نموذج YOLO بالتوازي. ينشئ التوازي القائم على المعالجة مساحات ذاكرة منفصلة، مما يؤدي إلى تجنب قفل المترجم العالمي (GIL) وتقليل مخاطر مشاكل التزامن. ستعمل كل عملية بشكل مستقل مع مثيل نموذج YOLO الخاص بها.

لمزيد من التفاصيل حول التوازي القائم على العمليات مع نماذج YOLO ، راجع الصفحة الخاصة بالاستدلال الآمن الترابطي.


📅 Created 10 months ago ✏️ Updated 20 days ago

التعليقات