HLW8012 Power Sensor¶
hlw8012 sensor platform allows you to use your HLW8012 voltage/current and power sensors
(datasheet) sensors with
ESPHome. This sensor is commonly found in Sonoff POWs. CSE7759 and BL0937 are similar to HLW8012
and work with this integration. Beware that CSE7759B is different and should be used
with the CSE7766 integration.
This sensor has two data outputs which both encode values using the frequency of a modulated signal: CF and CF1. CF’s frequency is proportional to the (active) power measured and CF1 is proportional to the current/voltage. Using the SEL pin, one can choose between which mode to use.
ESPHome will continuously cycle the state of the SEL pin to measure current and voltage, though both cannot be measured at the same exact points in time.
# Example configuration entry sensor: - platform: hlw8012 sel_pin: 5 cf_pin: 14 cf1_pin: 13 current: name: "HLW8012 Current" voltage: name: "HLW8012 Voltage" power: name: "HLW8012 Power" energy: name: "HLW8012 Energy" update_interval: 60s
The configuration above should work for Sonoff POWs (R1).
sel_pin (Required, Pin Schema): The pin SEL is connected to.
cf_pin (Required, Pin): The pin CF is connected to.
cf1_pin (Required, Pin): The pin CF1 is connected to.
current (Optional): Use the current value of the sensor in amperes. All options from Sensor.
power (Optional): Use the (active) power value of the sensor in watts. All options from Sensor.
voltage (Optional): Use the voltage value of the sensor in V (RMS). All options from Sensor.
energy (Optional): Use the total energy value of the sensor in Wh. All options from Sensor.
update_interval (Optional, Time): The interval to check the sensor. Defaults to
current_resistor (Optional, float): The value of the shunt resistor for current measurement. Defaults to the Sonoff POW’s value
voltage_divider (Optional, float): The value of the voltage divider on the board as
(R_upstream + R_downstream) / R_downstream. Defaults to the Sonoff POW’s value
change_mode_every (Optional, int): After how many updates to cycle between the current/voltage measurement mode. Note that the first value after switching is discarded because it is often inaccurate. Defaults to
initial_mode (Optional, string): The initial measurement mode. Defaults to
VOLTAGE. Possible initial measurement modes are
Permanent SEL Pin¶
Some devices have the SEL pin permanently pulled high or low. If this is the case, you can configure the initial measurement mode to match whichever mode the device uses, and disable mode switching.
# Example configuration entry for device with fixed measurement mode sensor: - platform: hlw8012 sel_pin: 5 cf_pin: 14 cf1_pin: 13 current: name: "HLW8012 Current" voltage: name: "HLW8012 Voltage" power: name: "HLW8012 Power" update_interval: 60s initial_mode: CURRENT change_mode_every: 4294967295