У меня проблема с соединением между Dragino LG01-S и Heltec WiFi LoRa 32.
WiFi LoRa 32 отправляет пакеты с данными о температуре на LG01-S каждые 5 секунд. LG01-S принимает пакеты постоянно, но через некоторое время (может быть 20 минут, может быть 7 часов) он получает пакет, который не похож на другие. Я следил за пакетами в последовательном мониторе, пока не обнаружился неисправный, вот так я увидел, как они выглядели.
«Неудачные» пакеты выглядят так:
¹h260 äàŽÛNR · à, ªê @ ö9AÚo … Œ £ ŪK;??! E I × .U * ®d§ «¿ ‘Зол
Обычно это что-то вроде:
30,00
Размер обычных пакетов составляет пять байт, тогда как размер ошибочного пакета составляет 73 байта.
Ошибка в приемнике (LG01-S), потому что после обнаружения сбойного пакета он просто прекращает получать любые данные и вообще не выполняет никакого кода. После сбоя LoRa32 продолжает отправлять пакеты.
Я проверил, соответствуют ли сбои, но это не так, как уже упоминалось, они происходят в разное время.
Ниже вы можете увидеть код отправителя и получателя.
отправитель
#include <SPI.h>
#include <LoRa.h>
#include "SSD1306.h"#include<Arduino.h>
#include <dht.h>SSD1306 display(0x3c, 4, 15);
#define DHTPIN 17
#define SS 18
#define RST 14
#define DI0 26
#define BAND 915E6
//create an instance of DHT sensor
dht TempSensor;
void setup()
{
pinMode(16, OUTPUT);
digitalWrite(16, LOW);
delay(50);
digitalWrite(16, HIGH);
Serial.begin(115200);
while (!Serial);
display.init();
display.flipScreenVertically();
display.setFont(ArialMT_Plain_10);
display.setTextAlignment(TEXT_ALIGN_LEFT);
display.drawString(5, 5, "LoRa Sender");
display.display();
SPI.begin(5, 19, 27, 18);
LoRa.setPins(SS, RST, DI0);
Serial.println("LoRa Sender");
if (!LoRa.begin(BAND)) {
Serial.println("Starting LoRa failed!");
while (1);
}
LoRa.setSyncWord(0xF3);
Serial.println("LoRa Initial OK!");
display.drawString(5, 20, "LoRa Initializing OK!");
display.display();
delay(2000);
}
void loop() {
double check = TempSensor.read11(DHTPIN);
Serial.println(TempSensor.temperature);
Serial.print("Sending temperature: ");
Serial.println(TempSensor.temperature);
display.clear();
display.setFont(ArialMT_Plain_16);
display.drawString(3, 5, "Sending temperature ");
display.drawString(50, 30, String(TempSensor.temperature));
display.display();
// sending packet
LoRa.beginPacket();
LoRa.print(TempSensor.temperature);
Serial.println("package sent");
LoRa.endPacket();
delay(5000);
}
Получатель:
#include <SPI.h>
#include <LoRa.h>
#include <Console.h>
#include <Process.h>
#include <Bridge.h>
// Set center frequency
uint32_t freq = 915E6;
Process logdata;
int timeCounter = 0;
void setup() {
Bridge.begin(115200);
Console.begin();
Console.println("LoRa Receiver");
if (!LoRa.begin(freq)) {
Console.println("Starting LoRa failed!");
while (1);
}
LoRa.setSyncWord(0xF3);
LoRa.receive();
}
void loop() {
// try to parse packet
int packetSize = LoRa.parsePacket();
if (packetSize) {
// received a packet read packet
while (LoRa.available()) {
String TemperatureData = LoRa.readString();
Console.println(TemperatureData);
Console.println(packetSize);
//Save in db
logdata.begin("lua");
logdata.addParameter("/root/LinkTempInside.lua"); //
logdata.addParameter(String(TemperatureData)); //
logdata.run(); // run the command
// read the output of the command
while (logdata.available() > 0) {
char c = logdata.read();
}
Console.println("Data Sent");
}
}
}
Спасибо за помощь.
Задача ещё не решена.
Других решений пока нет …