RM新时代网站-首页

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>使用Python繪制LoRa節(jié)點的實時數(shù)據(jù)

使用Python繪制LoRa節(jié)點的實時數(shù)據(jù)

2022-12-22 | zip | 0.34 MB | 次下載 | 免費

資料介紹

描述

?

?

本文遵循有關?如何?使用Zerynth創(chuàng)建以Python編程并連接到The Things Network的 LoRa/LoraWAN 網(wǎng)絡教程。

從上一個項目的相同設置開始,我們將了解如何使用 Zerynth、The Things Network 和 Matplotlib(一個非常流行的 Python 繪圖庫)獲取和可視化 LoRa 節(jié)點的傳感器數(shù)據(jù)。

您將看到如何:

  • 使用Zerynth在Python中?編寫LoRa?節(jié)點以獲取溫度?和?濕度數(shù)據(jù);
  • 通過MQTT從 The Things Network 控制臺獲取數(shù)據(jù);
  • 使用Matplotlib繪制傳感器數(shù)據(jù)。

所需材料

本質(zhì)上,我們需要與之前項目相同的配置,外加一個溫度和濕度傳感器

  • 勞拉網(wǎng)關。在本教程中,我們使用了 Link Labs BS-8,這是一種用于 LoRa 網(wǎng)絡的工業(yè)IoT/M2M 網(wǎng)關。它能夠支持具有 8 個同步接收通道的數(shù)千個端點。
  • LoRa 終端節(jié)點。在本教程中,我們使用了Flip&Click作為 MCU 板,一個?LoRa Click?和一個Temp&Hum Click ,它帶有 ST 的 HTS221 溫度和相對濕度傳感器。
  • Zerynth Studio:我們的專業(yè) IDE,它提供了一個平臺,用于開發(fā) Python 或混合 C/Python 代碼和管理您的開發(fā)板。它包括編譯器、調(diào)試器和編輯器,以及提供輕松學習體驗的教程和示例項目。

在 Python 中編程 LoRa 節(jié)點以獲取傳感器數(shù)據(jù)

在執(zhí)行 LoRa 網(wǎng)關配置和 LoRa 節(jié)點配置步驟后(參見之前的項目),我們將能夠?qū)υO備進行編程以從 Temp&Hum Click 獲取數(shù)據(jù)并將這些值發(fā)送到 The Things Network 控制臺。

特別是,我們必須在 Zerynth Studio 上創(chuàng)建一個新項目并粘貼此代碼:

# LoraWAN sensor data Logging
?
import streams
from microchip.rn2483 import rn2483
from stm.hts221 import hts221
?
streams.serial()
?
try:
????rst = D16 # reset pin 
????# insert otaa credentials!
????appeui = "YOUAPPEUI"
????appkey =??"YOUAPPKEY"
????print("joining...")
????
????if not rn2483.init(SERIAL1, appeui, appkey, rst): # LoRa Click on slot A
????????print("denied :(")
????????raise Exception
?
????print("sending first message, res:")
????print(rn2483.tx_uncnf('TTN'))
?
????temp_hum = hts221.HTS221( I2C1,D31 ) # Temp Hum Click on slot C
????
????while True:
????????temp, hum = temp_hum.get_temp_humidity()
????????print('temp: ', temp, 'hum: ', hum)
????????data = bytearray(4) 
????????data[0:2] = bytearray([ int(temp) + 127, int((temp - int(temp)) * 100) ])
????????data[2:4] = bytearray([ int(hum) + 127, int((hum - int(hum)) * 100) ])
????????r = rn2483.tx_uncnf(data) # send data to TTN
????????sleep(5000)
????????
except Exception as e:
????print(e)

使用您可以在TTN 控制臺的設備概述中找到的“ appeui ”和“ appkey ”值編輯行。

將代碼上傳到您的開發(fā)板,您就完成了!

現(xiàn)在單擊 TTN 控制臺的“數(shù)據(jù)”選項卡,您可以看到 LoRa 節(jié)點發(fā)送的傳感器數(shù)據(jù)!

如您所見,此腳本與上一個項目中使用的“ping”示例非常相似。唯一的區(qū)別與Temp&Hum Click搭載的HTS221溫濕度傳感器的使用有關。感謝 Zerynth,您只需要幾行Python ,就可以從傳感器獲取真實數(shù)據(jù)并將其發(fā)送到 LoRa 網(wǎng)絡!

通過 MQTT 從 The Things Network 控制臺獲取數(shù)據(jù)

現(xiàn)在是從 TTN 控制臺獲取數(shù)據(jù)的時候了。為此,我們準備了一個非常簡單的 Python 腳本,該腳本使用?Eclipse Paho MQTT Python 客戶端庫,該客戶端庫實現(xiàn)了MQTT協(xié)議的 3.1 和 3.1.1 版。

請注意,您必須在筆記本電腦上運行此腳本,因此您需要在 PC 上安裝 Python (3.x)。

get_plot_data_TTN.py:

# Get and plot data from TTN Console using Python
?
import paho.mqtt.client as mqtt
import json
import base64
?
APPEUI = 'YOURAPPEUI'
APPID??= 'YOUAPPID'
PSW????= 'YOURPASSWORD'
?
import matplotlib.pyplot as plt
#import DataPlot and RealtimePlot from the file plot_data.py
from plot_data import DataPlot, RealtimePlot
?
fig, axes = plt.subplots()
plt.title('Data from TTN console')
?
data = DataPlot()
dataPlotting= RealtimePlot(axes)
?
count=0
?
def bytes_to_decimal(i,d):
????xx = i - 127
????dec = (-d if xx < 0 else d)/100
????return xx + dec
?
def on_connect(client, userdata, flags, rc):
????client.subscribe('+/devices/+/up'.format(APPEUI))
?
def on_message(client, userdata, msg):
????j_msg = json.loads(msg.payload.decode('utf-8'))
????dev_eui = j_msg['hardware_serial']
?
????tmp_hum = base64.b64decode(j_msg['payload_raw'])
????tmp = bytes_to_decimal(*tmp_hum[0:2])
????hum = bytes_to_decimal(*tmp_hum[2:4])
?
????# print data
????print('---')
????print('tmp:', tmp, ' hum:', hum)
????print('dev eui: ', dev_eui)
?
????# plot data
????global count
????count+=1
????data.add(count, tmp , hum)
????dataPlotting.plot(data)
????plt.pause(0.001)
?
# set paho.mqtt callback
ttn_client = mqtt.Client()
ttn_client.on_connect = on_connect
ttn_client.on_message = on_message
ttn_client.username_pw_set(APPID, PSW)
ttn_client.connect("eu.thethings.network", 1883, 60) #MQTT port over TLS
?
try:
????ttn_client.loop_forever()
except KeyboardInterrupt:
????print('disconnect')
????ttn_client.disconnect()

使用 Matplotlib 實時繪制傳感器數(shù)據(jù)

一旦你的計算機中有了數(shù)據(jù),你就可以用它做各種各樣的事情。在這種情況下,我們想要讀取這些溫度和濕度值并將它們繪制為時間的函數(shù)。

因為我們喜歡 Python,所以我們準備了一個名為“ plot_data.py ”的腳本,它為此使用了Matplotlib庫。

plot_data.py:

import time
import math
from collections import deque , defaultdict
?
import matplotlib.animation as animation
from matplotlib import pyplot as plt
?
import threading
?
from random import randint
?
from statistics import *
?
class DataPlot:
????def __init__(self, max_entries = 20):
????????self.axis_x = deque(maxlen=max_entries)
????????self.axis_y = deque(maxlen=max_entries)
????????self.axis_y2 = deque(maxlen=max_entries)
?
????????self.max_entries = max_entries
?
????????self.buf1=deque(maxlen=5)
????????self.buf2=deque(maxlen=5)
?
???? 
????def add(self, x, y,y2):
?
????????self.axis_x.append(x)
????????self.axis_y.append(y)
????????self.axis_y2.append(y2)
?
class RealtimePlot:
????def __init__(self, axes):
???? 
????????self.axes = axes
?
????????self.lineplot, = axes.plot([], [], "ro-")
????????self.lineplot2, = axes.plot([], [], "go-")
?
????def plot(self, dataPlot):
????????self.lineplot.set_data(dataPlot.axis_x, dataPlot.axis_y)
????????self.lineplot2.set_data(dataPlot.axis_x, dataPlot.axis_y2)
?
????????self.axes.set_xlim(min(dataPlot.axis_x), max(dataPlot.axis_x))
????????ymin = min([min(dataPlot.axis_y), min(dataPlot.axis_y2)])-10
????????ymax = max([max(dataPlot.axis_y), max(dataPlot.axis_y2)])+10
????????self.axes.set_ylim(ymin,ymax)
????????self.axes.relim();
?
def main():
????fig, axes = plt.subplots()
????plt.title('Plotting Data')
?
????data = DataPlot();
????dataPlotting= RealtimePlot(axes)
?
????try:
????????count=0
????????while True:
????????????count+=1
????????????data.add(count, 30 + 1/randint(1,5) , 35 + randint(1,5))
????????????dataPlotting.plot(data)
?
????????????plt.pause(0.001)
????except KeyboardInterrupt:
????????print('\n\nKeyboard exception received. Exiting.')
????????plt.close()
????????ser.close()
????????exit()
?
if __name__ == "__main__": main()

請注意,您必須在之前的腳本中導入此文件才能正常工作。這就是情節(jié)的樣子。隨著數(shù)據(jù)的不斷涌入,它會向右滾動。

使用 Zerynth Studio PRO 擴展您的 LoRa 網(wǎng)絡

以下列表包括一些LoRa?關鍵特性:

  • 遠距離:15 – 20 公里;
  • 電池壽命長:超過十年;
  • 百萬節(jié)點!

Zerynth Studio?的免費版本允許您使用LoRa解決方案原型所需的所有功能,但您最多可以免費為每個受支持的電路板編程 5 個單元。您可以使用Zerynth Studio PRO?版本(從 6 月 28 日開始提供,預購可享受高達 50% 的折扣)解鎖此限制,該?版本還將包括工業(yè)級功能,例如:

  • 可選擇實時操作系統(tǒng);
  • 無線更新開發(fā);
  • 硬件驅(qū)動的安全固件以工業(yè)規(guī)模燒錄在設備上;
  • …以及更多
通過Zerynth 學院

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1Keysight B1500A 半導體器件分析儀用戶手冊、說明書 (中文)
  2. 19.00 MB  |  4次下載  |  免費
  3. 2使用TL431設計電源
  4. 0.67 MB   |  2次下載  |  免費
  5. 3BT134雙向可控硅手冊
  6. 1.74 MB   |  2次下載  |  1 積分
  7. 4一種新型高效率的服務器電源系統(tǒng)
  8. 0.85 MB   |  1次下載  |  1 積分
  9. 5LabVIEW環(huán)形控件
  10. 0.01 MB   |  1次下載  |  1 積分
  11. 6PR735,使用UCC28060的600W交錯式PFC轉換器
  12. 540.03KB   |  1次下載  |  免費
  13. 751單片機核心板原理圖
  14. 0.12 MB   |  1次下載  |  5 積分
  15. 8BP2879DB支持調(diào)光調(diào)滅的非隔離低 PF LED 驅(qū)動器
  16. 1.44 MB  |  1次下載  |  免費

本月

  1. 1開關電源設計原理手冊
  2. 1.83 MB   |  54次下載  |  免費
  3. 2FS5080E 5V升壓充電兩串鋰電池充電管理IC中文手冊
  4. 8.45 MB   |  23次下載  |  免費
  5. 3DMT0660數(shù)字萬用表產(chǎn)品說明書
  6. 0.70 MB   |  13次下載  |  免費
  7. 4UC3842/3/4/5電源管理芯片中文手冊
  8. 1.75 MB   |  12次下載  |  免費
  9. 5ST7789V2單芯片控制器/驅(qū)動器英文手冊
  10. 3.07 MB   |  11次下載  |  1 積分
  11. 6TPS54202H降壓轉換器評估模塊用戶指南
  12. 1.02MB   |  8次下載  |  免費
  13. 7STM32F101x8/STM32F101xB手冊
  14. 1.69 MB   |  8次下載  |  1 積分
  15. 8基于MSP430FR6043的超聲波氣體流量計快速入門指南
  16. 2.26MB   |  7次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935119次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
  4. 1.48MB  |  420061次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233084次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73807次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65987次下載  |  10 積分
RM新时代网站-首页