rasProject_01 / weSweetHome  R. 240
process control       /     RasPi software         by   weinert-automation
Loading...
Searching...
No Matches
sweetHome2.h File Reference

Types, values and functions for a smart home project. More...

#include "weBatt.h"
#include "weStateM.h"
#include "sweetHome.h"
#include "weGPIOd.h"
#include "weModbus.h"
#include "mqttHome.h"
#include "we1wire.h"
#include <errno.h>

Macros

#define BATu
 Battery unload (hi active via open drain; gr/gr-ws)
 
#define BEFORE_RISE
 Before sunrise timer offset. More...
 
#define CHS_CP_OFFSET
 CP signal PWM correction offset. More...
 
#define CONb
 Inverter to battery step up (dto.; ws/ge-ws)
 
#define CONcarLd
 Contactor (relay) power to car is ON (low active)
 
#define CONcarRq
 Car (CP resistor 2k7) connected / ready (low active)
 
#define HYPr
 Bat. to /ref Hippogreiff (dto. ws/gn)
 
#define isOnPPSrel()
 Check if the phase power switch control relay is on.
 
#define LED9
 life LED hi active
 
#define LEDx
 other LED hi active (currently unused, always on)
 
#define offPort(N)
 Switch port N off. More...
 
#define offRel(N)
 Switch relay N off. More...
 
#define onPort(N)
 Switch port N on. More...
 
#define onRel(N)
 Switch relay N on. More...
 
#define PCK_POWER_IND_MAX
 phase packet control limit 200%
 
#define PCK_POWER_LIM_DEF
 phase packet default limit 3,6kW
 
#define PCK_POWER_LIM_MAX
 phase packet max. limit
 
#define PCK_POWER_REL
 phase packet switch control relay
 
#define PDEL_BALEND
 Minimal delivery power to stop ballast. More...
 
#define PDEL_BALINC
 Maximal delivery power not to add ballast. More...
 
#define PDEL_BALRED
 Minimal delivery power to reduce ballast. More...
 
#define PDEL_SGCONS
 Minimal delivery power (W) to signal consumer.
 
#define PDEL_SGGIVE
 Maximal delivery power to signal give away. More...
 
#define PH_P_SSR1
 Phase packet switch SSR1 (heater element 1)
 
#define PH_P_SSR2
 Phase packet switch SSR2 (heater element 2)
 
#define POWH
 Power module voltage control (li/br-ws).
 
#define ppsContPow
 phase packet switch: contactor power /W
 
#define PWMcarLd
 PWM to control max. car load current (per phase)
 
#define SENS0PATH
 Temperature of water tank (top level). More...
 
#define SENS1PATH
 Temperature of hot water pipe (from tank top).since 12 23: 28-6fb4d443009b. More...
 
#define SENS2PATH
 Temperature of water tank (bottom level). More...
 
#define switchPPSrel(V)
 Actuate phase power switch control relay. More...
 
#define switchRel(N, V)
 Switch relay N on or off. More...
 

Functions

uint8_t pckSwPec (float power)
 Set and get package switch percentage by power. More...
 
void reduceBatLoadPWM (uint8_t const pwmRed)
 Reduce battery loader module PWM. More...
 
void setBatLoadPWM (uint8_t pwm)
 Set battery loader module PWM. More...
 
uint8_t setPckSwPerc (uint8_t perc)
 Set package switch percentage. More...
 
float setPhPckLimit (float powerLimit)
 Set and get package switch power limit. More...
 
void switchBatToStepUp (uint8_t on)
 Switch battery to step up converter. More...
 
void switchHotWpump (uint8_t const on)
 Hot water comfort pump turn on/off. More...
 
void switchInvToBatUnl (uint8_t on)
 Switch inverter to battery unload. More...
 

Variables

state_t batCntBalSeq
 Battery controlled load as ballast.
 
state_t batCntLodSeq
 Battery loading and keeping.
 
state_t batKeepInh
 Inhibit battery keep alive loading. More...
 
int batUnloadAllowed
 Battery unload allowed. More...
 
state_t batUnloadSeq
 Battery controlled unload via inverter.
 
uint8_t batVoltValid
 The measured battery voltage is valid. More...
 
state_t befRiseTimer
 Before sunrise timer. More...
 
state_t consumeGiveHyst
 Give away hysteresis. More...
 
state_t consumeGiveSFC
 Give away state machine / SFC. More...
 
state_t dawnTimer
 Dawn timer. More...
 
state_t duskTimer
 Dusk timer. More...
 
uint8_t heaterAllowed
 phase packet load enabled (always)
 
int hippoSwitchMode
 Hippogreiff on/off times. More...
 
state_t load250Wcont
 Controlled load SFC.
 
volatile uint8_t phPckCnt
 current switch state duration counter
 
volatile uint8_t phPckOff
 current phase packet switch OFF duration
 
volatile uint8_t phPckOn
 current phase packet switch ON duration
 
volatile uint8_t phPckRelOffDelay
 PPS relay off delay.
 
volatile uint8_t phPckS2
 heater 2 pps switch state: 0 off; 1 on
 
volatile uint8_t phPckSw
 phase packet switch state: 0 off; 1 on
 
volatile uint8_t phPckSwIndex
 Actual index (0..200%) determining power. More...
 
volatile uint8_t phPpow2
 heater 2 power * 50% (0:0% .. 2:100%)
 
oneWireDevice_t sensors [3]
 The 1-wire sensors used.
 
state_t solarPowerHyst
 Solar power producer hysteresis.
 
state_t sunriseTimer
 Sunrise timer. More...
 
state_t sunsetTimer
 Sunset timer. More...
 
state_t wouldGive250WHyst
 Would give away 250W hysteresis. More...
 
state_t wouldGiveAwayHyst
 Would give away hysteresis. More...
 

Detailed Description

Types, values and functions for a smart home project.

Copyright (c) 2018 - 2024 Albrecht Weinert
weinert-automation.de a-weinert.de
/ / /\
/ /___ / \ |
\ /____\ /____\ | _|__
\ /\ / \ / \| |
\/ \/ \__/ \__/|_

Revision history

Rev. 266 10.10.2024
Rev. 99 29.01.2018 : load module voltage handling added
Rev. 148 16.06.2018 : battery ballast handling improved, Hippogreiff relay
Rev. 170 24.07.2018 : temperature sensors documentation
Rev. 190 12.02.2019 : remove 4 status relay output as (minimal) preparation
for VDE-AR-N 4105 evaluation and inverter cut off
Rev. 192 16.02.2019 : REL2 3 interchanged (2 now extra meter cut off)
Rev. 218 07.09.2019 : MQTT excerpted to mqttHome.h
Rev. 241 12.08.2021 : battery values updated (200Ah ++)
Rev. 245 24.02.2023 : battery keep 24 -> 12.5V
Rev. 252 17.08.2023 : ECar loading ++
Rev. 255 17.03.2024 : flexible /ref Hippogreiff switching times
Rev. 256 19.06.2024 : max. battery load voltages reduced
Rev. 259 04.08.2022 : battery changed to ECO-WORTHY 12.8V 100Ah LiFePO4 Akku
oneWireDevice_t sensors[3]
The 1-wire sensors used.
Definition: sweetHome2.c:56

This file is the addendum to sweetHome.h and sweetHome.c. It contains process IO related issues. These are not necessary for programs related to pure HMI, logging and the like. For those programs sweetHome.h and sweetHome.c will be sufficient.

In the smart home under control, there's one smart meter for the whole house's public electricity supply and one for solar generators and battery storage. The (two, cf. ANZmodSLAVES) meters are connected by Modbus. Additionally and also via Modbus, a Growatt inverter offers power and other values. Those are made available via an extra Pi acting as Modbus to MQTT bridge.

GPIO usage

See also file /forDSocu/Raspi3ioPinsMeterPi.ods

GPIO pins are used to control relays, LEDs and one button in the Pi's immediate neighbourhood. Three open drain (module) outputs control slightly remote (10m) periphery via shielded cable.

This program uses eight relays (one 10A change over contact each) in an eight relays module. The relays are energised by an active low "Din" (n:1..8) signal.

Eight 10A relays module connected via RS485 converter/shield pin connectors

module : Gnd Di1 Di2 Di3 Di4 Di5 Di6 Di7 Di8 3V3 Gnd 5V
colour : brn blk wht gry vio blu grn yel ora red brn red
RS conv.: Gnd P0 P1 P2 P3 P4 P5 P6 P7 3.3V Gnd 5V
Pi Pin : 6&c 11 12 13 15 16 18 22 3 1 &c 6&c 2&3
GPIO Pi3: 17 18 27 22 23 24 25 2
IO name : REL1 REL2 REL3 REL4 REL5 REL6 REL7 REL8

Other process IO see project file /forDocu/Raspi3ioPinsMeterPi.ods .

Notes on process IO functions

REL1 : defect XX (ex PPS-SSR pre-relay)
REL2 : off miniJoule's Ferraris meter on battery unload (out of use 6'23)
REL3 : not used (ex VDE-AR-N 4105)
REL4 : phase packet switch (PPS-SSR) pre-relay for heater contactor
REL5 : would give away more than 250 W (prolonged 2h)
REL6 : not used (ex VDE-AR-N 4105)
REL7 : not used (ex VDE-AR-N 4105)
REL8 : hot water circulation pump (comfort function)
Note: When searching relay usages search for macros onRel(N) and offRel(N)
LED9 : red LED; Modbus slave indicator; on: Modbus slave index > 0
LEDx : green LED; no function at the moment, always on
HWPB : start hot water pump (button to GND)
POWH : Battery load power module voltage control (via open drain)
PWM for adjustable 11..14V 10A power module
lo or off: for lowest voltage
BATu : Battery unload (hi active); battery to step up
when battery surveyor signal is OK
CONb : Step up to miniJoule inverter (32V)
HYPr : Battery to Hippogreiff
PH_P_SSR1: Phase packet switch SSR1 (heater element 1) 0..100%
PH_P_SSR2: Phase packet switch SSR2 (heater element 2) 0, 50, 100%
PWMcarLd : PWM to control max. car load current (per phase)
CONcarLd : Contactor (relay) "power to car" is set ON (low active OC in)
CONcarRq : Car (i.e. CP resistor 2k7) is connected (low active OC in)
#define ON
true On An marche go.
Definition: basicTyCo.h:74
#define onRel(N)
Switch relay N on.
Definition: sweetHome2.h:423
#define PWMcarLd
PWM to control max. car load current (per phase)
Definition: sweetHome2.h:272
#define PH_P_SSR2
Phase packet switch SSR2 (heater element 2)
Definition: sweetHome2.h:269
#define LED9
life LED hi active
Definition: sweetHome2.h:261
#define CONb
Inverter to battery step up (dto.; ws/ge-ws)
Definition: sweetHome2.h:265
#define CONcarLd
Contactor (relay) power to car is ON (low active)
Definition: sweetHome2.h:273
#define PH_P_SSR1
Phase packet switch SSR1 (heater element 1)
Definition: sweetHome2.h:268
#define HYPr
Bat. to /ref Hippogreiff (dto. ws/gn)
Definition: sweetHome2.h:266
#define offRel(N)
Switch relay N off.
Definition: sweetHome2.h:433
#define POWH
Power module voltage control (li/br-ws).
Definition: sweetHome2.h:292
#define LEDx
other LED hi active (currently unused, always on)
Definition: sweetHome2.h:263
#define BATu
Battery unload (hi active via open drain; gr/gr-ws)
Definition: sweetHome2.h:264
#define CONcarRq
Car (CP resistor 2k7) connected / ready (low active)
Definition: sweetHome2.h:274

MQTT usage

The MQTT protocol is used for remote process IO within "sweet home's" private (W)LAN:
a) battery surveillance and voltage measurement by specialised ESP8266
b) For Sonoff S20 plug switches modified to be MQTT clients (Tasmota).

PLG1 "would give 250 W" = parallel to REL5
PLG2 sunset to sunrise (since 03.03.2018; as Hippogreiff)
PLG3 just controlled by web interface (since August 2019 used
for outside air monitor's supply, to enable remote reset)
PLG4 "actually giving away" (neg. supply) warning

Macro Definition Documentation

◆ SENS0PATH

#define SENS0PATH

Temperature of water tank (top level).

This is the address of the 1-wire sensor's value file provided by the 1-wire-temp kernel module.

◆ SENS1PATH

#define SENS1PATH

Temperature of hot water pipe (from tank top).since 12 23: 28-6fb4d443009b.

See also SENS0PATH.

◆ SENS2PATH

#define SENS2PATH

Temperature of water tank (bottom level).

See also SENS0PATH.

◆ PDEL_BALEND

#define PDEL_BALEND

Minimal delivery power to stop ballast.

Value: 210.2 W

◆ PDEL_BALRED

#define PDEL_BALRED

Minimal delivery power to reduce ballast.

Value: 41.02 W

◆ PDEL_BALINC

#define PDEL_BALINC

Maximal delivery power not to add ballast.

Value: 14.02 W

◆ PDEL_SGGIVE

#define PDEL_SGGIVE

Maximal delivery power to signal give away.

Value: 14.3 W

◆ CHS_CP_OFFSET

#define CHS_CP_OFFSET

CP signal PWM correction offset.

The CP signal's duty cycle to E-car (+/-12V) might deviate from the ¶ęC's control signal (TTL); explanation see at DEF_CP_OFFSET.

-27 is the correct value for the (modified) Analog EVSE. Due to asymmetries caused by the optocoupler input the change to Hi state is propagated faster than the one to Lo.

◆ switchPPSrel

#define switchPPSrel (   V)

Actuate phase power switch control relay.

For safety reasons there is a contactor (Hager 4 * 40A) in front of the electronic zero crossing switches (solid state relays SSR) for the two heater elements.

The PPS relay (4) actuates this contactor. The Hager contactor consumes about 9W, see ppsContPow, when actuated.

Parameters
V0: off; else: on

◆ onPort

#define onPort (   N)

Switch port N on.

Parameters
Nport name (LEDx, BATu, CONb ..)

◆ offPort

#define offPort (   N)

Switch port N off.

Parameters
Nport name (LEDx, BATu, CONb ..)

◆ switchRel

#define switchRel (   N,
 
)

Switch relay N on or off.

Parameters
Nrelay number 1..8
V0: off; else: on

◆ onRel

#define onRel (   N)

Switch relay N on.

Parameters
Nrelay number 1..8

◆ offRel

#define offRel (   N)

Switch relay N off.

Parameters
Nrelay number 1..8

◆ BEFORE_RISE

#define BEFORE_RISE

Before sunrise timer offset.

See also: befRiseTimer value: 248 minutes (since 12.08.2021; 188 before)

Function Documentation

◆ pckSwPec()

uint8_t pckSwPec ( float  power)

Set and get package switch percentage by power.

Besides determining an returning the percentage(power), this function sets the process control values via setPckSwPerc() returns its value.

Parameters
powerin W
Returns
the phase packet percentage 0..100

◆ setPhPckLimit()

float setPhPckLimit ( float  powerLimit)

Set and get package switch power limit.

This function sets the PPS power limit in the range 0.0 ... PCK_POWER_LIM_MAX.

Parameters
powerLimitPPS power limit in W
Returns
the (new) power limit

◆ setPckSwPerc()

uint8_t setPckSwPerc ( uint8_t  perc)

Set package switch percentage.

This function sets phPckSwIndex by the parameter value in the range 0..200; respectively PCK_POWER_IND_MAX. Additionally it adjusts the current phPckCnt should its value be higher than by the new setting.

On transitions from respectively to 0 the control relay (PCK_POWER_REL) is actuated before respectively after actuating the electronic switch.

Parameters
perc0..200; values above PCK_POWER_IND_MAX will have no effect and return the current setting un-altered
Returns
the actual (new) phase packet percentage 0..200

◆ switchHotWpump()

void switchHotWpump ( uint8_t const  on)

Hot water comfort pump turn on/off.

It turns the hot water comfort circulation pump on respectively off.

Parameters
on!= 0 : on; else, ==0 : off

◆ switchInvToBatUnl()

void switchInvToBatUnl ( uint8_t  on)

Switch inverter to battery unload.

When the parameter is !=0 respectively ON, this function switches the (small) inverter from panel to the battery unload step up converter and turns the extra Ferraris energy meter off by REL2. Note: Said Ferraris is now unused (but still mounted).

When the parameter is off it does the other way round.

Parameters
ontrue: switch inverter to step up converter (battery unload); 0, false: switch inverter to panel.

◆ switchBatToStepUp()

void switchBatToStepUp ( uint8_t  on)

Switch battery to step up converter.

When the parameter is !=0 respectively ON, this function switches the battery to the step up converter.

When the parameter is off, this function switches the battery to the (max. 20 A) battery loader / keep alive module .

Parameters
ontrue: switch battery to step up converter; 0, false: switch battery to load modul.

◆ setBatLoadPWM()

void setBatLoadPWM ( uint8_t  pwm)

Set battery loader module PWM.

This function sets the battery load module power PWM signal and hence its output voltage. 0 is the lowest and 255 the highest possible setting. While this function allows setting to 0, the highest value is limited to BAT_LDMX_PWM.

Parameters
pwmthe pwm ratio 0: 0%; 255: 100%

◆ reduceBatLoadPWM()

void reduceBatLoadPWM ( uint8_t const  pwmRed)

Reduce battery loader module PWM.

This function reduces the battery load module power PWM signal and hence its output voltage by the parameter value. The reduction is limited to BAT_NOLD_PWM.

See also
setBatLoadPWM()
Parameters
pwmRedthe reduction of the pwm ratio

Variable Documentation

◆ batVoltValid

uint8_t batVoltValid
extern

The measured battery voltage is valid.

When not 0 the last MQTT battery voltage measurement respectively message is not older than 2.4s and hence considered the actual valid value.

◆ batUnloadAllowed

int batUnloadAllowed
extern

Battery unload allowed.

Bit 0 (1): allow after sunset
Bit 1 (2): allow before sunrise
start value: 8 set default value (usually 2 in winter and 3 in summer) Note: Made int en lieu de uint_8 for use in getopt_long.

See also
BAT_UNL_SUMM
BAT_UNL_WINT

◆ hippoSwitchMode

int hippoSwitchMode
extern

Hippogreiff on/off times.

Bit 0,1 ( 3): switch at sunset resp. sunrise (winter)
Bit 2,3 (12): switch at dusk resp. dawn (summer)
start value: 12 (/ref Hippogreiff summer)

◆ phPckSwIndex

volatile uint8_t phPckSwIndex
extern

Actual index (0..200%) determining power.

This is the control variable for the electric heater elements in the hot water tank. Until June 2023 there was one such element of PCK100PERC_POWER W and this variable had a range of 0..100%. Since July 2023 there are two heater elements of equal power. The range of this control variable was extended to 0..200%. The power distribution between the two heater elements is done by software; see setPckSwPerc(uint8_t const perc) and PCK_POWER_IND_MAX

◆ batKeepInh

state_t batKeepInh
extern

Inhibit battery keep alive loading.

While running disallow battery keep alive with BAT_KEEP_PWM. This timer is initially OFF and will be stopped in advance by low battery voltage stress and battery keep command via HMI/GUI.
It will be started after battery unload, after battery ballast load and by battery off command via GUI.

◆ sunriseTimer

state_t sunriseTimer
extern

Sunrise timer.

This timer will run out every day at (approximated) sunrise. For the "every day" behaviour, its state change function will — after all due actions — restart this timer for the next 24h to hit (very approximately) the next sunrise. This acceptable guess will be adjusted at day change or at program start.

◆ sunsetTimer

state_t sunsetTimer
extern

Sunset timer.

This timer will run out every day at (approximated) sunset. See also sunriseTimer

◆ dawnTimer

state_t dawnTimer
extern

Dawn timer.

This timer will run out every day at (approximated) dawn, meaning the beginning of civil twilight. See also sunriseTimer and duskTimer

◆ duskTimer

state_t duskTimer
extern

Dusk timer.

This timer will run out every day at (approximated) dusk, meaning the end of civil twilight. About this time street lamps and position lights may be lit. See also sunriseTimer

◆ befRiseTimer

state_t befRiseTimer
extern

Before sunrise timer.

This timer will run out every day at about 180 min before (approximated) sunrise. The offset must be sufficient time to unload the battery before sunrise.
See also: sunriseTimer BEFORE_RISE

◆ consumeGiveHyst

state_t consumeGiveHyst
extern

Give away hysteresis.

thresholds: PDEL_SGGIVE, PDEL_SGCONS

◆ consumeGiveSFC

state_t consumeGiveSFC
extern

Give away state machine / SFC.

Status ON means consumer: OK.
Status OFF means very low power consumption: Inhibit power delivery.

◆ wouldGiveAwayHyst

state_t wouldGiveAwayHyst
extern

Would give away hysteresis.

thresholds (04.03.18): -/+ 7W

◆ wouldGive250WHyst

state_t wouldGive250WHyst
extern

Would give away 250W hysteresis.

thresholds (04.03.18): -250 / -178W