صفحة 284 - كتاب إنترنت الأشياء - الصف 11 - الفصل 1 - المملكة العربية السعودية

الكتاب: كتاب إنترنت الأشياء - الصف 11 - الفصل 1 | المادة: إنترنت الأشياء | المرحلة: الصف 11 | الفصل الدراسي: 1

الدولة: المملكة العربية السعودية | المنهج: المنهج السعودي - وزارة التعليم

📚 معلومات الصفحة

الكتاب: كتاب إنترنت الأشياء - الصف 11 - الفصل 1 | المادة: إنترنت الأشياء | المرحلة: الصف 11 | الفصل الدراسي: 1

الدولة: المملكة العربية السعودية | المنهج: المنهج السعودي - وزارة التعليم

نوع المحتوى: درس تعليمي

📝 ملخص الصفحة

📚 البرنامج بشكله النهائي (Complete Code)

المفاهيم الأساسية

reset_can(): دالة تعيد تعيين عداد القمامة (`garbage_drops`) إلى الصفر وتغير حالة الحاوية (`can_full`) إلى غير ممتلئة.

خريطة المفاهيم

```markmap

7. الرسائل في إنترنت الأشياء

تصميم وبرمجة جهاز ذكي (صفحة 273)

مشروع: إدارة النفايات الذكية

#### المشكلة: اكتظاظ سكاني يؤدي لتراكم النفايات

#### الحل: استخدام حاويات نفايات ذكية

##### ترسل تنبيه عند الامتلاء

##### تحلل البيانات لتحسين العملية

#### التنفيذ: نموذج أولي لحاوية ذكية

##### يحسب متوسط مرات الاستخدام للوصول للسعة الكاملة

##### يرسل رسالة إلى وسيط (MQTT) عند كل استخدام

##### يرسل رسالة عند الامتلاء إلى متحكم النظام

#### التقنيات المستخدمة

##### متحكم أردوينو (Arduino)

##### برمجة باستخدام بروتوكول Firmata ولغة بايثون

##### منصة MQTT (مثل EMQX) لتوزيع الرسائل

مكونات وأدوات المشروع (صفحة 274)

الترانزستور الضوئي (Phototransistor)

#### الوظيفة: كشف الضوء وتحويله لإشارات كهربائية

#### الرمز التخطيطي: رمز ترانزستور مع سهمين باتجاه القاعدة

#### المظهر الفعلي: جسم بلاستيكي صغير بثلاثة أطراف ونافذة شفافة

مستشعر الإمالة (Tilt Sensor)

#### الوظيفة: قياس درجة الميل بالنسبة للجاذبية

#### الرمز التخطيطي: دائرة تحتوي على دوائر صغيرة تمثل آلية الكرة أو الزئبق

#### المظهر الفعلي: مكون مستطيل أسود بثلاثة أطراف

النموذج الأولي باستخدام الأردوينو (صفحة 275)

آلية عمل النموذج

#### مستشعر الإمالة: يسجل حدث الفتح/الإمالة في كل مرة.

#### الترانزستور الضوئي: يعمل كمستشعر عند الوصول إلى حد معين (يعني أن الحاوية مليئة).

المكونات المطلوبة

#### لوحة أردوينو أونو R3

#### لوحة توصيل الدوائر الصغيرة (Breadboard)

#### ترانزستور ضوئي

#### مستشعر إمالة

#### مقاومتان (1 كيلو أوم)

الاتصال ببسيط EMXQ العام (صفحة 276)

خطوات التثبيت والاتصال

#### 1. تثبيت تطبيق MQTTX

##### زيارة موقع: https://mqttx.app/

##### تنزيل أحدث إصدار وتشغيل المثبت

#### 2. تكوين الاتصال بالوسيط (EMQX)

##### فتح تطبيق MQTTX وإنشاء اتصال جديد

##### إدخال بيانات الاتصال:

###### الاسم (Name): مثال: desktop_connection

###### المضيف (Host): mqtt://broker.emqx.io

###### المنفذ (Port): 1883

دائرة الأردوينو (صفحة 277)

تثبيت المكونات

#### 1. لوحة أردوينو أونو R3

#### 2. لوحة توصيل الدوائر الصغيرة (Breadboard)

#### 3. مستشعر الضوء (Phototransistor)

#### 4. مستشعر الإمالة بأربعة أطراف (4-pin Tilt Sensor)

#### 5. مقاومتان (Resistor)

توصيل المكونات (صفحة 278)

توصيل الترانزستور الضوئي

#### 1. الباعث (Emitter) → الطرف التناظري A0 (سلك أصفر)

#### 2. المقاومة: طرف مع الباعث، والطرف الآخر → العمود السالب للوحة

#### 3. 5V من الأردوينو → المقاومة الموجبة للوحة (سلك أحمر)

#### 4. GND من الأردوينو → العمود السالب للوحة (سلك أسود)

#### 5. المجمع (Collector) → العمود الموجب للوحة

توصيل مستشعر الإمالة

#### 1. المقاومة الثانية → الطرف الثاني للمستشعر

#### 2. الطرف الثاني للمستشعر → الطرف الرقمي 3 للأردوينو (سلك أحمر)

#### 3. الطرف الرابع للمستشعر → العمود الموجب للوحة (سلك أحمر)

#### 4. المقاومة: طرف → العمود السالب للوحة (سلك أسود)

الدائرة بشكلها النهائي (صفحة 279)

الشكل النهائي للدائرة

#### شكل 7.16: مخطط تخطيطي للدائرة الكاملة

##### يوضح لوحة أردوينو أونو متصلة بلوحة توصيل

##### يظهر المكونات: مقاومة، LED، ترانزستور

##### يظهر أسلاك التوصيل (أحمر، أصفر، أخضر، أسود، برتقالي)

#### شكل 7.17: صورة فعلية للدائرة

##### تمثل الشكل الحقيقي للدائرة عند بنائها

##### تظهر المكونات نفسها في الواقع

#### شكل 7.18: توصيل الأطراف بالمكونات

##### يوضح كيفية توصيل مكونات محددة بأطراف الأردوينو

##### يظهر مكونًا مربعًا أسود

##### يظهر مكونًا دائريًا موصولًا بالطرف D3

##### يظهر مكونًا دائريًا موصولًا بالطرف A0

برمجة الأردوينو (صفحة 280)

إعداد بيئة البرمجة

#### 1. تشغيل بروتوكول StandardFirmata على الأردوينو

#### 2. تثبيت حزمة paho-mqtt في بايثون

##### الأمر: pip install paho-mqtt

#### 3. إنشاء ملف بايثون جديد (mqtt_arduino.py)

#### 4. استيراد المكتبات المطلوبة

##### datetime: لإنشاء طوابع زمنية

##### time: للتحكم في سير البرنامج

##### json: للعمل مع كائنات JSON

##### pyfirmata: للتواصل مع الأردوينو

##### paho.mqtt.client: لإنشاء عميل MQTT

#### 5. تعريف متغيرات عميل MQTT

##### CLIENT_ID: معرف العميل (مثال: "PUBLISHER_01")

##### MQTT_BROKER: عنوان الوسيط (مثال: "broker.emqx.io")

##### TOPIC: اسم الموضوع (مثال: "waste/drops")

##### PORT: منفذ الخادم الافتراضي (1883)

##### FLAG_CONNECTED: متغير إشارة للاتصال

تهيئة الاتصال وبرمجة المتغيرات (صفحة 281)

تهيئة الاتصال بالأردوينو

#### استخدام مكتبة pyfirmata للاتصال عبر منفذ معين (مثل COM4)

#### تحديد أطراف المستشعرات:

##### مستشعر الإضاءة: الطرف التناظري A0

##### مستشعر الإمالة: الطرف الرقمي 3

إنشاء متغيرات المشروع

#### can_full: متغير منطقي (True/False) يحدد ما إذا كانت الحاوية ممتلئة.

#### garbage_drops: عداد لتتبع عدد مرات الاستخدام (الإمالة).

إنشاء دالة لإعادة التعيين

#### reset_can(): تعيد تعيين متغيري can_full و garbage_drops إلى القيم الافتراضية عند امتلاء الحاوية.

إنشاء رسالة JSON (صفحة 282)

خطوات إنشاء الدالة publish_message()

#### 1. إنشاء متغير timestamp بتنسيق الوقت (مثال: "%H:%M:%S")

#### 2. إنشاء كائن قاموس (Dictionary) يحتوي على:

##### timestamp

##### garbage_drops

##### can_full

#### 3. تحويل القاموس إلى كائن JSON باستخدام json.dumps()

#### 4. نشر الرسالة إلى الموضوع المشترك (مثال: "waste/drops") عبر client.publish()

#### 5. التعامل مع الأخطاء المحتملة أثناء النشر

الاتصال بـ MQTT (صفحة 282)

إنشاء دالة معالج الأحداث on_connect()

#### الوظيفة: إرسال رسالة تأكيد إلى الواجهة الطرفية (Terminal) حول نجاح الاتصال أو فشله.

#### الوسيط rc: يرسل من خلال مكتبة paho ليعرض حالة الاتصال.

##### إذا كان rc == 0: الاتصال ناجح.

##### إذا كان rc != 0: الاتصال فاشل.

البرنامج الرئيسي (صفحة 283)

تهيئة عميل MQTT والاشتراك

#### تهيئة عميل MQTT باستخدام معرف العميل (CLIENT_ID).

#### ربط معالج الأحداث on_connect.

#### الاتصال بالوسيط (MQTT_BROKER) على المنفذ المحدد (PORT).

#### الاشتراك في الموضوع المحدد (TOPIC).

التكرار الرئيسي للبرنامج

#### قراءة قيم المستشعرات (light_value, tilt_value) بشكل مستمر.

#### طباعة القيم المقروءة وعداد القمامة (garbage_drops).

#### زيادة العداد (garbage_drops) عند حدوث إمالة (tilt_value == True).

#### إذا حدثت إمالة وكانت الحاوية ممتلئة (light_value <= 0.200):

##### تعيين can_full = True.

##### نشر رسالة عبر publish_message().

##### إعادة تعيين الحاوية عبر reset_can().

##### نشر رسالة أخرى.

#### الانتظار لمدة ثانية (time.sleep(1)) قبل التكرار التالي.

البرنامج بشكله النهائي (صفحة 284)

الكود الكامل

#### استيراد المكتبات:

##### datetime, time, json, pyfirmata, paho.mqtt.client

#### تعريف متغيرات عميل MQTT:

##### CLIENT_ID, MQTT_BROKER, TOPIC, PORT, FLAG_CONNECTED

#### تهيئة الاتصال بالأردوينو:

##### تحديد منفذ الاتصال (مثل 'COM4')

##### بدء مكرر (Iterator) للوحة

#### تحديد أطراف المستشعرات:

##### light_sensor_pin: الطرف التناظري A0

##### tilt_sensor_pin: الطرف الرقمي 3

#### تعريف متغيرات المشروع:

##### can_full: حالة امتلاء الحاوية

##### garbage_drops: عداد مرات الاستخدام

#### تعريف دالة reset_can():

##### إعادة تعيين garbage_drops = 0

##### إعادة تعيين can_full = False

```

نقاط مهمة

  • الصفحة تحتوي على الكود الكامل للبرنامج، بما في ذلك استيراد المكتبات، تعريف المتغيرات، تهيئة الاتصال بالأردوينو والمستشعرات، وتعريف دالة `reset_can()`.
  • دالة `reset_can()` تستخدم الكلمة المفتاحية `global` للوصول إلى المتغيرات `garbage_drops` و `can_full` وتعديل قيمتهما.

📋 المحتوى المنظم

📖 محتوى تعليمي مفصّل

نوع: محتوى تعليمي

from datetime import datetime import time import json import pyfirmata import paho.mqtt.client as mq # Variables to setup MQTT client CLIENT_ID = "PUBLISHER_01" # ID of the client MQTT_BROKER = "broker.emqx.io" # Address of the broker TOPIC = "waste/drops" # Topic to subscribe to PORT = 1883 # Default server port FLAG_CONNECTED = False # Connection flag board = pyfirmata.Arduino('COM4') # Specify communication port it = pyfirmata.util.Iterator(board) # Select the board to connect it.start() # Connect to board # Selecting the sensor pins light_sensor_pin = board.get_pin('a:0:i') tilt_sensor_pin = board.get_pin('d:3:i') can_full = False # Flag to indicate whether the can is full garbage_drops = 0 # Counter for the garbage drops def reset_can(): global garbage_drops # Access garbage_drops variable global can_full # Access can_full variable garbage_drops = 0 # Reset the counter to 0 can_full = False # Clear the can

نوع: محتوى تعليمي

وزارة التعليم Ministry of Education 2025 - 1447

📄 النص الكامل للصفحة

from datetime import datetime import time import json import pyfirmata import paho.mqtt.client as mq # Variables to setup MQTT client CLIENT_ID = "PUBLISHER_01" # ID of the client MQTT_BROKER = "broker.emqx.io" # Address of the broker TOPIC = "waste/drops" # Topic to subscribe to PORT = 1883 # Default server port FLAG_CONNECTED = False # Connection flag board = pyfirmata.Arduino('COM4') # Specify communication port it = pyfirmata.util.Iterator(board) # Select the board to connect it.start() # Connect to board # Selecting the sensor pins light_sensor_pin = board.get_pin('a:0:i') tilt_sensor_pin = board.get_pin('d:3:i') can_full = False # Flag to indicate whether the can is full garbage_drops = 0 # Counter for the garbage drops def reset_can(): global garbage_drops # Access garbage_drops variable global can_full # Access can_full variable garbage_drops = 0 # Reset the counter to 0 can_full = False # Clear the can وزارة التعليم Ministry of Education 2025 - 1447

🎴 بطاقات تعليمية للمراجعة

عدد البطاقات: 3 بطاقة لهذه الصفحة

في برنامج مراقبة سلة المهملات باستخدام إنترنت الأشياء، ما الغرض من المتغير `can_full`؟

  • أ) هو عداد لحساب عدد مرات إفراغ السلة.
  • ب) هو متغير يخزن عنوان بروكر MQTT.
  • ج) هو علم (flag) يشير إلى ما إذا كانت السلة ممتلئة أم لا.
  • د) هو دالة مسؤولة عن إعادة تعيين العداد.

الإجابة الصحيحة: c

الإجابة: هو علم (flag) يشير إلى ما إذا كانت السلة ممتلئة أم لا.

الشرح: 1. `can_full` هو متغير منطقي (boolean). 2. قيمته الافتراضية هي `False` (السلة غير ممتلئة). 3. عندما يصل عداد القمامة إلى حد معين، يتم تغيير قيمته إلى `True`. 4. يستخدم هذا العلم لتنفيذ إجراءات مثل إرسال تنبيه أو إعادة تعيين العداد.

تلميح: يتم استخدامه للتحكم في عملية إعادة تعيين العداد.

التصنيف: تعريف | المستوى: سهل

ما الغرض من الدالة `reset_can()` في نموذج برمجة سلة المهملات الذكية؟

  • أ) إرسال رسالة MQTT إلى البروكر للإعلان عن امتلاء السلة.
  • ب) إعادة تعيين عداد القمامة (`garbage_drops`) إلى الصفر ومسح حالة امتلاء السلة (`can_full`).
  • ج) فصل اتصال الأردوينو عن الحساسات.
  • د) تغيير رقم منفذ الاتصال بالبروكر MQTT.

الإجابة الصحيحة: b

الإجابة: إعادة تعيين عداد القمامة (`garbage_drops`) إلى الصفر ومسح حالة امتلاء السلة (`can_full`).

الشرح: 1. الدالة `reset_can()` تُعيد ضبط النظام بعد إفراغ السلة. 2. الخطوة الأولى: تعيين قيمة المتغير العالمي `garbage_drops` إلى 0. 3. الخطوة الثانية: تعيين قيمة المتغير العالمي `can_full` إلى `False`. 4. النتيجة: يصبح النظام جاهزاً لبدء عد جديد للقمامة.

تلميح: تؤثر هذه الدالة على متغيرين رئيسيين في البرنامج.

التصنيف: صيغة/خطوات | المستوى: متوسط

في سياق برمجة إنترنت الأشياء، ما معنى استخدام الكلمة المفتاحية `global` داخل دالة مثل `reset_can()`؟

  • أ) تعريف متغيرات جديدة يمكن استخدامها في أي جزء من البرنامج.
  • ب) استيراد مكتبات برمجية إضافية للدالة.
  • ج) تسمح للدالة بتعديل قيمة متغيرات تم تعريفها خارج نطاقها (في النطاق العام للبرنامج).
  • د) جعل الدالة تعمل بشكل أسرع عن طريق تحسين استخدام الذاكرة.

الإجابة الصحيحة: c

الإجابة: تسمح للدالة بتعديل قيمة متغيرات تم تعريفها خارج نطاقها (في النطاق العام للبرنامج).

الشرح: 1. المتغيرات `garbage_drops` و `can_full` عُرّفت خارج الدالة `reset_can()`. 2. داخل الدالة، تُستخدم `global` قبل اسم المتغير. 3. هذا يخبر المترجم أننا نريد الوصول إلى المتغير العام وتعديله، وليس إنشاء متغير محلي جديد. 4. بدون `global`، لن تتغير قيم المتغيرات الأصلية خارج الدالة.

تلميح: بدونها، قد ينشئ المترجم متغيراً محلياً جديداً بنفس الاسم.

التصنيف: مفهوم جوهري | المستوى: صعب