Hallo Miteinander,
ich stelle hier mal meine Homematic Steuerung vor, vielleicht interessiert es ja den ein oder anderen.
Angefangen habe ich mit Homematic, da ich eine gebrauchte Gasbrennwertheizung bei mir eingebaut habe. Ein ganz einfaches Modell mit Brenner und Warmwasserspeicher. Die Gasheizung hatte nur ein einziges Thermostat für einen Führungsraum. Das ist dafür vorgesehen um einen Raum (meist das Wohnzimmer) der Heizung mitzuteilen ob sie nun heizen soll oder nicht.
Da ich zu Hause arbeite, trifft das mit dem Führungsraum aber auf mich nicht zu. Tagsüber bin ich im Büro und Abends im Wohnzimmer - kein einzelner Führungsraum. Ich habe mir daraufhin das original Thermostat der Heizung genauer angesehen. Das ist einfach nur ein potentialfreies Relais. Von da an war klar, dass ich die Heizung mit einer Hausautomationsanlage steuern könnte.
Ich habe mir dann eine CCU2, ein paar Thermostate und einen potentialfreien Schalter (HM-LC-Sw4-SM) gekauft um damit die Heizung zu steuern.
Am Anfang waren die Solltemperaturen der Thermostate noch einfach zeitbasiert. Ich habe alleridngs auch eine Fritzbox und ein Smartphone, so dass ich darauf kam das auf anwesenheitsbasiertes Heizen umzustellen. D.h. es wird versucht über die spärlichen Informationen zu schliessen ob und wer in welchen Räumen ist.
Wenn mein Handy im WLAN eingebucht ist, bin ich wohl im Haus. Wird in einem Raum ein elektrischer Schalter (Licht, Zwischenstecker,...) ein geschaltet, ist wohl jemand im dem Raum. Ist eine Person zu Hause und zeitlich meist in einem Raum (z.B. Morgens in der Küche), dann wird die Heizung entsprechend gesteuert. Sind Gäste im Haus wird das Gästezimmer wärmer gemacht und auch sonst die Temperaturen auf gästefreundliche Niveaus angehoben.
Die Scripte laufen auf einer unveränderten CCU2 - sowie die Anwesenheitserkennung des WLANs auf einer Fritzbox. Alle meine Scripte finden sich unter https://github.com/jollyjinx/homematic .
Anwesenheitserkennung mit WLAN (presencedetection.sh)
Auf meiner Fritzbox läuft ein Script presencedetection.sh, mit dem ich die Anwesenheit von Geräten in meinem WLAN feststelle. Moderne SmartPhones versuchen ständig eine Internetverbindung aufrecht zu erhalten (z.B. für Push-Nachrichten) und sind damit dem Router immer bekannt. Das Script schaut also nur die ARP Tabelle an und pingt die Geräte nicht an, dadurch ändert sich an der Batterielaufzeit der Geräte nichts !
Bestimmte Geräte sind bestimmten Leuten zugeordnet und somit werden Variblen auf der CCU2 durch das Script gesetzt. Also z.B. presence.wlan.patrick, oder presence.wlan.guests.
Anwesenheitsaggregation (presenceVariableAggregation.hms)
Da nicht alle Leute mit einem Gerät im WLAN einbuchen, gibt es noch manuell setzbare Variablen in der CCU2 z.B. presence.manual.guests. Diese werden mit dem script presenceVariableAggregation.hms mit den anderen Anwesenheitserkennungen zusammengefasst in die Variablen: presence.any, presence.guests, presence.patrick, usw. Es gibt noch die Möglichkeit bestimmte personen als Kinder zu definieren, die nur im Haus sind, wenn Erwachsene im Haus sind. Meine Tochter hat kein Handy und wird über eine Zeittabelle , bzw. einen virtuellen Taster als an/abwesend markiert. Durch die Aggregation ist sie nun nur anwesend, wenn auch ein Erwachsener anwesend ist.
Als Beispiel sind folgende Anwesenheitsvariablen gesetzt:
presence.wlan.guests: abwesend
presence.wlan.patrick: ANWESEND
presence.wlan.isabel: abwesend
presence.manual.guests: abwesend
presence.manual.patrick: abwesend
presence.manual.isabel: ANWESEND
presence.calender.guests: abwesend
presence.calender.patrick: abwesend
presence.calender.isabel: abwesend
.
.
.
daraus setzt das presenceVariableAggregation.hms script dann:
presence.any: ANWESEND
presence.guests: abwesend
presence.patrick: ANWESEND
presence.isabel: ANWESEND
.
.
.
Diese zusammengefassten Anwesenheitsvariabelen werte ich dann in weiteren Scripten aus.
Anwesenheits Thermostatsteuerung (PresenceTriggersTemperature.hms)
Die ganze Anwesenheitserkennung mache ich nur, damit ich die Solltemperaturen der Thermostate einstellen kann. So hängt die Solltemperatur der Räume von den Leuten ab die im Haus sind und deren Vorlieben, das habe ich einer Tabelle aus dem Script eingefügt:
presence.guests: hall 0:00,17C 6:00,18.5C 7:30,19.5C 19:30,20C
living 0:00,17C 7:30,19C 19:30,20C
kitchen 0:00,17C 6:00,18.5C 7:30,20C 20:30,17C
guests 0:00,17C 8:00:16C 21:00,17.5C
presence.patrick: hall 0:00,16C 7:30:18C 20:30,19C
living 0:00,16C 7:30:17C 20:30,18C
kitchen 0:00,16C 7:30,18C 20:30,17C
office 0:00,16C 7:30,19.5C 19:30,16.5C
sleeping 0:00,15C 8:00,10C 22:00,16C
Das Script PresenceTriggersTemperature.hms wertet diese Tabelle aus, überprüft die Anwesenheit der Personen im Haus und deren Temperaturwerte für die jeweiligen Räume. Es wertet aus ob ein Fenster oder eine Tür im Raum geöffnet ist oder ob Heizungsrelevante Schalter im Raum aktiv sind. So geht das Script davon aus, dass wenn Licht im Raum brennt, wohl auch jemand anwesend ist.
Falls in einem Raum keine Fenster/Tür sensoren sind, wird eine Fenster-offen Erkennung des Thermostats berücksichtigt. D.h. wenn das Thermostat ein offenes Fenster durch einen Temperatursturz erkennt überschreibt das Script die Fenster-offen-temperatur nicht. Allerdings muss dafür die Fenster-offen-temperatur des Thermostats mit der im Fenster-offen-temperatur variable im Script (openwindowtemp) übereinstimmen.
Das Script setzt dann die Solltemperatur falls die aktuelle Solltemperatur nicht der berechneten übereinstimmt und das Thermostat im Automatikmodus läuft. Man kann also durch Umstellen auf manuellen Thermostatmodus auch die Temperatur manuell verändern.
Ergänzt habe ich die Möglichkeit der Termostate automatisch in den AUTO vom MANU Modus nach einer festgelegten Zeit zurückzuspringen. Man kann also mal für ein paar Stunden die Temperatur manuell verändern und danach läuft alles wie gewohnt. Die Temperaturtabelle habe ich um die Möglichkeit ergänzt Komfort Temperaturen für Räume und Zeiten mit anzugeben, ganz so wie bei Benutzern. Damit kann man also durch Licht einschalten je nach Raum und Zeit eine andere Komforttemperatur einstellen.
Es gibt nun auch die Möglichkeit die Thermostate bis zur nächsten Umstellung - sei es durch die Zeittabelle der verschiedenen Personen oder Fensteröffnen oder Schalter betätigen - nicht zu verstellen. Allerdings muss man dann alle AUTO Schaltzeiten der Thermostate selbst auch in die Tabelle aufnehmen, weswegen ich diesen Teil optional gemacht habe.
Heizungssteuerung Hauptschalter (TurnHeatingOn.hms)
Angefangen habe ich mit Homematic, da ich eine gebrauchte Gasbrennwertheizung bei mir eingebaut habe. Ein ganz einfaches Modell mit Brenner und Boiler. Die Gasheizung hat natürlich keinen HomeMatic Anschluss ;-( und noch schlimmer die Gasheizung hat nur ein einziges Führungstermostat. Das ist dafür vorgesehen um einen Raum (meist das Wohnzimmer) der Heizung mitzuteilen ob sie nun heizen soll oder nicht.
Da ich zu Hause arbeite, trifft das mit dem Führungsraum aber auf mich nicht zu. Tagsüber bin ich im Büro und Abends im Wohnzimmer - kein einzelner Führungsraum. Deshalb habe ich mir das original Thermostat der Heizung genauer angesehen. Das ist einfach nur ein potentialfreies Relais. Da wusste ich schon mal, dass ich mit einem HM-LC-Sw4-SM das Thermostat des Führungraums ersetzen kann.
An die Heizköper habe ich die normalen HM-CC-RT-DN Thermostate angeschraubt. Mit einem einfachen Script TurnHeatingOn.hms schalte ich nun seit letzten März die Heizung entsprechend ein oder aus. Die Heizung erkennt selbtständig an Vor- und Rücklauf und wieviel der Brenner brennen muss, da habe ich nichts geändert. Ich übernehme mit dem Script nur die Simulation des Führungsthermostaten. Das Script wertet die Soll/Ist Temperaturen sowie die Ventilstellung der HM-CC-RT-DN Thermostate aus um die Heizung ein oder auszustellen.
Heizungssteuerung Warmwasserspeicher (TurnBoilerOnAfterVacation.hms)
Ich habe mir dann auch noch den Warmwasserspeicher der Heizung angesehen. Die Heizung erkennt die Warmwassertemperatur über einen Heissleiter. Ich habe dann mal ausprobiert ob ein einfaches überbrücken des Widerstandes ausreicht der Heizung klar zu machen dass der Boiler heiss ist, aber da meldet die Heizung (korrekterweise) dass der Widerstand defekt sei.
Zufälligerweise lagen der Heizung noch ein paar Widerstände bei, mit denen ich (parallel zum Heisswiderstand geschaltet) der Heizung eine rund 20 Grad höhere Temperatur vorgaukeln kann. Ich habe dann das zweite potentialfreie Relais vom HM-LC-Sw4-SM daran angeschlossen und kann damit den Boiler nun an und ausstellen.
Da ich, um den Warmwasserspeicher auszustellen der Heizung eine 20 Grad höhere Temperatur im Warmwasserspeicher vorgaukle, ist klar, dass ich den Frostschutz der Heizung damit ausheble und die Heizung evtl. Frost nicht erkennen könnte. Da es bei mir im Reihenhauskeller nicht fröstelt, habe ich damit kein Problem.
Wenn jemand zu Hause ist, wird der Warmwasserspeicher einmal am Tag um 6:15 Uhr angeschaltet. Wenn ich also übers Wochenende nicht da bin, wird der Warmwasserspeicher auch nicht erhitzt.
Der Warmwasserspeicher wird über ein weiteres Script immer nach einer halben Stunde ausgeschaltet. So kann man den Warmwasserspeicher auch mal zwischendurch manuell anschalten und er schaltet automatisch nach einer halben Stunde aus. Für Gaeste gibt es noch einen Schalter (HM-Sec-SCo:Funk- Tuer-/Fensterkontakt) an der Dusche, der den Boiler automatisch anschaltet sobald Gäste im Haus sind und geduscht wird (damit ist für den nächsten Duschenden auch warmes Wasser bereit). Und zu guter letzt, da ich gerne, wenn ich nach einem Urlaub nach Hause komme, Dusche, habe ich noch ein kleines Script laufen, welches den Boiler einschaltet wenn ich nach einem Urlaub nach Hause komme. TurnBoilerOnAfterVacation.hms
Hoffe es gibt Euch Anregungen. Falls Ihr Sachen verbessert, könnt Ihr einfach einen Pull Request auf GitHub machen.