not using supercaps but lipo
This commit is contained in:
parent
0aef4ac99a
commit
67546aa925
|
|
@ -7,14 +7,24 @@
|
||||||
NAU7802 nau7802;
|
NAU7802 nau7802;
|
||||||
BME280 bme280;
|
BME280 bme280;
|
||||||
|
|
||||||
|
//#define Vext GPIO6
|
||||||
|
|
||||||
|
/******************************************************************************/
|
||||||
|
/* Firmware Version */
|
||||||
|
/******************************************************************************/
|
||||||
|
static const int32_t fwVersion = 20210116;
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
/* LoraWAN Settings */
|
/* LoraWAN Settings */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
/* OTAA para*/
|
/* OTAA para*/
|
||||||
uint8_t devEui[] = { 0x00, 0x72, 0x4A, 0x61, 0xB5, 0xB6, 0x20, 0xBB };
|
//uint8_t devEui[] = { 0x22, 0x32, 0x33, 0x00, 0x00, 0x88, 0x88, 0x02 };
|
||||||
uint8_t appEui[] = { 0x70, 0xB3, 0xD5, 0x7E, 0xD0, 0x02, 0xE5, 0xAB };
|
//uint8_t appEui[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
|
||||||
uint8_t appKey[] = { 0x55, 0x11, 0xF4, 0x55, 0x71, 0x81, 0xC0, 0xBC, 0x04, 0xA9, 0x16, 0x7F, 0x75, 0x8A, 0xEA, 0xB4 };
|
//uint8_t appKey[] = { 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x66, 0x01 };
|
||||||
|
uint8_t devEui[] = { 0x00, 0x00, 0xd3, 0xa6, 0x59, 0x83, 0x3b, 0x25 };
|
||||||
|
uint8_t appEui[] = { 0x70, 0xb3, 0xd5, 0x7e, 0xd0, 0x02, 0xe5, 0xab };
|
||||||
|
uint8_t appKey[] = { 0x00, 0x00, 0xd3, 0xa6, 0x59, 0x83, 0x3b, 0x25, 0x00, 0x00, 0xd3, 0xa6, 0x59, 0x83, 0x3b, 0x25 };
|
||||||
|
|
||||||
/* ABP para*/
|
/* ABP para*/
|
||||||
uint8_t nwkSKey[] = { 0x15, 0xb1, 0xd0, 0xef, 0xa4, 0x63, 0xdf, 0xbe, 0x3d, 0x11, 0x18, 0x1e, 0x1e, 0xc7, 0xda, 0x85 };
|
uint8_t nwkSKey[] = { 0x15, 0xb1, 0xd0, 0xef, 0xa4, 0x63, 0xdf, 0xbe, 0x3d, 0x11, 0x18, 0x1e, 0x1e, 0xc7, 0xda, 0x85 };
|
||||||
|
|
@ -140,7 +150,6 @@ float stddev(long samples[], int m) //calculate the stdandard deviation
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
/* Global Data Structures */
|
/* Global Data Structures */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
static const int32_t fwVersion = 20201020;
|
|
||||||
|
|
||||||
// send an init package every 100 packages;
|
// send an init package every 100 packages;
|
||||||
static const byte INIT_PACKAGE_INTERVAL = 100;
|
static const byte INIT_PACKAGE_INTERVAL = 100;
|
||||||
|
|
@ -165,7 +174,7 @@ typedef struct {
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint8_t version; // Version of Packet Format (must be increased every time format changes...)
|
uint8_t version; // Version of Packet Format (must be increased every time format changes...)
|
||||||
uint8_t vsupercap; // Spannung Supercap in mV / 20
|
uint8_t vbat; // Batteriespannung (0: <= 2510mV, 70: 3000mV, 170: 3700mV, 255: >= 4295mV [1 Einheit => 7mV])
|
||||||
int16_t temperature; // Temperatur (Startwert) in 1/10 Grad Celsius
|
int16_t temperature; // Temperatur (Startwert) in 1/10 Grad Celsius
|
||||||
uint8_t humidity; // Luftfeuchtigkeit in Prozent
|
uint8_t humidity; // Luftfeuchtigkeit in Prozent
|
||||||
uint8_t pressure; // Luftdruck in Hekto-Pascal (0 entspricht 825 hPa)
|
uint8_t pressure; // Luftdruck in Hekto-Pascal (0 entspricht 825 hPa)
|
||||||
|
|
@ -179,7 +188,7 @@ typedef struct {
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint8_t version; // Version of Packet Format (must be increased every time format changes...)
|
uint8_t version; // Version of Packet Format (must be increased every time format changes...)
|
||||||
int32_t fw_version; // Version of Firmware, Nummer entspricht YYYYMMDD
|
int32_t fw_version; // Version of Firmware, Nummer entspricht YYYYMMDD
|
||||||
uint8_t vsupercap; // Spannung Supercap in mV / 20
|
uint8_t vbat; // Batteriespannung (0: <= 2510mV, 70: 3000mV, 170: 3700mV, 255: >= 4295mV [1 Einheit => 7mV])
|
||||||
int16_t temperature; // Temperatur in 1/10 Grad Celsius
|
int16_t temperature; // Temperatur in 1/10 Grad Celsius
|
||||||
uint8_t humidity; // Luftfeuchtigkeit in Prozent
|
uint8_t humidity; // Luftfeuchtigkeit in Prozent
|
||||||
uint8_t pressure; // Luftdruck in Hekto-Pascal (0 entspricht 825 hPa)
|
uint8_t pressure; // Luftdruck in Hekto-Pascal (0 entspricht 825 hPa)
|
||||||
|
|
@ -192,7 +201,7 @@ typedef struct {
|
||||||
} __attribute__((packed)) LORA_data_first;
|
} __attribute__((packed)) LORA_data_first;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint8_t vsupercap; // Spannung Supercap in mV / 20
|
uint8_t vbat; // Batteriespannung (0: <= 2510mV, 70: 3000mV, 170: 3700mV, 255: >= 4295mV [1 Einheit => 7mV])
|
||||||
int16_t temperature; // Temperatur in 1/10 Grad Celsius
|
int16_t temperature; // Temperatur in 1/10 Grad Celsius
|
||||||
uint8_t humidity; // Luftfeuchtigkeit in Prozent
|
uint8_t humidity; // Luftfeuchtigkeit in Prozent
|
||||||
uint8_t pressure; // Luftdruck in Hekto-Pascal (0 entspricht 825 hPa)
|
uint8_t pressure; // Luftdruck in Hekto-Pascal (0 entspricht 825 hPa)
|
||||||
|
|
@ -224,7 +233,7 @@ uint32_t gRebootMs;
|
||||||
void ClearLoraData(bool clearLastValues)
|
void ClearLoraData(bool clearLastValues)
|
||||||
{
|
{
|
||||||
lora_data.version = LORA_DATA_VERSION;
|
lora_data.version = LORA_DATA_VERSION;
|
||||||
lora_data.vsupercap = 0;
|
lora_data.vbat = 0;
|
||||||
lora_data.temperature = 0;
|
lora_data.temperature = 0;
|
||||||
lora_data.humidity = 0;
|
lora_data.humidity = 0;
|
||||||
lora_data.pressure = 0;
|
lora_data.pressure = 0;
|
||||||
|
|
@ -241,7 +250,7 @@ void ClearLoraData(bool clearLastValues)
|
||||||
|
|
||||||
lora_data_first.version = LORA_DATA_VERSION_FIRST_PACKAGE;
|
lora_data_first.version = LORA_DATA_VERSION_FIRST_PACKAGE;
|
||||||
lora_data_first.fw_version = fwVersion;
|
lora_data_first.fw_version = fwVersion;
|
||||||
lora_data_first.vsupercap = 0;
|
lora_data_first.vbat = 0;
|
||||||
lora_data_first.weight_a = 0;
|
lora_data_first.weight_a = 0;
|
||||||
lora_data_first.weight_b = 0;
|
lora_data_first.weight_b = 0;
|
||||||
lora_data_first.cal_a_0 = config_data.cal_a_0;
|
lora_data_first.cal_a_0 = config_data.cal_a_0;
|
||||||
|
|
@ -256,7 +265,7 @@ void ClearLoraData(bool clearLastValues)
|
||||||
|
|
||||||
// We initialize last_sensor_reading
|
// We initialize last_sensor_reading
|
||||||
if (clearLastValues) {
|
if (clearLastValues) {
|
||||||
last_sensor_reading.vsupercap = 0;
|
last_sensor_reading.vbat = 0;
|
||||||
last_sensor_reading.weight_a = 0;
|
last_sensor_reading.weight_a = 0;
|
||||||
last_sensor_reading.weight_b = 0;
|
last_sensor_reading.weight_b = 0;
|
||||||
last_sensor_reading.weight = 0;
|
last_sensor_reading.weight = 0;
|
||||||
|
|
@ -275,7 +284,7 @@ void ShowLORAData(bool firstTime)
|
||||||
Serial.printf("{\n");
|
Serial.printf("{\n");
|
||||||
Serial.printf(" \"version\": \"%d\",\n", lora_data_first.version);
|
Serial.printf(" \"version\": \"%d\",\n", lora_data_first.version);
|
||||||
Serial.printf(" \"fw_version\": \"%d\",\n", lora_data_first.fw_version);
|
Serial.printf(" \"fw_version\": \"%d\",\n", lora_data_first.fw_version);
|
||||||
Serial.printf(" \"vsupercap:\": \"%u\",\n", lora_data_first.vsupercap);
|
Serial.printf(" \"vbat:\": \"%u\",\n", lora_data_first.vbat);
|
||||||
Serial.printf(" \"humidity\": \"%u\",\n", lora_data_first.humidity);
|
Serial.printf(" \"humidity\": \"%u\",\n", lora_data_first.humidity);
|
||||||
Serial.printf(" \"pressure\": \"%u\",\n", lora_data_first.pressure);
|
Serial.printf(" \"pressure\": \"%u\",\n", lora_data_first.pressure);
|
||||||
Serial.printf(" \"weight_a\": \"%ld\",\n", lora_data_first.weight_a);
|
Serial.printf(" \"weight_a\": \"%ld\",\n", lora_data_first.weight_a);
|
||||||
|
|
@ -291,7 +300,7 @@ void ShowLORAData(bool firstTime)
|
||||||
|
|
||||||
Serial.printf("{\n");
|
Serial.printf("{\n");
|
||||||
Serial.printf(" \"version\": \"%d\",\n", lora_data.version);
|
Serial.printf(" \"version\": \"%d\",\n", lora_data.version);
|
||||||
Serial.printf(" \"vsupercap\": \"%u\",\n", lora_data.vsupercap);
|
Serial.printf(" \"vbat\": \"%u\",\n", lora_data.vbat);
|
||||||
Serial.printf(" \"temperature\": \"%u\",\n", lora_data.temperature);
|
Serial.printf(" \"temperature\": \"%u\",\n", lora_data.temperature);
|
||||||
Serial.printf(" \"humidity\": \"%u\",\n", lora_data.humidity);
|
Serial.printf(" \"humidity\": \"%u\",\n", lora_data.humidity);
|
||||||
Serial.printf(" \"pressure\": \"%u\",\n", lora_data.pressure);
|
Serial.printf(" \"pressure\": \"%u\",\n", lora_data.pressure);
|
||||||
|
|
@ -534,12 +543,58 @@ void PowerupScale()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CalculateWeight()
|
||||||
|
{
|
||||||
|
int32_t weight_current32;
|
||||||
|
int32_t weight_current32_a;
|
||||||
|
int32_t weight_current32_b;
|
||||||
|
|
||||||
|
bool plausible;
|
||||||
|
bool plausible_a;
|
||||||
|
bool plausible_b;
|
||||||
|
|
||||||
|
// Gewicht berechnen
|
||||||
|
weight_current32_a = (int32_t)((sensor_data.weight_a - config_data.cal_a_0) / config_data.cal_a_factor);
|
||||||
|
weight_current32_b = (int32_t)((sensor_data.weight_b - config_data.cal_b_0) / config_data.cal_b_factor);
|
||||||
|
weight_current32 = (int32_t)((weight_current32_a + weight_current32_b) / 5.0);
|
||||||
|
|
||||||
|
// we check if weights are plausible
|
||||||
|
plausible_a = (weight_current32_a > -10000) && (weight_current32_a < 150000);
|
||||||
|
plausible_b = (weight_current32_b > -10000) && (weight_current32_b < 150000);
|
||||||
|
plausible = (plausible_a && plausible_b);
|
||||||
|
|
||||||
|
if (weight_current32 < 0) {
|
||||||
|
if (plausible) {
|
||||||
|
weight_current32 = 0;
|
||||||
|
}
|
||||||
|
} else if (weight_current32 > UINT16_MAX) {
|
||||||
|
//weight_current32 = UINT16_MAX;
|
||||||
|
// we set the weight to 0, as such high values are not realistic and probably a sign for bad calibration...
|
||||||
|
weight_current32 = 0;
|
||||||
|
}
|
||||||
|
if (!plausible) {
|
||||||
|
weight_current32 = NOT_PLAUSIBLE_16;
|
||||||
|
//if (!plausible_a) {
|
||||||
|
// sensor_data.weight_a = NOT_PLAUSIBLE_32;
|
||||||
|
//}
|
||||||
|
//if (!plausible_b) {
|
||||||
|
// sensor_data.weight_b = NOT_PLAUSIBLE_32;
|
||||||
|
//}
|
||||||
|
}
|
||||||
|
sensor_data.weight = (uint16_t)weight_current32;
|
||||||
|
}
|
||||||
|
|
||||||
void ReadScales()
|
void ReadScales()
|
||||||
{
|
{
|
||||||
PowerupScale();
|
PowerupScale();
|
||||||
sensor_data.weight_a = ReadScale('A');
|
sensor_data.weight_a = ReadScale('A');
|
||||||
sensor_data.weight_b = ReadScale('B');
|
sensor_data.weight_b = ReadScale('B');
|
||||||
|
if (config_data.debug_level > 0) {
|
||||||
|
Serial.printf("Reading A, B: %d, %d\n", sensor_data.weight_a, sensor_data.weight_b);
|
||||||
|
|
||||||
|
}
|
||||||
PowerdownScale();
|
PowerdownScale();
|
||||||
|
CalculateWeight();
|
||||||
}
|
}
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
@ -612,19 +667,19 @@ bool checkUserAt(char *cmd, char *content)
|
||||||
Serial.printf(" \"temperature\": \"%d\",\n", sensor_data.temperature);
|
Serial.printf(" \"temperature\": \"%d\",\n", sensor_data.temperature);
|
||||||
Serial.printf(" \"humidity\": \"%d\",\n", sensor_data.humidity);
|
Serial.printf(" \"humidity\": \"%d\",\n", sensor_data.humidity);
|
||||||
Serial.printf(" \"pressure\": \"%d\",\n", sensor_data.pressure);
|
Serial.printf(" \"pressure\": \"%d\",\n", sensor_data.pressure);
|
||||||
Serial.printf(" \"vsupercap\": \"%d\",\n", sensor_data.vsupercap);
|
Serial.printf(" \"vbat\": \"%d\",\n", sensor_data.vbat);
|
||||||
Serial.printf("}\n");
|
Serial.printf("}\n");
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(cmd, "SUPERCAP") == 0)
|
if (strcmp(cmd, "VBAT") == 0)
|
||||||
{
|
{
|
||||||
if (content[0] == '?')
|
if (content[0] == '?')
|
||||||
{
|
{
|
||||||
uint16_t BatteryVoltage = getBatteryVoltage();
|
uint16_t VBatVoltage = getBatteryVoltage();
|
||||||
Serial.print("+SUPERCAP=");
|
Serial.print("+VBAT=");
|
||||||
Serial.print(BatteryVoltage);
|
Serial.print(VBatVoltage);
|
||||||
Serial.println();
|
Serial.println();
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
@ -729,7 +784,7 @@ void AddSensorDataToLoraData()
|
||||||
iteration++;
|
iteration++;
|
||||||
next_package_is_init_package = ((iteration <= INIT_PACKETS) || ((package_counter % INIT_PACKAGE_INTERVAL) == 0));
|
next_package_is_init_package = ((iteration <= INIT_PACKETS) || ((package_counter % INIT_PACKAGE_INTERVAL) == 0));
|
||||||
if (next_package_is_init_package) {
|
if (next_package_is_init_package) {
|
||||||
lora_data_first.vsupercap = sensor_data.vsupercap;
|
lora_data_first.vbat = sensor_data.vbat;
|
||||||
lora_data_first.weight_a = sensor_data.weight_a;
|
lora_data_first.weight_a = sensor_data.weight_a;
|
||||||
lora_data_first.weight_b = sensor_data.weight_b;
|
lora_data_first.weight_b = sensor_data.weight_b;
|
||||||
lora_data_first.temperature = sensor_data.temperature;
|
lora_data_first.temperature = sensor_data.temperature;
|
||||||
|
|
@ -739,7 +794,7 @@ void AddSensorDataToLoraData()
|
||||||
ShowLORAData(true);
|
ShowLORAData(true);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lora_data.vsupercap = sensor_data.vsupercap;
|
lora_data.vbat = sensor_data.vbat;
|
||||||
if (my_position == 0) {
|
if (my_position == 0) {
|
||||||
lora_data.temperature = sensor_data.temperature;
|
lora_data.temperature = sensor_data.temperature;
|
||||||
lora_data.weight_first = sensor_data.weight;
|
lora_data.weight_first = sensor_data.weight;
|
||||||
|
|
@ -796,6 +851,22 @@ bool TooBigWeightChange()
|
||||||
return big_difference;
|
return big_difference;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint8_t GetVBatValue(int millivolts)
|
||||||
|
{
|
||||||
|
uint8_t res;
|
||||||
|
if (millivolts <= 2510) {
|
||||||
|
res = 0;
|
||||||
|
|
||||||
|
} else if (millivolts >= 4295) {
|
||||||
|
res = 255;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
res = (millivolts - 2510) / 7;
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
// returns true if data should be sent; read_only: when true, do not use as lora_data
|
// returns true if data should be sent; read_only: when true, do not use as lora_data
|
||||||
bool ReadSensors(bool read_only)
|
bool ReadSensors(bool read_only)
|
||||||
{
|
{
|
||||||
|
|
@ -811,7 +882,7 @@ bool ReadSensors(bool read_only)
|
||||||
disableVext();
|
disableVext();
|
||||||
|
|
||||||
uint16_t voltage = getBatteryVoltage();
|
uint16_t voltage = getBatteryVoltage();
|
||||||
sensor_data.vsupercap = (uint8_t)(voltage / 20);
|
sensor_data.vbat = GetVBatValue(voltage);
|
||||||
if (config_data.debug_level > 0) {
|
if (config_data.debug_level > 0) {
|
||||||
Serial.printf("Read ADC, %d Millivolts...\n", voltage);
|
Serial.printf("Read ADC, %d Millivolts...\n", voltage);
|
||||||
}
|
}
|
||||||
|
|
@ -857,9 +928,12 @@ void loop()
|
||||||
{
|
{
|
||||||
case DEVICE_STATE_INIT:
|
case DEVICE_STATE_INIT:
|
||||||
{
|
{
|
||||||
#if(AT_SUPPORT)
|
#if(LORAWAN_DEVEUI_AUTO)
|
||||||
getDevParam();
|
LoRaWAN.generateDeveuiByChipID();
|
||||||
#endif
|
#endif
|
||||||
|
#if(AT_SUPPORT)
|
||||||
|
getDevParam();
|
||||||
|
#endif
|
||||||
printDevParam();
|
printDevParam();
|
||||||
LoRaWAN.init(loraWanClass, loraWanRegion);
|
LoRaWAN.init(loraWanClass, loraWanRegion);
|
||||||
deviceState = DEVICE_STATE_JOIN;
|
deviceState = DEVICE_STATE_JOIN;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue