مشروع نظام الإنذار الأمني باستخدام Ultralytics YOLO11
يدمج مشروع نظام الإنذار الأمني الذي يستخدم Ultralytics YOLO11 قدرات الرؤية الحاسوبية المتقدمة لتعزيز التدابير الأمنية. YOLO11 Ultralytics ، الذي تم تطويره من قبل ، يوفر الكشف عن الأجسام في الوقت الحقيقي، مما يسمح للنظام بتحديد التهديدات الأمنية المحتملة والاستجابة لها على الفور. يقدم هذا المشروع العديد من المزايا:
- الكشف في الوقت الحقيقي: تمكّن كفاءة YOLO11 نظام الإنذار الأمني من الكشف عن الحوادث الأمنية والاستجابة لها في الوقت الحقيقي، مما يقلل من وقت الاستجابة.
- الدقة: YOLO11 معروف بدقته في اكتشاف الأجسام، مما يقلل من الإيجابيات الخاطئة ويعزز موثوقية نظام الإنذار الأمني.
- قدرات التكامل: يمكن دمج المشروع بسلاسة مع البنية التحتية الأمنية الحالية، مما يوفر طبقة مطورة من المراقبة الذكية.
شاهد: مشروع نظام الإنذار الأمني مع Ultralytics YOLO11 اكتشاف الكائن
الكود
إعداد معلمات الرسالة
ملاحظة
إنشاء كلمة مرور التطبيق ضروري
- انتقل إلى منشئ كلمة مرور التطبيق، وحدد اسم التطبيق مثل "مشروع الأمان"، واحصل على كلمة مرور مكونة من 16 رقمًا. انسخ كلمة المرور هذه وألصقها في حقل كلمة المرور المخصص حسب التعليمات.
password = ""
from_email = "" # must match the email used to generate the password
to_email = "" # receiver email
إنشاء الخادم والمصادقة عليه
import smtplib
server = smtplib.SMTP("smtp.gmail.com: 587")
server.starttls()
server.login(from_email, password)
وظيفة إرسال البريد الإلكتروني
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
def send_email(to_email, from_email, object_detected=1):
"""Sends an email notification indicating the number of objects detected; defaults to 1 object."""
message = MIMEMultipart()
message["From"] = from_email
message["To"] = to_email
message["Subject"] = "Security Alert"
# Add in the message body
message_body = f"ALERT - {object_detected} objects has been detected!!"
message.attach(MIMEText(message_body, "plain"))
server.sendmail(from_email, to_email, message.as_string())
كشف الكائنات ومرسل التنبيهات
from time import time
import cv2
import torch
from ultralytics import YOLO
from ultralytics.utils.plotting import Annotator, colors
class ObjectDetection:
def __init__(self, capture_index):
"""Initializes an ObjectDetection instance with a given camera index."""
self.capture_index = capture_index
self.email_sent = False
# model information
self.model = YOLO("yolo11n.pt")
# visual information
self.annotator = None
self.start_time = 0
self.end_time = 0
# device information
self.device = "cuda" if torch.cuda.is_available() else "cpu"
def predict(self, im0):
"""Run prediction using a YOLO model for the input image `im0`."""
results = self.model(im0)
return results
def display_fps(self, im0):
"""Displays the FPS on an image `im0` by calculating and overlaying as white text on a black rectangle."""
self.end_time = time()
fps = 1 / round(self.end_time - self.start_time, 2)
text = f"FPS: {int(fps)}"
text_size = cv2.getTextSize(text, cv2.FONT_HERSHEY_SIMPLEX, 1.0, 2)[0]
gap = 10
cv2.rectangle(
im0,
(20 - gap, 70 - text_size[1] - gap),
(20 + text_size[0] + gap, 70 + gap),
(255, 255, 255),
-1,
)
cv2.putText(im0, text, (20, 70), cv2.FONT_HERSHEY_SIMPLEX, 1.0, (0, 0, 0), 2)
def plot_bboxes(self, results, im0):
"""Plots bounding boxes on an image given detection results; returns annotated image and class IDs."""
class_ids = []
self.annotator = Annotator(im0, 3, results[0].names)
boxes = results[0].boxes.xyxy.cpu()
clss = results[0].boxes.cls.cpu().tolist()
names = results[0].names
for box, cls in zip(boxes, clss):
class_ids.append(cls)
self.annotator.box_label(box, label=names[int(cls)], color=colors(int(cls), True))
return im0, class_ids
def __call__(self):
"""Run object detection on video frames from a camera stream, plotting and showing the results."""
cap = cv2.VideoCapture(self.capture_index)
assert cap.isOpened()
cap.set(cv2.CAP_PROP_FRAME_WIDTH, 640)
cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 480)
frame_count = 0
while True:
self.start_time = time()
ret, im0 = cap.read()
assert ret
results = self.predict(im0)
im0, class_ids = self.plot_bboxes(results, im0)
if len(class_ids) > 0: # Only send email If not sent before
if not self.email_sent:
send_email(to_email, from_email, len(class_ids))
self.email_sent = True
else:
self.email_sent = False
self.display_fps(im0)
cv2.imshow("YOLO11 Detection", im0)
frame_count += 1
if cv2.waitKey(5) & 0xFF == 27:
break
cap.release()
cv2.destroyAllWindows()
server.quit()
استدعاء فئة اكتشاف الكائنات وتشغيل الاستدلال
هذا كل شيء! عند تنفيذ الشيفرة، ستتلقى إشعارًا واحدًا على بريدك الإلكتروني إذا تم اكتشاف أي كائن. يتم إرسال الإشعار على الفور وليس بشكل متكرر. ومع ذلك، لا تتردد في تخصيص الشيفرة البرمجية لتناسب متطلبات مشروعك.
نموذج البريد الإلكتروني المستلم
الأسئلة الشائعة
كيف يعمل Ultralytics YOLO11 على تحسين دقة نظام الإنذار الأمني؟
Ultralytics YOLO11 يعزز أنظمة الإنذار الأمني من خلال توفير دقة عالية في الوقت الحقيقي للكشف عن الأجسام في الوقت الحقيقي. وتقلل خوارزمياته المتقدمة بشكل كبير من الإيجابيات الخاطئة، مما يضمن استجابة النظام للتهديدات الحقيقية فقط. يمكن دمج هذه الموثوقية المتزايدة بسلاسة مع البنية التحتية الأمنية الحالية، مما يرفع من جودة المراقبة الشاملة.
هل يمكنني دمج Ultralytics YOLO11 مع البنية التحتية الأمنية الموجودة لديّ؟
نعم، يمكن دمج Ultralytics YOLO11 بسلاسة مع البنية التحتية الأمنية الموجودة لديك. يدعم النظام أوضاعًا مختلفة ويوفر مرونة في التخصيص، مما يسمح لك بتعزيز الإعدادات الحالية لديك بقدرات متقدمة للكشف عن الكائنات. للحصول على إرشادات مفصلة حول دمج YOLO11 في مشاريعك، تفضل بزيارة قسم التكامل.
ما هي متطلبات التخزين لتشغيل Ultralytics YOLO11 ؟
عادةً ما يتطلب تشغيل Ultralytics YOLO11 على إعداد قياسي حوالي 5 جيجابايت من مساحة القرص الحرة. يتضمن ذلك مساحة لتخزين نموذج YOLO11 وأي تبعيات إضافية. بالنسبة للحلول المستندة إلى السحابة، يوفر Ultralytics HUB إدارة فعالة للمشروع ومعالجة مجموعة البيانات، والتي يمكن أن تحسن احتياجات التخزين. تعرّف على المزيد حول خطة Pro Plan للحصول على ميزات محسّنة بما في ذلك التخزين الموسع.
ما الذي يجعل Ultralytics YOLO11 مختلفاً عن نماذج اكتشاف الأجسام الأخرى مثل Faster R-CNN أو SSD؟
Ultralytics YOLO11 يوفر ميزة على طرازات مثل Faster R-CNN أو SSD بقدراته على الكشف في الوقت الحقيقي ودقة أعلى. تسمح له بنيته الفريدة بمعالجة الصور بشكل أسرع بكثير دون المساومة على الدقة، مما يجعله مثاليًا للتطبيقات الحساسة للوقت مثل أنظمة الإنذار الأمني. للحصول على مقارنة شاملة لنماذج اكتشاف الأجسام، يمكنك استكشاف دليلنا.
كيف يمكنني تقليل تكرار الإيجابيات الخاطئة في نظام الأمان الخاص بي باستخدام Ultralytics YOLO11 ؟
لتقليل النتائج الإيجابية الكاذبة، تأكد من أن نموذج Ultralytics YOLO11 الخاص بك مدرب بشكل كافٍ باستخدام مجموعة بيانات متنوعة ومشروحة بشكل جيد. يمكن أن يؤدي ضبط المعلمات التشعبية وتحديث النموذج بانتظام ببيانات جديدة إلى تحسين دقة الكشف بشكل كبير. يمكن العثور على تقنيات الضبط التفصيلي للمعاملات الفائقة في دليل ضبط المعلمات الفائقة الخاص بنا.