Skip to content

Commit

Permalink
Adds documentation for pulse meter functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
mmmichl committed Jun 2, 2024
1 parent 2e2fe38 commit 154c574
Show file tree
Hide file tree
Showing 6 changed files with 27 additions and 8 deletions.
26 changes: 22 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -201,14 +201,32 @@ Depending on your HP model, SG3 might be configurable in "ECO mode", "Normal mod
Note: Smart Grid needs to be switched ON in the heatpump configuration menu, otherwise SG1 and SG2 contacts are not evaluated.

## Step 5 (optional) - Pulse Meter feature
_Needs step 4 - Smart grid features_
ESPaltherma can communicate how much energy the HP should consume via a pulse meter. For this, uncomment and confugre `PIN_PULSE`, `PULSES_PER_kWh` and `PULSE_DURATION_MS` in `src/setup.h`. Send energy amount in Watt to MQTT channel `espaltherma/pulse/set`. Current Watt setting is available in `espaltherma/pulse/state`.

*TODO more close description what it is to do*
### Hardware
Similar to the SG1 and SG2 connections, an additional relay is needed for the pulse meter. As relays have a rather limited cycle count and switching is slow, it is strongly recommended to use alternatives like optocouplers. The relay/optocoupler needs to be connected to the S4S contacts of your heat pump and needs a 200 Ohm resistor on the positive side of the connection.

Note the limits to reporded Watt. Both limits depend on
For the optocoupler I used the [LTV 815](https://cdn-reichelt.de/documents/datenblatt/A200/LTV815_LTV825_LTV845_LIT.pdf). Be aware of the supported Voltage. On my heat pump I measured between 12 and 20 Volt on all connections (SG1, SG2 and Smart Grid). Here is the resulting PCB, note that also the SG1, SG2 contacts as well as the serial connection is implemented. _Important: The 200 Ohm resistor on the Smart Grid (S4S) connection is missing_

<img src="doc/images/PCB_bottom.jpg" width="250" style="display: inline"/> <img src="doc/images/PCB_top.jpg" width="200" /> <img src="doc/images/PCB_wiring.jpg" width="200" />

### Heat Pump Settings
[9.A.2] Installer settings > Energy Metering > Electricity meter 2: Set to "1000/kWh for PV-Panel". Keep this in sync with the `PULSES_PER_kWh` setting in `src/setup.h`.

Possibly following settings are also needed
[9.8.4] Installer settings > Benefit kWh power supply > Benefit kWh power supply: Set to "Smartgrid"

### Usage
Set the Smart Grid value to "2 - Recommended ON" and set a set the _excess power_ in Watt in the MQTT channel `espaltherma/pulse/set`.

Be aware, that this is not a direct command for the heat pump. It was build to be an information of a smart meter, thus the heat pumpt decides wheather or not to turn on. Could very well be, that the heat pump needs to see a certain level of power over a duration of time.
Also when the heat pump starts, the reported "excess power" needs to decrease. Unless you know what you do, it would be wise to report the exported power as seen by your smart meter!

Note the limits to the reporded power. Limits are depnendend on these settings:
* `PULSES_PER_kWh` (default is 1000)
* `PULSE_DURATION_MS` (default is 75)
For these defaults, the minimum reported power is 60 and the maximum is 21 kWh. If you need to represent more power, try reducing `PULSE_DURATION_MS`. If this is not sufficient, adapt `PULSES_PER_kWh` but keep it in sync with the HP setting.
* `PULSE_DURATION_MS` (default is 50)
For the above defaults, the minimum reported power is 60 W and the maximum is 18 kWh. If you need to represent more power, try reducing `PULSE_DURATION_MS` to at most 10. If this is not sufficient, adapt `PULSES_PER_kWh` but keep it in sync with the heat pump setting.

# Troubleshooting

Expand Down
Binary file added doc/images/PCB_bottom.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/images/PCB_top.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/images/PCB_wiring.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
7 changes: 4 additions & 3 deletions include/mqtt.h
Original file line number Diff line number Diff line change
Expand Up @@ -270,9 +270,10 @@ void callbackPulse(byte *payload, unsigned int length)
target_watt = (long) WH_PER_PULSE * 60;
Serial.printf("Capping pulse to %d Watt to ensure pulse rate is <= 60 sec\n", target_watt);
}
if (ms_until_pulse < 20) {
// ensure a 20 ms gap between two pulses
ms_until_pulse = 20;
if (ms_until_pulse < 100) {
// ensure a 100 ms gap between two pulses
// taken from https://www.manualslib.de/manual/480757/Daikin-Brp069A61.html?page=10#manual
ms_until_pulse = 100;
long original_target = target_watt;
target_watt = (long) ((1000 * WH_PER_PULSE * 3600) / (ms_until_pulse + PULSE_DURATION_MS));
Serial.printf("WARNING pulse frequency to high, capping at %d Watt! Target is %d Watt. Decrease PULSE_DURATION or PULSES_PER_kWh\n", target_watt, original_target);
Expand Down
2 changes: 1 addition & 1 deletion src/setup.h
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@
//Uncomment and set to enable Pulse Meter mqtt functions
// #define PIN_PULSE 25// Pin connected to pulse meter relay
// #define PULSES_PER_kWh 1000 // match setting on HP (TODO hint for setting path)
// #define PULSE_DURATION_MS 75 // Duration of the pulse, decrease on very high energy settings (TODO give example)
// #define PULSE_DURATION_MS 50 // Duration of the pulse, decrease on very high energy settings (TODO give example)
// #define PULSE_LED_BUILTIN 1 // also pulse the build in LED

// DO NOT CHANGE: Defines the SG active/inactive relay states, according to the definition of the trigger status
Expand Down

0 comments on commit 154c574

Please sign in to comment.