Fix HLW8012

Fix Hlw8012/Bl0937 averages pulses over 200ms (#11722)
This commit is contained in:
Theo Arends 2021-04-14 17:47:04 +02:00
parent 1ac45bd66e
commit cb270198a2
1 changed files with 20 additions and 18 deletions

View File

@ -48,12 +48,15 @@ struct HLW {
#endif #endif
volatile uint32_t cf_pulse_length = 0; volatile uint32_t cf_pulse_length = 0;
volatile uint32_t cf_pulse_last_time = 0; volatile uint32_t cf_pulse_last_time = 0;
volatile uint32_t cf_summed_pulse_length = 0;
volatile uint32_t cf_pulse_counter = 0;
uint32_t cf_power_pulse_length = 0; uint32_t cf_power_pulse_length = 0;
volatile uint32_t cf1_pulse_length = 0; volatile uint32_t cf1_pulse_length = 0;
volatile uint32_t cf1_pulse_last_time = 0; volatile uint32_t cf1_pulse_last_time = 0;
volatile uint32_t cf1_summed_pulse_length = 0; volatile uint32_t cf1_summed_pulse_length = 0;
volatile uint32_t cf1_pulse_counter = 0; volatile uint32_t cf1_pulse_counter = 0;
uint32_t cf1_voltage_pulse_length = 0; uint32_t cf1_voltage_pulse_length = 0;
uint32_t cf1_current_pulse_length = 0; uint32_t cf1_current_pulse_length = 0;
@ -77,8 +80,7 @@ void HlwCfInterrupt(void) IRAM_ATTR;
void HlwCf1Interrupt(void) IRAM_ATTR; void HlwCf1Interrupt(void) IRAM_ATTR;
#endif // USE_WS2812_DMA #endif // USE_WS2812_DMA
void HlwCfInterrupt(void) // Service Power void HlwCfInterrupt(void) { // Service Power
{
uint32_t us = micros(); uint32_t us = micros();
if (Hlw.load_off) { // Restart plen measurement if (Hlw.load_off) { // Restart plen measurement
@ -87,13 +89,14 @@ void HlwCfInterrupt(void) // Service Power
} else { } else {
Hlw.cf_pulse_length = us - Hlw.cf_pulse_last_time; Hlw.cf_pulse_length = us - Hlw.cf_pulse_last_time;
Hlw.cf_pulse_last_time = us; Hlw.cf_pulse_last_time = us;
Hlw.cf_summed_pulse_length += Hlw.cf_pulse_length;
Hlw.cf_pulse_counter++;
Hlw.energy_period_counter++; Hlw.energy_period_counter++;
} }
Energy.data_valid[0] = 0; Energy.data_valid[0] = 0;
} }
void HlwCf1Interrupt(void) // Service Voltage and Current void HlwCf1Interrupt(void) { // Service Voltage and Current
{
uint32_t us = micros(); uint32_t us = micros();
Hlw.cf1_pulse_length = us - Hlw.cf1_pulse_last_time; Hlw.cf1_pulse_length = us - Hlw.cf1_pulse_last_time;
@ -113,8 +116,7 @@ void HlwCf1Interrupt(void) // Service Voltage and Current
/********************************************************************************************/ /********************************************************************************************/
void HlwEvery200ms(void) void HlwEvery200ms(void) {
{
uint32_t cf1_pulse_length = 0; uint32_t cf1_pulse_length = 0;
uint32_t hlw_w = 0; uint32_t hlw_w = 0;
uint32_t hlw_u = 0; uint32_t hlw_u = 0;
@ -125,6 +127,11 @@ void HlwEvery200ms(void)
Hlw.load_off = true; Hlw.load_off = true;
} }
Hlw.cf_power_pulse_length = Hlw.cf_pulse_length; Hlw.cf_power_pulse_length = Hlw.cf_pulse_length;
if (Hlw.cf_pulse_counter && !Hlw.load_off) {
Hlw.cf_power_pulse_length = Hlw.cf_summed_pulse_length / Hlw.cf_pulse_counter;
}
Hlw.cf_summed_pulse_length = 0;
Hlw.cf_pulse_counter = 0;
if (Hlw.cf_power_pulse_length && Energy.power_on && !Hlw.load_off) { if (Hlw.cf_power_pulse_length && Energy.power_on && !Hlw.load_off) {
hlw_w = (Hlw.power_ratio * Settings.energy_power_calibration) / Hlw.cf_power_pulse_length ; // W *10 hlw_w = (Hlw.power_ratio * Settings.energy_power_calibration) / Hlw.cf_power_pulse_length ; // W *10
@ -195,8 +202,7 @@ void HlwEvery200ms(void)
} }
} }
void HlwEverySecond(void) void HlwEverySecond(void) {
{
if (Energy.data_valid[0] > ENERGY_WATCHDOG) { if (Energy.data_valid[0] > ENERGY_WATCHDOG) {
Hlw.cf1_voltage_pulse_length = 0; Hlw.cf1_voltage_pulse_length = 0;
Hlw.cf1_current_pulse_length = 0; Hlw.cf1_current_pulse_length = 0;
@ -215,8 +221,7 @@ void HlwEverySecond(void)
} }
} }
void HlwSnsInit(void) void HlwSnsInit(void) {
{
if (!Settings.energy_power_calibration || (4975 == Settings.energy_power_calibration)) { if (!Settings.energy_power_calibration || (4975 == Settings.energy_power_calibration)) {
Settings.energy_power_calibration = HLW_PREF_PULSE; Settings.energy_power_calibration = HLW_PREF_PULSE;
Settings.energy_voltage_calibration = HLW_UREF_PULSE; Settings.energy_voltage_calibration = HLW_UREF_PULSE;
@ -245,8 +250,7 @@ void HlwSnsInit(void)
attachInterrupt(Pin(GPIO_HLW_CF), HlwCfInterrupt, FALLING); attachInterrupt(Pin(GPIO_HLW_CF), HlwCfInterrupt, FALLING);
} }
void HlwDrvInit(void) void HlwDrvInit(void) {
{
Hlw.model_type = 0; // HLW8012 Hlw.model_type = 0; // HLW8012
if (PinUsed(GPIO_HJL_CF)) { if (PinUsed(GPIO_HJL_CF)) {
SetPin(Pin(GPIO_HJL_CF), AGPIO(GPIO_HLW_CF)); SetPin(Pin(GPIO_HJL_CF), AGPIO(GPIO_HLW_CF));
@ -275,8 +279,7 @@ void HlwDrvInit(void)
} }
} }
bool HlwCommand(void) bool HlwCommand(void) {
{
bool serviced = true; bool serviced = true;
if ((CMND_POWERCAL == Energy.command_code) || (CMND_VOLTAGECAL == Energy.command_code) || (CMND_CURRENTCAL == Energy.command_code)) { if ((CMND_POWERCAL == Energy.command_code) || (CMND_VOLTAGECAL == Energy.command_code) || (CMND_CURRENTCAL == Energy.command_code)) {
@ -306,8 +309,7 @@ bool HlwCommand(void)
* Interface * Interface
\*********************************************************************************************/ \*********************************************************************************************/
bool Xnrg01(uint8_t function) bool Xnrg01(uint8_t function) {
{
bool result = false; bool result = false;
switch (function) { switch (function) {