You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
IoT-For-Beginners/translations/my/2-farm/lessons/1-predict-plant-growth/single-board-computer-temp-...

71 lines
6.9 KiB

<!--
CO_OP_TRANSLATOR_METADATA:
{
"original_hash": "4efc74299e19f5d08f2f3f34451a11ba",
"translation_date": "2025-08-28T18:10:18+00:00",
"source_file": "2-farm/lessons/1-predict-plant-growth/single-board-computer-temp-publish.md",
"language_code": "my"
}
-->
# အပူချိန်ကို ထုတ်ဝေခြင်း - Virtual IoT Hardware နှင့် Raspberry Pi
ဒီသင်ခန်းစာရဲ့ အပိုင်းမှာတော့ Raspberry Pi သို့မဟုတ် Virtual IoT Device က ရှာဖွေတွေ့ရှိထားတဲ့ အပူချိန်တန်ဖိုးတွေကို MQTT ကနေ ထုတ်ဝေပြီးနောက်ပိုင်း GDD တွက်ချက်ဖို့ အသုံးပြုနိုင်အောင် ပြုလုပ်ပါမယ်။
## အပူချိန်ကို ထုတ်ဝေပါ
အပူချိန်ကို ဖတ်ပြီးတာနဲ့ MQTT ကနေ 'server' code တစ်ခုဆီကို ထုတ်ဝေနိုင်ပါတယ်။ ဒီ code က အပူချိန်တန်ဖိုးတွေကို ဖတ်ပြီး GDD တွက်ချက်ဖို့ အသင့်ထားပေးပါမယ်။
### တာဝန် - အပူချိန်ကို ထုတ်ဝေပါ
အပူချိန်ဒေတာကို ထုတ်ဝေဖို့အတွက် device ကို အစီအစဉ်ရေးပါ။
1. `temperature-sensor` app project ကို ဖွင့်ထားမဟုတ်ရင် ဖွင့်ပါ။
1. Lesson 4 မှာ လုပ်ခဲ့တဲ့အတိုင်း MQTT ကို ချိတ်ဆက်ပြီး telemetry ပို့ဖို့ လုပ်ဆောင်ပါ။ ဒီအတွက် public Mosquitto broker ကို အသုံးပြုပါမယ်။
ဒီအဆင့်တွေကို လိုက်နာပါ-
- MQTT pip package ကို ထည့်ပါ။
- MQTT broker ကို ချိတ်ဆက်ဖို့ code ထည့်ပါ။
- Telemetry ကို ထုတ်ဝေဖို့ code ထည့်ပါ။
> ⚠️ [MQTT ချိတ်ဆက်ရန် လမ်းညွှန်ချက်များ](../../../1-getting-started/lessons/4-connect-internet/single-board-computer-mqtt.md) နှင့် [telemetry ပို့ရန် လမ်းညွှန်ချက်များ](../../../1-getting-started/lessons/4-connect-internet/single-board-computer-telemetry.md) ကို လိုအပ်ပါက Lesson 4 မှာ ပြန်ကြည့်ပါ။
1. `client_name` က ဒီ project ရဲ့ နာမည်ကို ပြသနိုင်အောင် သေချာစေပါ-
```python
client_name = id + 'temperature_sensor_client'
```
1. Telemetry အတွက်တော့ light value ပို့မယ့်အစား DHT sensor က ဖတ်ထားတဲ့ အပူချိန်တန်ဖိုးကို JSON document ရဲ့ `temperature` ဆိုတဲ့ property အနေနဲ့ ပို့ပါ-
```python
_, temp = sensor.read()
telemetry = json.dumps({'temperature' : temp})
```
1. အပူချိန်တန်ဖိုးကို မကြာခဏ ဖတ်စရာမလိုပါဘူး - အချိန်အတိုအတွင်းမှာ များစွာပြောင်းလဲမှာ မဟုတ်လို့ `time.sleep` ကို ၁၀ မိနစ်အထိ သတ်မှတ်ပါ-
```cpp
time.sleep(10 * 60);
```
> 💁 `sleep` function က အချိန်ကို စက္ကန့်အနေနဲ့ ယူပါတယ်။ အလွယ်တကူ ဖတ်နိုင်အောင် ၁ မိနစ်မှာ ၆၀ စက္ကန့်ဆိုတာကို အသုံးပြုပြီး ၁၀ x (၁ မိနစ်မှာ ၆၀ စက္ကန့်) ဆိုတဲ့ တွက်ချက်မှုရလဒ်ကို ပေးထားပါတယ်။
1. အစီအစဉ်ကို အရင်အပိုင်းမှာ လုပ်ခဲ့သလိုပဲ run လိုက်ပါ။ Virtual IoT device ကို အသုံးပြုနေတယ်ဆိုရင် CounterFit app ကို run ထားပြီး humidity နဲ့ temperature sensors ကို မှန်ကန်တဲ့ pins တွေမှာ ဖန်တီးထားတာ သေချာပါစေ။
```output
pi@raspberrypi:~/temperature-sensor $ python3 app.py
MQTT connected!
Sending telemetry {"temperature": 25}
Sending telemetry {"temperature": 25}
```
> 💁 ဒီ code ကို [code-publish-temperature/virtual-device](../../../../../2-farm/lessons/1-predict-plant-growth/code-publish-temperature/virtual-device) folder သို့မဟုတ် [code-publish-temperature/pi](../../../../../2-farm/lessons/1-predict-plant-growth/code-publish-temperature/pi) folder မှာ ရှာနိုင်ပါတယ်။
😀 သင့် device ကနေ telemetry အနေနဲ့ အပူချိန်ကို အောင်မြင်စွာ ထုတ်ဝေပြီးပါပြီ။
---
**အကြောင်းကြားချက်**:
ဤစာရွက်စာတမ်းကို AI ဘာသာပြန်ဝန်ဆောင်မှု [Co-op Translator](https://github.com/Azure/co-op-translator) ကို အသုံးပြု၍ ဘာသာပြန်ထားပါသည်။ ကျွန်ုပ်တို့သည် တိကျမှုအတွက် ကြိုးစားနေသော်လည်း၊ အလိုအလျောက် ဘာသာပြန်မှုများတွင် အမှားများ သို့မဟုတ် မတိကျမှုများ ပါဝင်နိုင်သည်ကို သတိပြုပါ။ မူရင်းဘာသာစကားဖြင့် ရေးသားထားသော စာရွက်စာတမ်းကို အာဏာတရ အရင်းအမြစ်အဖြစ် သတ်မှတ်သင့်ပါသည်။ အရေးကြီးသော အချက်အလက်များအတွက် လူ့ဘာသာပြန်ပညာရှင်များမှ ပရော်ဖက်ရှင်နယ် ဘာသာပြန်မှုကို အကြံပြုပါသည်။ ဤဘာသာပြန်မှုကို အသုံးပြုခြင်းမှ ဖြစ်ပေါ်လာသော အလွဲအလွတ်များ သို့မဟုတ် အနားယူမှားမှုများအတွက် ကျွန်ုပ်တို့သည် တာဝန်မယူပါ။