NEWS
Adapter für Buderus KM200 (und eventuell auch anderen KMxxx)
-
@atifan
Ich habe den km200 Adapter seit 3 Jahren und ems-esp seit 6 Monaten parallel installiert.Für ältere Heizungsanlagen der Boschgruppe (Buderus, Junkers Netfit etc) gibt es separate internetfähige Interfaces wie KM50, KM100, KM200 oder KM300. Neuere Heizungen gaben seit ca. 4 Jahren in der Regel IP-intern bereits installiert.
Diese KMxxx Interfaces kommunizieren verschlüsselt mit der Bosch Cloud und damit sind dann mit App's Grundfunktionen der Anlage steuerbar und ggfs. der Energieverbrauch auswertbar.
Der KM200 Adapter liest die Datenstrukturen des KMxxx Interfaces mit http aus. Das geschieht Datenpunkt für Datenpunkt mit http get requests und ist recht langsam. (Bei mir ca. 150 Datenpunkte - ca. 3 Minuten).
Die Ent- und Verschlüsselung (Rijndael-128 ECB) übernimmt der Adapter. Je nach Firmware und installierte Hardware gibt es unterschiedliche Datenpunkte und bei FW-Updates können sich diese verändern. Schreibbare Datenpunkte können mit dem Adapter geschrieben werden.Das EMS-ESP ist eine Hardware basierend auf ESP8266 (veraltet) bzw. ESP32 (aktuell) welches sich direkt an den EMS-Bus anbindet und dort Daten liest und auch schreiben kann. EMS-ESP unterstützt mehr als 70 verschiedene Systeme und ist dafür gedacht ältere Heizungen über MQTT (Homeassistent) oder über REST API steuerbar zu machen. Die aktuelle API V3 läuft nur auf ESP32 und inzwischen auch stabil parallel zum km200 / IP-intern. Der Betrieb ist nicht ganz unkritisch da direkt im EMS-Bus geschrieben wird. GGfs. kann mit falschen Parametern die Heizungsanlage ausfallen. EMS-ESP ist ein privates "Bastelprojekt" welches im Wesentlichen von 2 Leuten vorangetrieben wird. EMS-ESP Gateways können von BBQKees bezogen werden: https://bbqkees-electronics.nl
Vor wenigen Tagen ist die REST-API V3 soweit fertiggestellt, dass ein von mir geschriebener ioBroker ems-esp Adapter bereits funktioniert. Dieser kann sowohl KM200 Daten als auch EMS-ESP Daten verarbeiten. Der Adapter ist noch nicht im ioBroker Repository und kann testweise installiert werden. Ist aber noch Work in Progress. Voraussetzung ist EMS-ESP mit ESP32 und der aktuellen Development Firmware: https://github.com/tp1de/ioBroker.ems-esp
EMS-ESP liefert die Daten im 15 Sekundentakt und beinhaltet einige Parameter die KM200 nicht hat. Dies sind die Steuerung der Zirkulationspumpe und Regelungsparameter. Es fehlen aber noch einige Inhalte aus dem KM200 Adapter wie z.B. Urlaube, Zeitprogramme etc. Einige EMS-ESP Daten sind für meine Heizungsanlage (KB192i, MM100, RC310) noch fehlerhaft. Die Datenstrukturen im EMS-ESP sind auf die Hardware bezogen (Boiler, Thermostat, Mixer etc) und unterscheiden sich vom KM200. Im EMS-ESP Adapter habe ich versucht diese zu harmonisieren.
-
@tom57 Hi, schonmal vielen Dank für den guten Überblick.
Ich habe eine Ölbrennwertheizung KB195i und überlege mir ob ich mir so ein EMS-ESP mit ESP32 hole.
Ich steuere die Heizung eigentlich nicht wirklich über Iobroker, aber möglicherweise könnte man mit dem Adapter eine Logik programmieren, die das Takten in der Übergangszeit etwas vermindert.
.
.
.
Zu dem Problem anbei eine Beschreibung die ich bereits im Buderus Heizungsforum geschildert habe.Hallo, ich habe seit 2018 einen Buderus KB195i Ölbrennwertkessel.
Im Schnitt habe ich auf das Jahr gesehen pro Tag etwa 3 Brennerstarts, was schon denke ich ganz gut ist.
Im Winter läuft die Anlage fast komplett durch und ich habe ca. 1-2 Starts pro Tag.
In der Übergangszeit habe ich aber teilweise sehr viele Starts, ca. 15-20 pro Tag.
Das sieht man schön an dem Screenshot.
Im oberen Diagramm die gelbe Linie ist die Vorlauftemperatur. Immer wenn der Brenner anspringt und diese nach oben geht, sehe ich dass ein Brennerstart stattgefunden hat.
Außerdem sieht man im unteren Diagramm dazu auch die roten Ausschläge, das sind die Vorheizphasen für das Öl aufzuwärmen, immer ca. 1,8kW für paar Minuten.
Das Problem in der Übergangszeit ist dass die Wärme nicht abgenommen wird und dann der Brenner natürlich wieder abschaltet.
Ich habe schon die Taktsperre auf die maximal möglichen 60min eingestellt.
Hat jemand noch Ideen wie man diese unnötigen Starts noch vermindern könnte?
Ich habe Smarthome-System mit IoBroker am Laufen und könnte auch z.B. über eigene Software und Logik evtl. den Start unterbinden.
Aber da fehlt mir halt eine Schnittstelle zu der Heizung.
Gibt es die Möglichkeit eine Hardware nachzurüsten, so dass man z.B. einen Kontakt hätte über den man steuern kann ob die Heizung starten soll oder nicht?
Z.B. wenn Kontakt geschlossen dann darf er heizen, wenn Kontakt offen dann nicht anspringen, auch wenn es eine Wärmeanforderung gibt
Bin für alle Tipps für weitere Optimierungen dankbar. -
@atifan sagte in Adapter für Buderus KM200 (und eventuell auch anderen KMxxx):
KB195i
Um zum Thema Takten etwas zu sagen, bräuchte ich mehr Info's:
Nur FB Heizung oder auch Heizkörper? Ist ein Mischer (MM100) installiert?
Wie werden die Räume der FB Heizung / Heizkörper geregelt? Kann ioBroker diese Regler lesen / verändern?Nach meiner Erfahrung beim Gasbrenner ist die Einstellung einer langen Taktzeit nicht optimal.
Mein Brenner hat eine Modulation von 1:6, wenn aber die Kessel-Temperatur zu stark abgefallen ist, dann wird zu lange mit hoher Leistung geheizt und zu spät runtergeregelt - dann sehr häufig getaktet. Ich reduziere dann die maximale Heizleistung auf 50% - geht aber nur über EMS-ESP. Hat der Ölbrenner überhaupt die Möglichkeit der Modulation?Ich selber lese die Temperatur der Referenzräume und leite daraus die benötigte Heizleistung ab.
Mit dem State km200.0.heatingCircuits.hc1.supplyTemperatureSetpoint kann man dann den Heizkreis ausschalten bzw. beeinflussen: -1: Auto Modus, 0: Aus , 5-30 die Solltemperatur des Raumes für den Heizkreis.Ich selber schalte solange aus, bis genug Heizbedarf ansteht (Ist-Temperatur < Solltemperatur - Differenz. Differenz bei mir > 1.0 Grad. Ich habe Homematic Thermostate in den wesentlichen Räumen und leite daraus den Heizbedarf ab.
-
@tom57
Hi,- nur Fußbodenheizung, keine Heizkörper
- MM100 Mischer ist vorhanden
- 3K Anhebung der Vorlauftemperatur ist eingestellt
- einige wenige Heizkreise sind über Stellmotoren geregelt bzw. werden über ein Wandthermostat geöffnet/geschlossen -> ist so atm nicht über IoBroker steuerbar, wäre aber ggf. machbar -> bringt aber nix denke ich, da das Takten auch passiert wenn alle Heizkreise komplett offen sind
- der Brenner moduliert von 30% bis 100% (4,5kW bis 15kW)
- Reduktion der maximalen Heizleistung von aktuell 100% auf weniger bringt da denke ich auch nix, weil das Takten passiert schon bei 30% Heizleistung
Meine Überlegung war auch wie du schreibst die Heizung iwie solange auf aus zu stellen wie es sinn macht bzw. bis die benötigte Heizlast da ist und er dann nicht mehr taktet. Habe überall im Haus Xiaomi Temperatursensoren und könnte darüber was regeln, ggf. auch über nen ESP mit Tempsesor in einem Raum als Referenzraum.
-
@atifan sagte in Adapter für Buderus KM200 (und eventuell auch anderen KMxxx):
nur Fußbodenheizung, keine Heizkörper
MM100 Mischer ist vorhanden
3K Anhebung der Vorlauftemperatur ist eingestelltVerstehe nicht ganz warum mit 3K Temperaturanhebung ein Mischer Sinn macht bei nur FB Heizung.
Was macht denn die Taktung bei 10K Anhebung?bringt aber nix denke ich, da das Takten auch passiert wenn alle Heizkreise komplett offen sind
Das kann eigentlich nur dann der Fall sein, wenn Vorlauf- und Rücklauftemperatur sich kaum unterscheiden, d.h. wenn keine Wärme mehr abgegeben wird. Häufiger machen die Stellmotoren bei Erreichen der Solltemperatur zu.
Fazit: Wenn keine Wärmebedarf, dann kann die Heizung aus sein. Meine FB Heizung steht auf Sommerbetrieb ab 18°C und der Raumeinfluss ist mit 6°C sehr hoch eingestellt. Bei erreichen der Solltemperatur im Referenzraum (WZ) - dort wo der RC310 steht - geht der Heizkreis auch automatisch aus.
Ansonsten per Script den State State km200.0.heatingCircuits.hc1.temporaryRoomSetpoint auf 0 setzen.
(War oben der falsche State - sorry). Gilt übrigens bis zum nächsten Schaltzeitpunkt im Automatikmodus. -
@tom57
3K Anhebung war immer so eingestellt, hatte auch schon mit 0K Anhebung getestet. Aber ist 10K nicht unnötig hoch? Dann heizt der Kessel ja immer 10K höher als die Sollvorlauftemperatur, ist das nicht ineffizienter bzw. würde dann eher Takten noch verstärken? 10K hatte ich noch nie eingestellt.
Ich hab Sommerbetrieb ab 15°C, d.h. meine Heizung geht ja schon früher in den Sommerbetrieb als deine. Kommt natürlich auch auf Dämmung bzw. Wärmeverlust an. Raumeinfluss habe ich bei mir nix eingestellt, ich hab auch keinen RC310 im Wohnzimmer sondern nur am Kessel direkt. Meinst es würde Sinn machen noch einen RC310 im Wohnzimmer zu installieren damit ich Raumtemp als Referenz habe?
Im Prinzip könnte das aber doch IoBroker übernehmen in Verbindung mit meinen Temperatursensor im Wohnzimmer?
Über Blockly könnte ich dann km200.0.heatingCircuits.hc1.temporaryRoomSetpoint auf 0 setzen, solange eine bestimmte Raumtemperatur erreicht ist.
Bzw. ich könnte damit die Taktsperre auch z.B. auf 3h erhöhen, was auch einiges ausmachen sollte.Was bedeutet gilt bis zum nächsten Schaltzeitpunkt im Automatikmodus?
Ich hab bei mir im Zeitprogramm eingestellt -> ab 5 Uhr morgens 21°C Heizen, keine Absenkung
Würde dann jeden Morgen um 5 Uhr der Datenpunkt von 0 auf -1 gestellt werden? -
Geil, habs mal ausprobiert und auf 0 gesetzt, die Heizung geht aus bis morgen 5:00 Uhr.
Wenn jetzt jemand duschen würde und Warmwasser benötigt wird, geht das aber dann oder?Was muss ich einstellen wenn ich sie wieder einschalten will? Den Datenpunkt auf 21 stellen?
Ich denke damit lässt sich schon mal irgend eine Logik über Blocky bauen, mit der man das Takten noch weiter vermindern kann
Danke! -
@atifan sagte in Adapter für Buderus KM200 (und eventuell auch anderen KMxxx):
Wenn jetzt jemand duschen würde und Warmwasser benötigt wird, geht das aber dann oder?
Warmwasser ist unabhängig von den Heizkreisen.
ich hab auch keinen RC310 im Wohnzimmer sondern nur am Kessel direkt. Meinst es würde Sinn machen noch einen RC310 im Wohnzimmer zu installieren damit ich Raumtemp als Referenz habe?
So hast Du eine reine Außentemperatur-gesteuerte Heizung. Wenn Du den RC310 im WZ installierst (einer reicht), dann kannst Du die Heizung auch dort bedienen. Brauchst dann ein zweiadriges Kabel für den EMS-Bus.
Oder steuerst eben über den ioBroker.Was bedeutet gilt bis zum nächsten Schaltzeitpunkt im Automatikmodus?
Das Schaltprogramm hat normalerweise als Schaltzeiten:
Heizbeginn (5 Uhr) Heizende (z.b.22 Uhr) und dann ggfs. Nachtabsenkung.
Im RC310 kannst Du z.B. den Eco Modu einstellen, dass die Heizung Nachts:- aus ist (Aussentemp > Temp1)
- mit Absenkung arbeitet (Aussentemp < Temp1)
- Durchläuft ohne Absenkung (Aussentemp < Temp2)
Im Schaltprogramm kannst Du mehrere Schaltzeiten definieren mit unterschiedlichen Temperaturvorgaben (oder den gleichen) - macht aber nur Sinn wenn Innentemperaturfühler vorhanden (z.B. RC310 im WZ).
Den temporaryRoomSetpoint auf 0 bedeutet gilt bis zum nächsten Schaltzeitpunkt. Setzen auf -1 geht wieder in den Automatik Modus bzw. dieser wird beim Erreichen des Schaltzeitpunktes automatisch auf -1 gesetzt.
(Falls ioBroker mal nicht läuft, dann regelt die Heizung unabhängig!) -
@tom57
Hi, ja das ist super. Ich denke damit bekomm ich was optimiert.
Ich brauch kein RC310 im Wohnzimmer oder sonst einem Raum, weil ich hab ja überall die Xiaomi Temperatursensoren.
Die liefern jede Stunde einen Wert, das ist mir genau genug.
Ich möchte ja nix über RC310 manuell steuern, das soll schön alles automatisch passieren
Hab schon die erste Blockly-Logik am Laufen und bin gespannt was das ausmacht und obs funktioniert wie ich das hoffe
Muss natürlich dann noch ne Weile testen welche Werte am besten sind, welcher Temperatursensor als Referenz am besten ist, ob ich evtl. sogar mehrere Sensoren einbinde, wie sich das bei verschiedenen Jahreszeiten auswirkt usw Aber denke das wird was.
Im Prinzip ist der Datenpunkt genau das was ich gesucht habe, ein "EIN/AUS-Schalter" für die Heizung der smart und automatisiert ansteuerbar ist
Danke für den Tipp -
@tom57 : Hm, habe den Datenpunkt km200.0.heatingCircuits.hc1.temporaryRoomSetpoint per Script auf 0 gesetzt. Nach einiger Zeit hat er sich aber selbst auf 5 gesetzt, hast du eine Idee woran das liegen kann? Wobei 5°C ja im Prinzip ebenfalls AUS bedeutet. Aber irgendwas verstellt halt den Wert.
-
@atifan sagte in Adapter für Buderus KM200 (und eventuell auch anderen KMxxx):
Hm, habe den Datenpunkt km200.0.heatingCircuits.hc1.temporaryRoomSetpoint per Script auf 0 gesetzt. Nach einiger Zeit hat er sich aber selbst auf 5 gesetzt, hast du eine Idee woran das liegen kann? Wobei 5°C ja im Prinzip ebenfalls AUS bedeutet. Aber irgendwas verstellt halt den Wert.
Erste Frage: Welche Version des js-controllers benutzt Du? (Unter Hosts schauen..)
Zweite Frage: Hast Du Einträge im Log?Bei Dir ist der Wert km200.0.heatingCircuits.hc1.temperatureLevels.eco auf den Wert 0 gesetzt.
Das ist normalerweise die Nachtabsenkung wenn die Heizperiode des activeSwitchProgram = A endet. Welche Zeiten stehen bei Dir im Schaltprogramm A ?Den ECO-Wert auf 0 zu stellen halte ich für falsch. Bei einer FB-Hzg sollte der Wert ca. 2 Grad niedriger als der Wert Comfort2 sein. Der Rest dann mit den Schaltwerten wie vorher beschrieben. Lies Dir mal das Manual zum RC310 durch.
Mit dem js-controller 3.3.xx hat sich einiges geändert. Viele meiner Programme und mein Adapter liefen nicht mehr richtig. Grund sind erweiterte Prüfungen zur Werteübergabe. Auch beim km200 Adapter kommen dann viele Warnungen, aber Werte von -1 und 0 sind noch eingebbar.
Der State km200.0.heatingCircuits.hc1.temporaryRoomSetpoint wird mit Min Value von 5 angelegt, obwohl Werte von -1 oder 0 im KM200 REST API definiert sind. Bisher lief das problemlos durch aber mit dem neuesten js-controller nicht mehr. (Warnmeldungen)
Der km200 Adapter ist leider so programmiert, dass die State Definitionen jeweils beim Adapterstart überschrieben werden. Das sollte so nicht sein. Manuell kann man daher den minimalen Wert nur temporär ändern.
Der Wert von 5 kommt wohl bei Übergabe der 0 aus dem ECO-Wert vermute ich. -
@tom57
Ich habe alles auf dem aktuellsten Stand (Beta) -> Node.js 12.22.1, js-controller 3.3.10.
Im Log hab ich nix drin, aber ich hatte eine orangene Fehler-Meldung im Script, das war mir zufällig aufgefallen.
Der Wert 0 wurde aber definitiv übergeben. Hatte das ja überprüft. Es stand der Wert 0 im Datenpunkt. Nur später irgendwann stand dann da 5.
Ich hatte im Script aber einen String "0" übergeben, dachte es liegt daran. Habe es jetzt geändert auf numerische Zahl, also 0.
Aber wenn du meinst das liegt am Controller?
Es steht jetzt zwar 5 drin, aber eigentlich ist das ja gleich wie 0 = aus oder? Die Temperatur 5°C ist ja so niedrig dass die nie erreicht wird im Heizbetrieb.Ich hab immer Zeitprogramm1 aktiv. Da steht nur drin Mo-So ab 5:00 Uhr Heizen, ansonsten hab ich nix eingestellt. Die Temperatur ist auf 21,5°C eingestellt. Sommer/Winterumschaltung bei 15°C Außentemperatur.
Solange es draußen wärmer als 15°C ist ist der Heizbetrieb also aus, nur Warmwasser. Wird es draußen kälter als 15°C ist das Zeitprogramm1 aktiv. Es wird dann durchgehend geheizt bis die gewünschte eingestellte Raumtemperatur von 21,5°C erreicht ist.Nachtabsenkung und Eco habe ich nie genutzt bisher, halte ich eigentlich auch nicht für notwendig. Schaue es mir aber nochmal an.
-
@atifan
Hm es hat iwie nicht richtig funktioniert. Normalerweise hätte um 2:00 Uhr ca. die Heizung anspringen sollen, da ab dann die Temperatur im Referenzraum unter 21,5°C war und dann das Script die -1 in den Datenpunkt schreibt.
Die Heizung ging aber erst heute Morgen um 5 Uhr an. Oder sollte das so richtig sein, weil um 5 Uhr ja bei mir der Automatik-Schaltpunkt "Heizen" ist?
Ich werde jetzt mal statt der -1 versuchen mit 21.5 zu übergeben. Dann sollte er vermutlich direkt anfangen zu heizen und nicht erst beim nächsten Schaltpunkt im Programm.Das komische ist dann aber, eine Stunde später um ca. 6 Uhr wurde wieder abgeschaltet. Im Datenpunkt km200.0.heatingCircuits.hc1.temporaryRoomSetpoint stand wieder 5°C drin. Normal sollte ja dort dann -1 oder 21,5 drin stehen. Ich logge mal den Datenpunkt, evtl. lässt sich dann rausfinden wann/wieso/weshalb er auf 5 gesetzt wird.
Ich glaube aber nicht dass die 5 darin wegen dem Wert 0 im Datenpunkt km200.0.heatingCircuits.hc1.temperatureLevels.eco verursacht wird. Habe den aber mal auf 21°C eingestellt, statt "Heizung aus".
-
Hallo KM200 Gemeinde,
ich habe 2 Instanzen in meinen Ferienwohnungen. Bei beiden stehtder Wert des Datenpunts km200.0.heatingCircuits.hc1.currentSuWiMode immer auf "forced". Der Sommermodus ist bei beiden nicht aktiv, scheint mir also ein Bug zu sein. Wer hat das gleiche Phänomen? -
@manrum1 sagte in Adapter für Buderus KM200 (und eventuell auch anderen KMxxx):
m200.0.heatingCircuits.hc1.currentSuWiMode immer auf "forced". Der Sommermodus ist bei beiden nicht aktiv, scheint mir also ein Bug zu sein. Wer hat das gleiche Phänomen?
Hi, bei mir ist das gleiche, auch forced. Ich vermute aber das liegt daran, weil ich durch mein Script ja km200.0.heatingCircuits.hc1.temporaryRoomSetpoint manuell setze. In dem Moment läuft die Anlage bis zum nächsten Programmschaltpunkt ja im Prinzip im manuellen Modus und nicht im Automatikmodus.
-
@atifan
Hi, danke für deine Antwort. Kann eigentlich nicht sein, ich fahre eigentlich nur im Auto-Betrieb. -
@frankjoke
Hi, was meinst Du - kann man den Bug beheben?Danke im Voraus!
-
@manrum1 sagte in Adapter für Buderus KM200 (und eventuell auch anderen KMxxx):
@frankjoke
Hi, was meinst Du - kann man den Bug beheben?
Danke im Voraus!@Atifan @manrum1 Ich verstehe Eure Diskussion nicht.
Das setzten des Datenpunktes km200.0.heatingCircuits.hc1.currentSuWiMode hat nichts mit dem km200 Adapter zu tun und ist auch kein Bug. Der Inhalt wird vom km200 Interface bestimmt. Ich habe meinen eigenen Adapter geschrieben und dort ist der Inhalt bei "Auto Mode" immer forced. Nur wenn der Sommermodus manuell eingeschaltet wird, dann steht der Punkt auf off.Ist aber doch uninteressant. Warum führt Ihr diese Diskussion?
Entweder Ihr schaltet bewusst manuell die Heizung auf Sommerbetrieb oder Ihr lasst diese auf Automatikbetrieb und setzt den heatingCircuits.hc1.suWiThreshold auf den Wert, wann die Heizung auf Sommerbetrieb geht. Der heatingCircuits.hc1.supplyTemperatureSetpoint wird dann entsprechend gesetzt. -
@tom5 Danke für Deine Antwort.
Ich vermiete meine Fereinwohnungen und bin aber selbst ca. 900km weit entfernt. Deshalb interessiert mich jeder Status der Heizung und im speziellen Fall geht es einfach darum zu wissen, wann die Heizung im Sommermodus geschaltet ist. Dies wird ja an der Steuerung auch angezeigt. -
Hallo zusammen, vielleicht kann mir mal jemand bei der Fehleranalyse helfen, danke schon mal im Voraus!
Anbei das Log: