rasProject_01 / weSweetHome
R. 240
process control / RasPi software by weinert-automation
|
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... | |
Types, values and functions for a smart home project.
Revision history
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
Other process IO see project file /forDocu/Raspi3ioPinsMeterPi.ods .
Notes on process IO functions
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).
#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.
#define SENS1PATH |
Temperature of hot water pipe (from tank top).since 12 23: 28-6fb4d443009b.
See also SENS0PATH.
#define SENS2PATH |
Temperature of water tank (bottom level).
See also SENS0PATH.
#define PDEL_BALEND |
Minimal delivery power to stop ballast.
Value: 210.2 W
#define PDEL_BALRED |
Minimal delivery power to reduce ballast.
Value: 41.02 W
#define PDEL_BALINC |
Maximal delivery power not to add ballast.
Value: 14.02 W
#define PDEL_SGGIVE |
Maximal delivery power to signal give away.
Value: 14.3 W
#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.
#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.
V | 0: off; else: on |
#define onPort | ( | N | ) |
Switch port N on.
N | port name (LEDx, BATu, CONb ..) |
#define offPort | ( | N | ) |
Switch port N off.
N | port name (LEDx, BATu, CONb ..) |
#define switchRel | ( | N, | |
V | |||
) |
Switch relay N on or off.
N | relay number 1..8 |
V | 0: off; else: on |
#define onRel | ( | N | ) |
Switch relay N on.
N | relay number 1..8 |
#define offRel | ( | N | ) |
Switch relay N off.
N | relay number 1..8 |
#define BEFORE_RISE |
Before sunrise timer offset.
See also: befRiseTimer value: 248 minutes (since 12.08.2021; 188 before)
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.
power | in W |
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.
powerLimit | PPS power limit in W |
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.
perc | 0..200; values above PCK_POWER_IND_MAX will have no effect and return the current setting un-altered |
void switchHotWpump | ( | uint8_t const | on | ) |
Hot water comfort pump turn on/off.
It turns the hot water comfort circulation pump on respectively off.
on | != 0 : on; else, ==0 : off |
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.
on | true: switch inverter to step up converter (battery unload); 0, false: switch inverter to panel. |
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 .
on | true: switch battery to step up converter; 0, false: switch battery to load modul. |
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.
pwm | the pwm ratio 0: 0%; 255: 100% |
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.
pwmRed | the reduction of the pwm ratio |
|
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.
|
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.
|
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)
|
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
|
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.
|
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.
|
extern |
Sunset timer.
This timer will run out every day at (approximated) sunset. See also sunriseTimer
|
extern |
Dawn timer.
This timer will run out every day at (approximated) dawn, meaning the beginning of civil twilight. See also sunriseTimer and 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
|
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
|
extern |
Give away hysteresis.
thresholds: PDEL_SGGIVE, PDEL_SGCONS
|
extern |
Give away state machine / SFC.
Status ON means consumer: OK.
Status OFF means very low power consumption: Inhibit power delivery.
|
extern |
Would give away hysteresis.
thresholds (04.03.18): -/+ 7W
|
extern |
Would give away 250W hysteresis.
thresholds (04.03.18): -250 / -178W