Add Sensor34 commands

Add commands ``Sensor34 10 <valueA>`` and ``Sensor34 11 <valueB>`` to use HX711 absolute weight conversion (#15292)
This commit is contained in:
Theo Arends 2022-04-07 15:06:21 +02:00
parent d63077ab93
commit ccdd8c9861
5 changed files with 62 additions and 49 deletions

View File

@ -3,7 +3,11 @@ All notable changes to this project will be documented in this file.
## [Unreleased] - Development ## [Unreleased] - Development
## [11.0.0.5] ## [11.0.0.6]
### Added
- Commands ``Sensor34 10 <valueA>`` and ``Sensor34 11 <valueB>`` to use HX711 absolute weight conversion (#15292)
## [11.0.0.5] 20220407
### Added ### Added
- Support for improv as used by esp-web-tools - Support for improv as used by esp-web-tools
- Command ``IfxSensor 1`` to send non-teleperiod data to influxdb - Command ``IfxSensor 1`` to send non-teleperiod data to influxdb

View File

@ -103,7 +103,7 @@ The latter links can be used for OTA upgrades too like ``OtaUrl http://ota.tasmo
[Complete list](BUILDS.md) of available feature and sensors. [Complete list](BUILDS.md) of available feature and sensors.
## Changelog v11.0.0.5 ## Changelog v11.0.0.6
### Added ### Added
- Command ``SetOption135 1`` to disable LVGL splash screen - Command ``SetOption135 1`` to disable LVGL splash screen
- Command ``SetOption136 1`` to disable single sensor reports from Tuya devices while keeping teleperiod reports [#15216](https://github.com/arendst/Tasmota/issues/15216) - Command ``SetOption136 1`` to disable single sensor reports from Tuya devices while keeping teleperiod reports [#15216](https://github.com/arendst/Tasmota/issues/15216)
@ -112,6 +112,7 @@ The latter links can be used for OTA upgrades too like ``OtaUrl http://ota.tasmo
- Command ``RfTimeout 100..60000`` to disable duplicate RfReceive. Default 1000 [#15061](https://github.com/arendst/Tasmota/issues/15061) - Command ``RfTimeout 100..60000`` to disable duplicate RfReceive. Default 1000 [#15061](https://github.com/arendst/Tasmota/issues/15061)
- Command ``IfxSensor 1`` to send non-teleperiod data to influxdb - Command ``IfxSensor 1`` to send non-teleperiod data to influxdb
- Commands ``Sensor12 D0 .. D5, S0 .. S5`` allowing differential or single-ended modes [#15001](https://github.com/arendst/Tasmota/issues/15001) - Commands ``Sensor12 D0 .. D5, S0 .. S5`` allowing differential or single-ended modes [#15001](https://github.com/arendst/Tasmota/issues/15001)
- Commands ``Sensor34 10 <valueA>`` and ``Sensor34 11 <valueB>`` to use HX711 absolute weight conversion [#15292](https://github.com/arendst/Tasmota/issues/15292)
- NeoPool commands ``NPpHMin``, ``NPpHMax``, ``NPpH``, ``NPRedox``, ``NPHydrolysis``, ``NPIonization``, ``NPChlorine`` and ``NPControl`` [#15015](https://github.com/arendst/Tasmota/issues/15015) - NeoPool commands ``NPpHMin``, ``NPpHMax``, ``NPpH``, ``NPRedox``, ``NPHydrolysis``, ``NPIonization``, ``NPChlorine`` and ``NPControl`` [#15015](https://github.com/arendst/Tasmota/issues/15015)
- NeoPool system voltages display - NeoPool system voltages display
- TasmotaSerial implement ``end()`` - TasmotaSerial implement ``end()``

View File

@ -627,7 +627,7 @@ void SettingsSave(uint8_t rotate) {
Settings->cfg_size = sizeof(TSettings); Settings->cfg_size = sizeof(TSettings);
Settings->cfg_crc = GetSettingsCrc(); // Keep for backward compatibility in case of fall-back just after upgrade Settings->cfg_crc = GetSettingsCrc(); // Keep for backward compatibility in case of fall-back just after upgrade
Settings->cfg_crc32 = GetSettingsCrc32(); Settings->cfg_crc32 = GetSettingsCrc32();
#ifdef USE_COUNTER #ifdef USE_COUNTER
CounterInterruptDisable(true); CounterInterruptDisable(true);
#endif #endif
#ifdef ESP8266 #ifdef ESP8266
@ -655,7 +655,7 @@ void SettingsSave(uint8_t rotate) {
} }
#endif // FIRMWARE_MINIMAL #endif // FIRMWARE_MINIMAL
RtcSettingsSave(); RtcSettingsSave();
#ifdef USE_COUNTER #ifdef USE_COUNTER
CounterInterruptDisable(false); CounterInterruptDisable(false);
#endif #endif
} }
@ -1489,11 +1489,11 @@ void SettingsDelta(void) {
Settings->flag5.disable_referer_chk |= true; Settings->flag5.disable_referer_chk |= true;
#endif #endif
} }
if (Settings->version < 0x09050009) { if (Settings->version < 0x09050009) { // 9.5.0.9
memset(&Settings->energy_kWhtoday_ph, 0, 36); memset(&Settings->energy_kWhtoday_ph, 0, 36);
memset(&RtcSettings.energy_kWhtoday_ph, 0, 24); memset(&RtcSettings.energy_kWhtoday_ph, 0, 24);
} }
if (Settings->version < 0x0A000003) { if (Settings->version < 0x0A000003) { // 10.0.0.3
if (0 == Settings->param[P_ARP_GRATUITOUS]) { if (0 == Settings->param[P_ARP_GRATUITOUS]) {
Settings->param[P_ARP_GRATUITOUS] = WIFI_ARP_INTERVAL; Settings->param[P_ARP_GRATUITOUS] = WIFI_ARP_INTERVAL;
#ifdef USE_TLS #ifdef USE_TLS
@ -1506,16 +1506,20 @@ void SettingsDelta(void) {
#endif #endif
} }
} }
if (Settings->version < 0x0A010003) { if (Settings->version < 0x0A010003) { // 10.1.0.3
Settings->sserial_config = Settings->serial_config; Settings->sserial_config = Settings->serial_config;
} }
if (Settings->version < 0x0A010006) { if (Settings->version < 0x0A010006) { // 10.1.0.6
Settings->web_time_start = 0; Settings->web_time_start = 0;
Settings->web_time_end = 0; Settings->web_time_end = 0;
} }
if (Settings->version < 0x0B000003) { // 11.0.0.3 if (Settings->version < 0x0B000003) { // 11.0.0.3
memcpy(Settings->pulse_timer, Settings->ex_pulse_timer, 16); memcpy(Settings->pulse_timer, Settings->ex_pulse_timer, 16);
} }
if (Settings->version < 0x0B000006) { // 11.0.0.6
Settings->weight_absconv_a = 0;
Settings->weight_absconv_b = 0;
}
Settings->version = VERSION; Settings->version = VERSION;
SettingsSave(1); SettingsSave(1);

View File

@ -20,6 +20,6 @@
#ifndef _TASMOTA_VERSION_H_ #ifndef _TASMOTA_VERSION_H_
#define _TASMOTA_VERSION_H_ #define _TASMOTA_VERSION_H_
const uint32_t VERSION = 0x0B000005; // 11.0.0.5 const uint32_t VERSION = 0x0B000006; // 11.0.0.6
#endif // _TASMOTA_VERSION_H_ #endif // _TASMOTA_VERSION_H_

View File

@ -52,13 +52,15 @@
#define HX_GAIN_32 2 // Channel B, gain factor 32 #define HX_GAIN_32 2 // Channel B, gain factor 32
#define HX_GAIN_64 3 // Channel A, gain factor 64 #define HX_GAIN_64 3 // Channel A, gain factor 64
#define D_JSON_WEIGHT_REF "WeightRef"
#define D_JSON_WEIGHT_CAL "WeightCal"
#define D_JSON_WEIGHT_MAX "WeightMax"
#define D_JSON_WEIGHT_ITEM "WeightItem"
#define D_JSON_WEIGHT_CHANGE "WeightChange"
#define D_JSON_WEIGHT_RAW "WeightRaw" #define D_JSON_WEIGHT_RAW "WeightRaw"
#define D_JSON_WEIGHT_DELTA "WeightDelta" #define D_JSON_WEIGHT_REF "Ref"
#define D_JSON_WEIGHT_CAL "Cal"
#define D_JSON_WEIGHT_MAX "Max"
#define D_JSON_WEIGHT_ITEM "Item"
#define D_JSON_WEIGHT_CHANGE "Change"
#define D_JSON_WEIGHT_DELTA "Delta"
#define D_JSON_WEIGHT_ABSC_A "AbsConvA"
#define D_JSON_WEIGHT_ABSC_B "AbsConvB"
enum HxCalibrationSteps { HX_CAL_END, HX_CAL_LIMBO, HX_CAL_FINISH, HX_CAL_FAIL, HX_CAL_DONE, HX_CAL_FIRST, HX_CAL_RESET, HX_CAL_START }; enum HxCalibrationSteps { HX_CAL_END, HX_CAL_LIMBO, HX_CAL_FINISH, HX_CAL_FAIL, HX_CAL_DONE, HX_CAL_FIRST, HX_CAL_RESET, HX_CAL_START };
@ -187,85 +189,83 @@ void SetWeightDelta(void) {
* Sensor34 8 0 - Disable JSON weight change message * Sensor34 8 0 - Disable JSON weight change message
* Sensor34 8 1 - Enable JSON weight change message * Sensor34 8 1 - Enable JSON weight change message
* Sensor34 9 <weight code> - Set minimum delta to trigger JSON message * Sensor34 9 <weight code> - Set minimum delta to trigger JSON message
* Sensor34 10 <value A> - Set A = a * 10^9 for raw to absolute weight conversion: y=a*x+b
* Sensor34 11 <value B> - Set B = b * 10^6 for raw to absolute weight conversion: y=a*x+b
\*********************************************************************************************/ \*********************************************************************************************/
bool HxCommand(void) { bool HxCommand(void) {
bool serviced = true; bool serviced = true;
bool show_parms = false; bool show_parms = true;
char argument[XdrvMailbox.data_len]; char argument[XdrvMailbox.data_len];
long value = 0;
for (uint32_t ca = 0; ca < XdrvMailbox.data_len; ca++) { for (uint32_t ca = 0; ca < XdrvMailbox.data_len; ca++) {
if ((' ' == XdrvMailbox.data[ca]) || ('=' == XdrvMailbox.data[ca])) { XdrvMailbox.data[ca] = ','; } if ((' ' == XdrvMailbox.data[ca]) || ('=' == XdrvMailbox.data[ca])) { XdrvMailbox.data[ca] = ','; }
} }
bool any_value = (strchr(XdrvMailbox.data, ',') != nullptr);
if (any_value) { value = strtol(ArgV(argument, 2), nullptr, 10); }
switch (XdrvMailbox.payload) { switch (XdrvMailbox.payload) {
case 1: // Reset scale case 1: // Reset scale
HxReset(); HxReset();
Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, "Reset"); Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, "Reset");
show_parms = false;
break; break;
case 2: // Calibrate case 2: // Calibrate
if (strchr(XdrvMailbox.data, ',') != nullptr) { if (any_value) { Settings->weight_reference = value; }
Settings->weight_reference = strtol(ArgV(argument, 2), nullptr, 10);
}
Hx.scale = 1; Hx.scale = 1;
HxReset(); HxReset();
Hx.calibrate_step = HX_CAL_START; Hx.calibrate_step = HX_CAL_START;
Hx.calibrate_timer = 1; Hx.calibrate_timer = 1;
HxCalibrationStateTextJson(3); HxCalibrationStateTextJson(3);
show_parms = false;
break; break;
case 3: // WeightRef to user reference case 3: // WeightRef to user reference
if (strchr(XdrvMailbox.data, ',') != nullptr) { if (any_value) { Settings->weight_reference = value; }
Settings->weight_reference = strtol(ArgV(argument, 2), nullptr, 10);
}
show_parms = true;
break; break;
case 4: // WeightCal to user calculated value case 4: // WeightCal to user calculated value
if (strchr(XdrvMailbox.data, ',') != nullptr) { if (any_value) {
Settings->weight_calibration = strtol(ArgV(argument, 2), nullptr, 10); Settings->weight_calibration = value;
Hx.scale = Settings->weight_calibration; Hx.scale = Settings->weight_calibration;
} }
show_parms = true;
break; break;
case 5: // WeightMax case 5: // WeightMax
if (strchr(XdrvMailbox.data, ',') != nullptr) { if (any_value) { Settings->weight_max = value; }
Settings->weight_max = strtol(ArgV(argument, 2), nullptr, 10) / 1000;
}
show_parms = true;
break; break;
case 6: // WeightItem case 6: // WeightItem
if (strchr(XdrvMailbox.data, ',') != nullptr) { if (strchr(XdrvMailbox.data, ',') != nullptr) {
Settings->weight_item = (unsigned long)(CharToFloat(ArgV(argument, 2)) * 10); Settings->weight_item = (unsigned long)(CharToFloat(ArgV(argument, 2)) * 10);
} }
show_parms = true;
break; break;
case 7: // WeightSave case 7: // WeightSave
Settings->energy_frequency_calibration = Hx.weight; Settings->energy_frequency_calibration = Hx.weight;
Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, PSTR(D_JSON_DONE)); Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, PSTR(D_JSON_DONE));
show_parms = false;
break; break;
case 8: // Json on weight change case 8: // Json on weight change
if (strchr(XdrvMailbox.data, ',') != nullptr) { if (any_value) { Settings->SensorBits1.hx711_json_weight_change = value &1; }
Settings->SensorBits1.hx711_json_weight_change = strtol(ArgV(argument, 2), nullptr, 10) & 1;
}
show_parms = true;
break; break;
case 9: // WeightDelta case 9: // WeightDelta
if (strchr(XdrvMailbox.data, ',') != nullptr) { if (any_value) {
Settings->weight_change = strtol(ArgV(argument, 2), nullptr, 10); Settings->weight_change = value;
SetWeightDelta(); SetWeightDelta();
} }
show_parms = true;
break; break;
default: case 10: // AbsoluteConversion, A
show_parms = true; if (any_value) { Settings->weight_absconv_a = value; }
break;
case 11: // AbsoluteConversion, B
if (any_value) { Settings->weight_absconv_b = value; }
break;
} }
if (show_parms) { if (show_parms) {
char item[33];
dtostrfd((float)Settings->weight_item / 10, 1, item);
Response_P(PSTR("{\"Sensor34\":{\"" D_JSON_WEIGHT_REF "\":%d,\"" D_JSON_WEIGHT_CAL "\":%d,\"" D_JSON_WEIGHT_MAX "\":%d,\"" Response_P(PSTR("{\"Sensor34\":{\"" D_JSON_WEIGHT_REF "\":%d,\"" D_JSON_WEIGHT_CAL "\":%d,\"" D_JSON_WEIGHT_MAX "\":%d,\""
D_JSON_WEIGHT_ITEM "\":%s,\"" D_JSON_WEIGHT_CHANGE "\":\"%s\",\"" D_JSON_WEIGHT_DELTA "\":%d}}"), D_JSON_WEIGHT_ITEM "\":%1_f,\"" D_JSON_WEIGHT_CHANGE "\":\"%s\",\"" D_JSON_WEIGHT_DELTA "\":%d,\""
D_JSON_WEIGHT_ABSC_A "\":%d,\"" D_JSON_WEIGHT_ABSC_B "\":%d}}"),
Settings->weight_reference, Settings->weight_calibration, Settings->weight_max * 1000, Settings->weight_reference, Settings->weight_calibration, Settings->weight_max * 1000,
item, GetStateText(Settings->SensorBits1.hx711_json_weight_change), Settings->weight_change); &Settings->weight_item, GetStateText(Settings->SensorBits1.hx711_json_weight_change), Settings->weight_change,
Settings->weight_absconv_a, Settings->weight_absconv_b);
} }
return serviced; return serviced;
@ -445,13 +445,17 @@ void HxShow(bool json) {
uint16_t count = 0; uint16_t count = 0;
float weight = 0; float weight = 0;
if (Hx.calibrate_step < HX_CAL_FAIL) { if (Hx.calibrate_step < HX_CAL_FAIL) {
if (Hx.weight && Settings->weight_item) { if ((Settings->weight_absconv_a != 0) && (Settings->weight_absconv_b != 0)) {
count = (Hx.weight * 10) / Settings->weight_item; weight = (float)Settings->weight_absconv_a / 1e9 * Hx.raw + (float)Settings->weight_absconv_b / 1e6;
if (count > 1) { } else {
snprintf_P(scount, sizeof(scount), PSTR(",\"" D_JSON_COUNT "\":%d"), count); if (Hx.weight && Settings->weight_item) {
count = (Hx.weight * 10) / Settings->weight_item;
if (count > 1) {
snprintf_P(scount, sizeof(scount), PSTR(",\"" D_JSON_COUNT "\":%d"), count);
}
} }
weight = (float)Hx.weight / 1000; // kilograms
} }
weight = (float)Hx.weight / 1000; // kilograms
} }
char weight_chr[33]; char weight_chr[33];
dtostrfd(weight, Settings->flag2.weight_resolution, weight_chr); dtostrfd(weight, Settings->flag2.weight_resolution, weight_chr);