* Updates to atm90e32 according to PR according to #982
This commit is contained in:
John 2020-03-12 16:44:09 -04:00 committed by GitHub
parent 54a5f214b4
commit cfe5031977
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -33,6 +33,108 @@ The `CircuitSetup Expandable 6 Channel Energy Meter <https://circuitsetup.us/ind
CircuitSetup Expandable 6 Channel ESP32 Energy Meter Main Board. CircuitSetup Expandable 6 Channel ESP32 Energy Meter Main Board.
Configuration variables:
------------------------
- **cs_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The pin CS is connected to. For the 6 channel meter main board, this will always be 5 and 4. For the add-on boards a jumper can be selected for each CS pin, but default to 0 and 16.
- **line_frequency** (**Required**, string): The AC line frequency of the supply voltage. One of ``50Hz``, ``60Hz``.
- **phase_a** (*Optional*): The configuration options for the 1st phase.
- **voltage** (*Optional*): Use the voltage value of this phase in V (RMS).
All options from :ref:`Sensor <config-sensor>`.
- **current** (*Optional*): Use the current value of this phase in amperes. All options from
:ref:`Sensor <config-sensor>`.
- **power** (*Optional*): Use the power value on this phase in watts. All options from
:ref:`Sensor <config-sensor>`.
- **reactive_power** (*Optional*): Use the reactive power value on this phase. All options from
:ref:`Sensor <config-sensor>`.
- **power_factor** (*Optional*): Use the power factor value on this phase. All options from
:ref:`Sensor <config-sensor>`.
- **gain_voltage** (*Optional*, int): Voltage gain to scale the low voltage AC power pack to household mains feed.
Defaults to ``7305``.
- **gain_ct** (*Optional*, int): CT clamp calibration for this phase.
Defaults to ``27961``.
- **phase_b** (*Optional*): The configuration options for the 2nd phase. Same options as 1st phase.
- **phase_c** (*Optional*): The configuration options for the 3rd phase. Same options as 1st phase.
- **frequency** (*Optional*): Use the frequenycy value calculated by the meter. All options from
:ref:`Sensor <config-sensor>`.
- **chip_temperature** (*Optional*): Use the chip temperature value. All options from
:ref:`Sensor <config-sensor>`.
- **gain_pga** (*Optional*, string): The gain for the CT clamp, ``2X`` for 100A, ``4X`` for 100A - 200A. One of ``1X``, ``2X``, ``4X``.
Defaults to ``2X`` which is suitable for the popular SCT-013-000 clamp.
- **current_phases** (*Optional*): The number of phases the meter has, ``2`` or, ``3``
The 6 Channel Expandable Energy Meter should be set to ``3``, and the Split Single Phase meter should be set to ``2``. Defaults to ``3``.
- **update_interval** (*Optional*, :ref:`config-time`): The interval to check the sensor. Defaults to ``60s``.
- **spi_id** (*Optional*, :ref:`config-id`): Manually specify the ID of the :ref:`SPI Component <spi>` if you want
to use multiple SPI buses.
Calibration
-----------
This sensor needs calibration to show correct values. The default gain configuration is set to use the `SCT-013-000 <https://amzn.to/2E0KVvo>` current transformers with gain_pga set to 2X, and the `Jameco Reliapro 9v 120V AC transformer <https://amzn.to/2XcWJjI>` to measure voltage and supply power to the meter boards. A load which uses a known amount of current can be used to calibrate. For a more accurate calibration use a `Kill-A-Watt <https://amzn.to/2TXT7jx>` meter or similar. Mains voltages can fluctuate depending on grid load.
Voltage
^^^^^^^
Use the expected mains voltage for your region 110V/230V or plug in the Kill-A-Watt and select voltage. See what
value the ATM90E32 sensor reports for voltage. To adjust the sensor use the calculation:
``New gain_voltage = (your voltage reading / ESPHome voltage reading) * existing gain_voltage value``
Update **gain_voltage** for all phases in your ESPHome yaml, recompile and upload. Repeat as necessary.
Here are common voltage calibrations for the **Split Single Energy Meter**:
For meter <= v1.3:
- 42080 - 9v AC Transformer - Jameco 112336
- 32428 - 12v AC Transformer - Jameco 167151
For meter > v1.4:
- 37106 - 9v AC Transformer - Jameco 157041
- 38302 - 9v AC Transformer - Jameco 112336
- 29462 - 12v AC Transformer - Jameco 167151
For Meters >= v1.4 rev.3
- 3920 - 9v AC Transformer - Jameco 157041
Here are common voltage calibrations for the **Expandable 6 Channel Energy Meter**:
For meter <= v1.2:
- 42080 - 9v AC Transformer - Jameco 112336
- 32428 - 12v AC Transformer - Jameco 167151
For meter > v1.3:
- 7305 - 9v AC Transformer - Jameco 157041
Current
^^^^^^^
Switch on the current load and see what value the ATM90E32 sensor reports for
current on the selected phase. Using the known or measured current adjust the
sensor using calculation:
``New gain_ct = (your current reading / ESPHome current reading) * existing gain_ct value``
Update **gain_ct** for the phase in your ESPHome yaml, recompile and upload. Repeat as necessary.
It is possible that the two identical CT current sensors will have different
**gain_ct** numbers due to variances in manufacturing, although it will be
small. The current calibration can be done once and used on all sensors or
repeated for each one.
Here are common current calibration values for the **Split Single Phase Energy Meter** when **gain_pga** is set to ``2X``:
- 20A/25mA SCT-006: 10170
- 100A/50mA SCT-013-000: 25498
- 120A/40mA SCT-016: 39473
- Magnalab 100A: 46539
Here are common current calibrations for the **Expandable 6 Channel Energy Meter** when **gain_pga** is set to ``1X``:
- 20A/25mA SCT-006: 11131
- 30A/1V SCT-013-030: 8650
- 50A/1V SCT-013-050: 15420
- 80A/26.6mA SCT-010: 41996
- 100A/50ma SCT-013-000: 27961
- 120A/40mA: SCT-016: 41880
Additional Examples
-------------------
.. code-block:: yaml .. code-block:: yaml
# Example configuration entry for split single phase meter # Example configuration entry for split single phase meter
@ -55,9 +157,9 @@ The `CircuitSetup Expandable 6 Channel Energy Meter <https://circuitsetup.us/ind
name: "EMON Reactive Power CT1" name: "EMON Reactive Power CT1"
power_factor: power_factor:
name: "EMON Power Factor CT1" name: "EMON Power Factor CT1"
gain_voltage: 41820 gain_voltage: 3920
gain_ct: 25498 gain_ct: 39473
phase_b: phase_c:
current: current:
name: "EMON CT2 Current" name: "EMON CT2 Current"
power: power:
@ -66,87 +168,17 @@ The `CircuitSetup Expandable 6 Channel Energy Meter <https://circuitsetup.us/ind
name: "EMON Reactive Power CT2" name: "EMON Reactive Power CT2"
power_factor: power_factor:
name: "EMON Power Factor CT2" name: "EMON Power Factor CT2"
gain_voltage: 41820 gain_voltage: 3920
gain_ct: 25498 gain_ct: 39473
frequency: frequency:
name: "EMON Line Frequency" name: "EMON Line Frequency"
chip_temperature: chip_temperature:
name: "EMON Chip Temperature" name: "EMON Chip Temperature"
line_frequency: 50Hz line_frequency: 50Hz
current_phases: 2
gain_pga: 2X gain_pga: 2X
update_interval: 60s update_interval: 60s
Configuration variables:
------------------------
- **cs_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The pin CS is connected to. For the 6 channel meter main board, this will always be 5 and 4. For the add-on boards a jumper can be selected for each CS pin, but default to 0 and 16.
- **line_frequency** (**Required**, string): The AC line frequency of the supply voltage. One of ``50Hz``, ``60Hz``.
- **phase_a** (*Optional*): The configuration options for the 1st phase.
- **voltage** (*Optional*): Use the voltage value of this phase in V (RMS).
All options from :ref:`Sensor <config-sensor>`.
- **current** (*Optional*): Use the current value of this phase in amperes. All options from
:ref:`Sensor <config-sensor>`.
- **power** (*Optional*): Use the power value on this phase in watts. All options from
:ref:`Sensor <config-sensor>`.
- **reactive_power** (*Optional*): Use the reactive power value on this phase. All options from
:ref:`Sensor <config-sensor>`.
- **power_factor** (*Optional*): Use the power factor value on this phase. All options from
:ref:`Sensor <config-sensor>`.
- **gain_voltage** (*Optional*, int): Voltage gain to scale the low voltage AC power pack to household mains feed.
Defaults to ``41820``.
- **gain_ct** (*Optional*, int): CT clamp calibration for this phase.
Defaults to ``25498``.
- **phase_b** (*Optional*): The configuration options for the 2nd phase. Same options as 1st phase.
- **phase_c** (*Optional*): The configuration options for the 3rd phase. Same options as 1st phase.
- **frequency** (*Optional*): Use the frequenycy value calculated by the meter. All options from
:ref:`Sensor <config-sensor>`.
- **chip_temperature** (*Optional*): Use the chip temperature value. All options from
:ref:`Sensor <config-sensor>`.
- **gain_pga** (*Optional*, string): The gain for the CT clamp, ``2X`` for 100A, ``4X`` for 100A - 200A. One of ``1X``, ``2X``, ``4X``.
Defaults to ``2X`` which is suitable for the popular SCT-013-000 clamp.
- **update_interval** (*Optional*, :ref:`config-time`): The interval to check the sensor. Defaults to ``60s``.
- **spi_id** (*Optional*, :ref:`config-id`): Manually specify the ID of the :ref:`SPI Component <spi>` if you want
to use multiple SPI buses.
Calibration
-----------
This sensor needs calibration to show correct values. The default gain configuration is set to use the `SCT-013-000 <https://amzn.to/2E0KVvo>`__
current transformers with gain_pga set to 2X, and the `Jameco Reliapro 9v AC transformer <https://amzn.to/2XcWJjI>`__.
A load which uses a known amount of current can be used to calibrate. For a more accurate calibration use a
`Kill-A-Watt <https://amzn.to/2TXT7jx>`__ meter or similar, mains voltages can fluctuate depending on grid load.
Voltage
^^^^^^^
Use the expected mains voltage for your region 110V/230V or plug in the Kill-A-Watt and select voltage. See what
value the ATM90E32 sensor reports for voltage. To adjust the sensor use the calculation:
``New gain_voltage = (your voltage reading / ESPHome voltage reading) * existing gain_voltage value``
Update **gain_voltage** for all phases in your ESPHome yaml, recompile and upload. Repeat as necessary.
Current
^^^^^^^
Switch on the current load and see what value the ATM90E32 sensor reports for
current on the selected phase. Using the known or measured current adjust the
sensor using calculation:
``New gain_ct = (your current reading / ESPHome current reading) * existing gain_ct value``
Update **gain_ct** for the phase in your ESPHome yaml, recompile and upload. Repeat as necessary.
It is possible that the two identical CT current sensors will have different
**gain_ct** numbers due to variances in manufacturing, although it will be
small. The current calibration can be done once and used on all sensors or
repeated for each one.
Additional Examples
-------------------
.. code-block:: yaml .. code-block:: yaml
# Example CircuitSetup 6-channel entry # Example CircuitSetup 6-channel entry
@ -164,26 +196,27 @@ Additional Examples
name: "EMON CT1 Current" name: "EMON CT1 Current"
power: power:
name: "EMON Active Power CT1" name: "EMON Active Power CT1"
gain_voltage: 47660 gain_voltage: 7305
gain_ct: 12577 gain_ct: 12577
phase_b: phase_b:
current: current:
name: "EMON CT2 Current" name: "EMON CT2 Current"
power: power:
name: "EMON Active Power CT2" name: "EMON Active Power CT2"
gain_voltage: 47660 gain_voltage: 7305
gain_ct: 12577 gain_ct: 12577
phase_c: phase_c:
current: current:
name: "EMON CT3 Current" name: "EMON CT3 Current"
power: power:
name: "EMON Active Power CT3" name: "EMON Active Power CT3"
gain_voltage: 47660 gain_voltage: 7305
gain_ct: 12577 gain_ct: 12577
frequency: frequency:
name: "EMON Line Frequency" name: "EMON Line Frequency"
line_frequency: 50Hz line_frequency: 50Hz
gain_pga: 2X current_phases: 3
gain_pga: 1X
update_interval: 60s update_interval: 60s
- platform: atm90e32 - platform: atm90e32
cs_pin: 4 cs_pin: 4
@ -192,36 +225,37 @@ Additional Examples
name: "EMON CT4 Current" name: "EMON CT4 Current"
power: power:
name: "EMON Active Power CT4" name: "EMON Active Power CT4"
gain_voltage: 47660 gain_voltage: 7305
gain_ct: 12577 gain_ct: 12577
phase_b: phase_b:
current: current:
name: "EMON CT5 Current" name: "EMON CT5 Current"
power: power:
name: "EMON Active Power CT5" name: "EMON Active Power CT5"
gain_voltage: 47660 gain_voltage: 7305
gain_ct: 12577 gain_ct: 12577
phase_c: phase_c:
current: current:
name: "EMON CT6 Current" name: "EMON CT6 Current"
power: power:
name: "EMON Active Power CT6" name: "EMON Active Power CT6"
gain_voltage: 47660 gain_voltage: 7305
gain_ct: 12577 gain_ct: 12577
line_frequency: 50Hz line_frequency: 50Hz
gain_pga: 2X current_phases: 3
gain_pga: 1X
update_interval: 60s update_interval: 60s
.. code-block:: yaml .. code-block:: yaml
# Example CircuitSetup 6-channel without jumpers jp9-jp11 joined # Example CircuitSetup 6-channel without jumpers jp9-jp11 joined or < meter v1.4
# power is calculated in a template # power is calculated in a template
substitutions: substitutions:
disp_name: 6C disp_name: 6C
update_time: 10s update_time: 10s
current_cal: '32498' current_cal: '27961'
spi: spi:
clk_pin: 18 clk_pin: 18
@ -253,7 +287,8 @@ Additional Examples
frequency: frequency:
name: ${disp_name} Freq A name: ${disp_name} Freq A
line_frequency: 60Hz line_frequency: 60Hz
gain_pga: 2X current_phases: 3
gain_pga: 1X
update_interval: ${update_time} update_interval: ${update_time}
- platform: atm90e32 - platform: atm90e32
cs_pin: 4 cs_pin: 4
@ -280,7 +315,8 @@ Additional Examples
frequency: frequency:
name: ${disp_name} Freq B name: ${disp_name} Freq B
line_frequency: 60Hz line_frequency: 60Hz
gain_pga: 2X current_phases: 3
gain_pga: 1X
update_interval: ${update_time} update_interval: ${update_time}
#Watts per channel #Watts per channel