NEWS
Viessmann-Adapter mit vcontrol
-
Habe hier mal die Liste der Adressen die bei mir zumindest "0.0" und keinen Fehler ausgeben.
Einige sind doppelt (gleiche Werte auf verschiedenen Adressen). Manche bringen nur "0.0"
Die description ist teils nur von Viessmann übernommen und die unit ist alles UT (1/10 °C) noch nicht überarbeitet.
Wie erwähnt ist das nur eine Liste Grob ausgesiebter Datenpunke meiner A200.Vielleicht hilft es dennoch dem einen oder Anderen schon weiter

<command name="getVED" protocmd="getaddr"> <addr>1618</addr> <len>3</len> <unit>UT</unit> <description>Verdampfungsdruck Verdichter</description> </command> <command name="getKD1" protocmd="getaddr"> <addr>06B2</addr> <len>3</len> <unit>UT</unit> <description>Kondensatordruck</description> </command> <command name="getSD1" protocmd="getaddr"> <addr>06B0</addr> <len>3</len> <unit>UT</unit> <description>Saugdruck</description> </command> <command name="getSGD" protocmd="getaddr"> <addr>B410</addr> <len>3</len> <unit>UT</unit> <description>Sauggasdruck</description> </command> <command name="getHGD" protocmd="getaddr"> <addr>B411</addr> <len>3</len> <unit>UT</unit> <description>Heissgasdruck</description> </command> <command name="getEEV1-1" protocmd="getaddr"> <addr>5086</addr> <len>2</len> <unit>UT</unit> <description>EEV1-5086</description> </command> <command name="getEEV1-2" protocmd="getaddr"> <addr>5092</addr> <len>2</len> <unit>UT</unit> <description>EEV1-5092</description> </command> <command name="getEEV1-3" protocmd="getaddr"> <addr>5097</addr> <len>2</len> <unit>UT</unit> <description>EEV1-5097</description> </command> <command name="getEEV1-4" protocmd="getaddr"> <addr>5098</addr> <len>2</len> <unit>UT</unit> <description>EEV1-5098</description> </command> <command name="getgVKD" protocmd="getaddr"> <addr>1612</addr> <len>3</len> <unit>UT</unit> <description>gemittelter Kondensationsdruck Verdichter </description> </command> <command name="getTAVT" protocmd="getaddr"> <addr>1804</addr> <len>2</len> <unit>UT</unit> <description>Anlagenvorlauf Solltemperatur</description> </command> <command name="getTHK2" protocmd="getaddr"> <addr>1801</addr> <len>2</len> <unit>UT</unit> <description>Vorlauftemperatur HK2 </description> </command> <command name="getTPQ" protocmd="getaddr"> <addr>7415</addr> <len>2</len> <unit>UT</unit> <description>Primerquelle</description> </command> <command name="getTVD1" protocmd="getaddr"> <addr>5003</addr> <len>2</len> <unit>UT</unit> <description>Verdichter1</description> </command> <command name="getTEEV1-1" protocmd="getaddr"> <addr>5088</addr> <len>2</len> <unit>UT</unit> <description>EEV1 5088</description> </command> <command name="getTEEV1-2" protocmd="getaddr"> <addr>5089</addr> <len>2</len> <unit>UT</unit> <description>EEV1 5089</description> </command> <command name="getTEEV1-4" protocmd="getaddr"> <addr>5095</addr> <len>2</len> <unit>UT</unit> <description>EEV1 5095</description> </command> <command name="getTEEV1-5" protocmd="getaddr"> <addr>5212</addr> <len>2</len> <unit>UT</unit> <description>EEV1 5212</description> </command> <command name="getTEEV1-6" protocmd="getaddr"> <addr>5221</addr> <len>2</len> <unit>UT</unit> <description>EEV1 5221</description> </command> <command name="getTEEV1-7" protocmd="getaddr"> <addr>5223</addr> <len>2</len> <unit>UT</unit> <description>EEV1 5223</description> </command> <command name="getTVKE" protocmd="getaddr"> <addr>500D</addr> <len>3</len> <unit>UT</unit> <description>Verdampferkreis Eintritt</description> </command> <command name="getTVKA" protocmd="getaddr"> <addr>5010</addr> <len>2</len> <unit>UT</unit> <description>Verdampferkreis Austritt</description> </command> <command name="getTVKEg" protocmd="getaddr"> <addr>5036</addr> <len>2</len> <unit>UT</unit> <description>Verdampferkreis Eintritt gedaempft</description> </command> <command name="getTFG" protocmd="getaddr"> <addr>B404</addr> <len>3</len> <unit>UT</unit> <description>Fluessiggastemperatur</description> </command> <command name="getTSAM" protocmd="getaddr"> <addr>B432</addr> <len>3</len> <unit>UT</unit> <description>Temperatur Sammler</description> </command> <command name="getTVER" protocmd="getaddr"> <addr>B407</addr> <len>3</len> <unit>UT</unit> <description>Temperatur Verdampfung</description> </command> <command name="getTKON" protocmd="getaddr"> <addr>B408</addr> <len>3</len> <unit>UT</unit> <description>Temperatur Kondensation</description> </command> <command name="getTSG" protocmd="getaddr"> <addr>B409</addr> <len>3</len> <unit>UT</unit> <description>Temperatur Sauggas</description> </command> <command name="getTHG" protocmd="getaddr"> <addr>B40A</addr> <len>3</len> <unit>UT</unit> <description>Temperatur Heissgas</description> </command> <command name="getTPV" protocmd="getaddr"> <addr>B400</addr> <len>3</len> <unit>UT</unit> <description>Primaer Vorlauf Temperatur</description> </command> <command name="getTPR" protocmd="getaddr"> <addr>B401</addr> <len>3</len> <unit>UT</unit> <description>Primaer Ruecklauf Temperatur</description> </command> <command name="getTSV" protocmd="getaddr"> <addr>B402</addr> <len>3</len> <unit>UT</unit> <description>Sekunder Vorlauf Temperatur</description> </command> <command name="getTSR" protocmd="getaddr"> <addr>B403</addr> <len>3</len> <unit>UT</unit> <description>Sekunder Ruecklauf Temperatur</description> </command> <command name="getTFG1" protocmd="getaddr"> <addr>B484</addr> <len>3</len> <unit>UT</unit> <description>Fluessiggas</description> </command> <command name="getTFG2" protocmd="getaddr"> <addr>B485</addr> <len>3</len> <unit>UT</unit> <description>Fluessiggas</description> </command> <command name="getTDUK" protocmd="getaddr"> <addr>B40D</addr> <len>3</len> <unit>UT</unit> <description>Delat Unterkühlung</description> </command> <command name="getLVD" protocmd="getaddr"> <addr>B423</addr> <len>2</len> <unit>UT</unit> <description>Leitung Verdichter Prozentg</description> </command> <command name="getLPQ" protocmd="getaddr"> <addr>B420</addr> <len>2</len> <unit>UT</unit> <description>Leitung Primerquelle Prozent</description> </command> <command name="getLSP" protocmd="getaddr"> <addr>B421</addr> <len>2</len> <unit>UT</unit> <description>Leitung Serkunderpumpe Prozent</description> </command> <command name="getTVHK2" protocmd="getaddr"> <addr>01D4</addr> <len>3</len> <unit>UT</unit> <description>Vorlauftemperatur HK2</description> </command> <command name="getASKP" protocmd="getaddr"> <addr>B4C1</addr> <len>1</len> <unit>UT</unit> <description>Ausgang Sekundaerpumpe</description> </command> <command name="getDZSP" protocmd="getaddr"> <addr>B4A1</addr> <len>2</len> <unit>UT</unit> <description>Drehzahl Sekundaerpumpe</description> </command> <command name="getTPrVL" protocmd="getaddr"> <addr>01C3</addr> <len>3</len> <unit>UT</unit> <description>Primer VL Temp.</description> </command> <command name="getTPrRL" protocmd="getaddr"> <addr>01C4</addr> <len>3</len> <unit>UT</unit> <description>Primer RL Temp.</description> </command> <command name="getFKo" protocmd="getaddr"> <addr>1A54</addr> <len>1</len> <unit>UT</unit> <description>Frequenz Kompressor</description> </command> <command name="getFV1" protocmd="getaddr"> <addr>1003</addr> <len>3</len> <unit>UT</unit> <description>Frequenz Verdichter</description> </command> <command name="getTime" protocmd="getaddr"> <addr>08E0</addr> <len>8</len> <unit>UT</unit> <description>Datum</description> </command> <command name="getSHK2" protocmd="getaddr"> <addr>048E</addr> <len>1</len> <unit>UT</unit> <description>HK Pumpe</description> </command> <command name="getSMi" protocmd="getaddr"> <addr>0600</addr> <len>8</len> <unit>UT</unit> <description>Mischer</description> </command> <command name="getTSO" protocmd="getaddr"> <addr>01CD</addr> <len>3</len> <unit>UT</unit> <description>Temp. Speicher Oben</description> </command> <command name="getTSU" protocmd="getaddr"> <addr>01CE</addr> <len>3</len> <unit>UT</unit> <description>Temp. Speicher Unten</description> </command> <command name="getRLP" protocmd="getaddr"> <addr>0496</addr> <len>1</len> <unit>UT</unit> <description>Relais Ladepumpe</description> </command> <command name="getRZP" protocmd="getaddr"> <addr>0490</addr> <len>1</len> <unit>UT</unit> <description>Relais Zirkulation</description> </command> <command name="getCOP1" protocmd="getaddr"> <addr>1690</addr> <len>1</len> <unit>UT</unit> <description>COP V1</description> </command> <command name="getCOP2" protocmd="getaddr"> <addr>1691</addr> <len>1</len> <unit>UT</unit> <description>COP V2</description> </command>Hätte da noch eine Frage.
In meinel log kommt zu jeder Datenpunkt Abfrage die Meldung...State value to set for "viessmann.0.get.StatusVentilWW" has to be type "string" but received type "number"Wie kann ich das denn abstellen?
Im IOB ist der Datenpunkt auf "number" gestellt, ändere ich das auf "string" ist die Meldung unverändert!Ist da irgendwo was in der vito.xml zu ändern?
-
@mcbeath Also, ich habe die entsprechenden Datenpunkte unter Objekte im ioBroker auf den gewünschten Wert gesetzt. In diesem Fall wäre das beim Beispiel "Zahl" oder "number".
Möglicherweise kann man das auch in der Vito.xml umstellen. In der Definition einen Int-Wert dem Datenpunkt zuweisen. -
@mcbeath Also, ich habe die entsprechenden Datenpunkte unter Objekte im ioBroker auf den gewünschten Wert gesetzt. In diesem Fall wäre das beim Beispiel "Zahl" oder "number".
Möglicherweise kann man das auch in der Vito.xml umstellen. In der Definition einen Int-Wert dem Datenpunkt zuweisen. -
@mcbeath Also, ich habe die entsprechenden Datenpunkte unter Objekte im ioBroker auf den gewünschten Wert gesetzt. In diesem Fall wäre das beim Beispiel "Zahl" oder "number".
Möglicherweise kann man das auch in der Vito.xml umstellen. In der Definition einen Int-Wert dem Datenpunkt zuweisen. -
Das letztere wäre der korrekte Weg. Der Andere geht aber auch
@blauholsten
Ick wes. Das erste ist einfacher, das zweite der richtige weg, ist aber aufwendiger. -
@mcbeath Also, ich habe die entsprechenden Datenpunkte unter Objekte im ioBroker auf den gewünschten Wert gesetzt. In diesem Fall wäre das beim Beispiel "Zahl" oder "number".
Möglicherweise kann man das auch in der Vito.xml umstellen. In der Definition einen Int-Wert dem Datenpunkt zuweisen. -
@mcbeath
Noch nicht. Ich bin noch mit dem hydraulischen Abgleich meiner WP beschäftigt. Ich habe ja die bisherige Steuerung der VitoComfort 200 über den KM-Bus entsorgt und alle ERR entfernt bzw. abgeschaltet.
Das Ergebnis ist bisher eine Steigerung der COP Werte von 4,4 auf 5,1. Das sieht schon mal gut aus.
Die WP hat immer gegen teilweise geschlossene Ventile gearbeitet.Ich schaue mir das im Laufe der Woche an. Du hast eine Luft-Wärmepumpe, richtig? Ich muss mir dann die Werte mal anschauen und auf meinem Testsystem installieren.
Ich bin ja froh, dass der VControld gerade reibungslos läuft. Ich brauche ja die Werte für meine Auswertung. -
@mcbeath
Noch nicht. Ich bin noch mit dem hydraulischen Abgleich meiner WP beschäftigt. Ich habe ja die bisherige Steuerung der VitoComfort 200 über den KM-Bus entsorgt und alle ERR entfernt bzw. abgeschaltet.
Das Ergebnis ist bisher eine Steigerung der COP Werte von 4,4 auf 5,1. Das sieht schon mal gut aus.
Die WP hat immer gegen teilweise geschlossene Ventile gearbeitet.Ich schaue mir das im Laufe der Woche an. Du hast eine Luft-Wärmepumpe, richtig? Ich muss mir dann die Werte mal anschauen und auf meinem Testsystem installieren.
Ich bin ja froh, dass der VControld gerade reibungslos läuft. Ich brauche ja die Werte für meine Auswertung.@martybr sagte in Viessmann-Adapter mit vcontrol:
@mcbeath
Das Ergebnis ist bisher eine Steigerung der COP Werte von 4,4 auf 5,1. Das sieht schon mal gut aus.
Die WP hat immer gegen teilweise geschlossene Ventile gearbeitet.Ich schaue mir das im Laufe der Woche an. Du hast eine Luft-Wärmepumpe, richtig? Ich muss mir dann die Werte mal anschauen und auf meinem Testsystem installieren.
Ich bin ja froh, dass der VControld gerade reibungslos läuft. Ich brauche ja die Werte für meine Auswertung.Eine Steigerung von 4,4 auf 5,1
Da hätte ich gerne nähere Infos drüber 
Woher nimmst du denn den COP?
Ich bekomme hier nur die JAZ und die sind weit weg von 4,4
Ja genau, das ist eine Luftpumpe

Berichte mal, wenn du testen konntest, freue mich, wenn ich helfen konnte

-
@martybr sagte in Viessmann-Adapter mit vcontrol:
@mcbeath
Das Ergebnis ist bisher eine Steigerung der COP Werte von 4,4 auf 5,1. Das sieht schon mal gut aus.
Die WP hat immer gegen teilweise geschlossene Ventile gearbeitet.Ich schaue mir das im Laufe der Woche an. Du hast eine Luft-Wärmepumpe, richtig? Ich muss mir dann die Werte mal anschauen und auf meinem Testsystem installieren.
Ich bin ja froh, dass der VControld gerade reibungslos läuft. Ich brauche ja die Werte für meine Auswertung.Eine Steigerung von 4,4 auf 5,1
Da hätte ich gerne nähere Infos drüber 
Woher nimmst du denn den COP?
Ich bekomme hier nur die JAZ und die sind weit weg von 4,4
Ja genau, das ist eine Luftpumpe

Berichte mal, wenn du testen konntest, freue mich, wenn ich helfen konnte

@mcbeath
Die WO1C liefert die Werte kontinuierlich. Zu berechnen ist der Wert ja über Stromverbrauch == Aufwand zu Wärmeproduktion der WP == Ergebnis.Hier die Grafik:
Links der Peak = Warmwasser, Rechts = Heizung

Die Verbesserung des COP-Wertes lag in der Verminderung der Taktraten des Kompressors. Das habe ich wie weiter oben schon beschrieben durch Abschalten der ERR erreicht.
-
@mcbeath
Die WO1C liefert die Werte kontinuierlich. Zu berechnen ist der Wert ja über Stromverbrauch == Aufwand zu Wärmeproduktion der WP == Ergebnis.Hier die Grafik:
Links der Peak = Warmwasser, Rechts = Heizung

Die Verbesserung des COP-Wertes lag in der Verminderung der Taktraten des Kompressors. Das habe ich wie weiter oben schon beschrieben durch Abschalten der ERR erreicht.
-
@martybr
Das ist ja schön, wenn doch meine mir auch nur was zum COP erzählen würde.
Da kommt bei meiner bis dato immer nur 0,0 raus. -
@martybr
Wenn man zu blöd ist, klappt das auch nicht.... :man-facepalming:
Dein Diagramm barchte mich auf den Rechten Weg....
Mein Gedankengang ging richtung JAZ (statischer Wert)!
Allerdings ist der COP ja nur ein Momentaner Wert.
Meine Versuche den COP abzufragen war wohl immer dann, wenn die WP gerade nicht lief.
Jetz kommt er auch bei mir auf 1690 wie in deiner vito.xml
-
@martybr
Wenn man zu blöd ist, klappt das auch nicht.... :man-facepalming:
Dein Diagramm barchte mich auf den Rechten Weg....
Mein Gedankengang ging richtung JAZ (statischer Wert)!
Allerdings ist der COP ja nur ein Momentaner Wert.
Meine Versuche den COP abzufragen war wohl immer dann, wenn die WP gerade nicht lief.
Jetz kommt er auch bei mir auf 1690 wie in deiner vito.xml
-
@mcbeath
Das Ergebnis zählt doch, oder? Der Weg zur Erkenntnis ist manchmal steinig, sagte schon Konfuzius

@martybr
Da gebe ich dir voll und ganz Recht, und der Weg ist das Ziel!
Mein COP Schießt auf bis zu 20,5 hoch
Hast du auch solche Spitzen bei dir?
Wie Oft fragst du den COP ab? Habe zz. 10sec drin.
Passt zu meinen immer wieder aftretenden Einbrüchen der Sek_VL...!


-
@martybr
Da gebe ich dir voll und ganz Recht, und der Weg ist das Ziel!
Mein COP Schießt auf bis zu 20,5 hoch
Hast du auch solche Spitzen bei dir?
Wie Oft fragst du den COP ab? Habe zz. 10sec drin.
Passt zu meinen immer wieder aftretenden Einbrüchen der Sek_VL...!


-
@martybr
Da gebe ich dir voll und ganz Recht, und der Weg ist das Ziel!
Mein COP Schießt auf bis zu 20,5 hoch
Hast du auch solche Spitzen bei dir?
Wie Oft fragst du den COP ab? Habe zz. 10sec drin.
Passt zu meinen immer wieder aftretenden Einbrüchen der Sek_VL...!


-
@scrounger
Hast du einen DP für den Stromverbrauch deiner WP? In der ViessmannApi kommt ich den Wert auslesen, er muss also existieren. -
@scrounger
Hast du einen DP für den Stromverbrauch deiner WP? In der ViessmannApi kommt ich den Wert auslesen, er muss also existieren. -
@scrounger
Gut zu wissen, wenn das bei LWP's so ist.Sorry, da sind mir was viele Werte auf einmal drin.
Da sehe ich nichts mehr raus.Weniger ist manchmal mehr

-
@scrounger
Hast du einen DP für den Stromverbrauch deiner WP? In der ViessmannApi kommt ich den Wert auslesen, er muss also existieren.Ja hab ich. Gibt zwei Wege:
-
der einfache mit z.B. nem Shelly 3EM an die drei phasen der WP klemmen. Die werte stimmen dann auch bzw. da werden dann Pumpen etc. nicht mit unter schlagen.
-
der komplizierte Weg - die Statistik per vcontrold auslesen:
<!-- Statistik --> <command name="getStatistik_Jahresarbeitszahl" protocmd="getaddr"> <addr>1680</addr> <len>1</len> <unit>JAZ</unit> <description>Statistik - Energiebilanz: Jahresarbeitszahl (0..10)</description> </command> <command name="getStatistik_Jahresarbeitszahl_Heizen" protocmd="getaddr"> <addr>1681</addr> <len>1</len> <unit>JAZ</unit> <description>Statistik - Energiebilanz: Jahresarbeitszahl Heizen (0..10)</description> </command> <command name="getStatistik_Jahresarbeitszahl_Warmwasser" protocmd="getaddr"> <addr>1682</addr> <len>1</len> <unit>JAZ</unit> <description>Statistik - Energiebilanz: Jahresarbeitszahl WW (0..10)</description> </command> <command name="getStatistik_COP_Heizen" protocmd="getaddr"> <addr>1690</addr> <len>1</len> <unit>JAZ</unit> <description>Statistik - Energiebilanz: COP Heizbetrieb (0..10)</description> </command> <command name="getStatistik_COP_Warmwasser" protocmd="getaddr"> <addr>1691</addr> <len>1</len> <unit>JAZ</unit> <description>Statistik - Energiebilanz: COP Heizbetrieb (0..10)</description> </command> <command name="getEnergieFaktor" protocmd="getaddr"> <addr>163F</addr> <len>1</len> <unit>CO</unit> <description>Statistik - Energiebilanz: Faktor Energiebilanz (1 = 0.1 kWh, 10 = 1 kWh, 100 = 10 kWh)</description> </command> <command name="getEnergieHeizwaerme" protocmd="getaddr"> <addr>1640</addr> <len>4</len> <unit>CO</unit> <description>Statistik - Energiebilanz: Heizwärme "Heizbetrieb", Verdichter 1</description> </command> <command name="getEnergieHeizwaermeWW" protocmd="getaddr"> <addr>1650</addr> <len>4</len> <unit>CO</unit> <description>Statistik - Energiebilanz: Heizwärme "WW-Betrieb", Verdichter 1</description> </command> <command name="getEnergieHeizelektro" protocmd="getaddr"> <addr>1660</addr> <len>4</len> <unit>CO</unit> <description>Statistik - Energiebilanz: Elektroenergie "Heizbetrieb", Verdichter 1</description> </command> <command name="getEnergieWWelektro" protocmd="getaddr"> <addr>1670</addr> <len>4</len> <unit>CO</unit> <description>Statistik - Energiebilanz: Elektroenergie "WW-Betrieb", Verdichter 1</description> </command> <command name="getEnergyWeekDay" protocmd="setfunc"> <addr>B800</addr> <len>16</len> <unit>PL</unit> <description>Statistik Energie pro Tag (0...6)</description> </command>da bekommt man diese Daten:

Das Problem ist aber das die Gesamtwerte immer auf 52 Wochen kummuliert sind, also z.B. KW42/22 bis KW42/23. D.h. im Sommer gehen die dann runter, da ja der Verbrauch geringer wird.
Um dann den tatsächlichen Verbrauch zu ermitteln hab ich festgestellt muss man die Statistik der Tage nehmen und dann auseinander drösseln, weil die Wochenweise (7 Tage) kummuliert sind. Das habe ich mit dem folgenden Skript gemacht (Achtung das geht nicht out of the box, zeigt nur wie es gehen kann):
startScript(); async function startScript(): Promise<void> { const logPrefix = '[startScript]:'; try { // Statistik Energie Gesamt on({ id: [ 'alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Heizen.Elektrisch', 'alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Heizen.Waerme', 'alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Warmwasser.Elektrisch', 'alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Warmwasser.Waerme', ], change: 'ne' }, getEnergieStatistikGesamt); getEnergieStatistikGesamt(); // Statistik Energie Tage on({ id: [ "viessmann.0.get.Statistik_Energie_Day_0", "viessmann.0.get.Statistik_Energie_Day_1", "viessmann.0.get.Statistik_Energie_Day_2", "viessmann.0.get.Statistik_Energie_Day_3", "viessmann.0.get.Statistik_Energie_Day_4", "viessmann.0.get.Statistik_Energie_Day_5", "viessmann.0.get.Statistik_Energie_Day_6" ], change: 'ne' }, getEnergieStatistikTage); getEnergieStatistikTage(); on({ id: [ "alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute.Gesamt.Elektrisch", "alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute.Gesamt.Waerme", "alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute.Heizen.Elektrisch", "alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute.Heizen.Waerme", "alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute.Warmwasser.Elektrisch", "alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute.Warmwasser.Waerme" ], change: 'ne' }, kumuliereTodayEnergy); //@ts-ignore let scheduleResetDetailTodayValues = schedule({ time: { exactTime: true, start: "00:01" }, period: { days: 1 } }, resetTodayEnergy); //@ts-ignore let scheduleDeleteDetailOldValues = schedule({ time: { exactTime: true, start: "05:00" }, period: { weeks: 1, dows: "[1]" } }, deleteOldDetailsValues); // let scheduleNachtabsenkung = schedule({ time: { exactTime: true, start: "22:45" }, period: { days: 1 } }, nachtAbsenkung); onStop(function () { if (debug) console.debug(`[onStop]: clear schedule`); // clearSchedule(mySchedule); clearSchedule(scheduleResetDetailTodayValues); clearSchedule(scheduleDeleteDetailOldValues); // clearSchedule(scheduleNachtabsenkung); }); } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } } /** * Gesamt Statistik aus einzelnen Datenpunkten berechnen */ async function getEnergieStatistikGesamt() { let logPrefix = `[getEnergieStatistikGesamt]`; try { let waermeHeizen = await getStateAsync('alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Heizen.Waerme'); let waermeWW = await getStateAsync('alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Warmwasser.Waerme'); await myIob.setStateAsync.ifNotEqualAsync('alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Gesamt.Waerme', waermeHeizen.val + waermeWW.val, true, debug, `${logPrefix}: Heizung Wärme Gesamt aktualisiert`, elogType.info); let elektrischHeizen = await getStateAsync('alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Heizen.Elektrisch'); let elektrischWW = await getStateAsync('alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Warmwasser.Elektrisch'); await myIob.setStateAsync.ifNotEqualAsync('alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Gesamt.Elektrisch', elektrischHeizen.val + elektrischWW.val, true, debug, `${logPrefix}: Heizung Elektrisch Gesamt aktualisiert`, elogType.info); } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } } async function getEnergieStatistikTage() { let logPrefix = `[getEnergieStatistikTage]`; let idPrefix = "viessmann.0.get.Statistik_Energie_Day_"; try { let weekDayNames = moment.weekdays(true); let common: iobJS.StateCommon = { type: "number", name: 'Statistik Energie', read: true, write: false, def: 0, unit: 'kWh', role: 'state' }; for (var i = 0; i <= 6; i++) { let byteState = await getStateAsync(`${idPrefix}${i}`); let data = await statistikPerpareData(byteState.val); if (data) { let idPrefixDay = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Jahr_${data.year}.KW_${data.week.zeroPad(2)}.${data.day}_${weekDayNames[i]}` await myIob.Objects.setAsync(`${idPrefixDay}.Heizen.Waerme`, common, data.Henergy, scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDay}.Heizen.Elektrisch`, common, data.Helect, scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDay}.Warmwasser.Waerme`, common, data.DHWenergy, scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDay}.Warmwasser.Elektrisch`, common, data.DHWelec, scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDay}.Gesamt.Waerme`, common, data.Total_Energy, scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDay}.Gesamt.Elektrisch`, common, data.Totalelec, scriptName, debug, true); if (debug) console.debug(`${logPrefix} ${data.day}_${weekDayNames[i]}: ${JSON.stringify(data)}`); } } console.log(`${logPrefix}: Engerie Statistik für Tage aktualisiert`); await extractTodayEnergy(weekDayNames, common); } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } } /** * Viessmann bytes in lesbare Werte umwandeln * @param byteStr * @returns data object */ async function statistikPerpareData(byteStr) { let logPrefix = `[statistikPerpareData]`; try { let arr = byteStr.split(/[ ,]+/); let yearend = parseInt(arr[2], 16); let year = Number("20" + yearend); let day = parseInt(arr[1], 16); let week = parseInt(arr[3], 16); let Henergy = Number((parseInt((arr[5] + arr[4]), 16) * 0.1).maxDigits(3)); let Helect = Number((parseInt((arr[7] + arr[6]), 16) * 0.1).maxDigits(3)); let DHWenergy = Number((parseInt((arr[9] + arr[8]), 16) * 0.1).maxDigits(3)); let DHWelec = Number((parseInt((arr[11] + arr[10]), 16) * 0.1).maxDigits(3)); let totalenergy = Number((Henergy + DHWenergy).maxDigits(3)); let totalelec = Number((Helect + DHWelec).maxDigits(3)); return { "year": year, "week": week, "day": day, "Henergy": Henergy, "Helect": Helect, "DHWenergy": DHWenergy, "DHWelec": DHWelec, "Total_Energy": totalenergy, "Totalelec": totalelec }; } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } } /** * Engerie des heutigen Tages extrahieren * @param weekDayNames * @param common */ async function extractTodayEnergy(weekDayNames, common) { let logPrefix = `[extractTodayEnergy]`; try { // Energie für Heute extrahieren -> Heute von gestern abziehen, da Woche kumliert wird seitens Daten let dayOfWeek = moment().isoWeekday() - 1; let idPrefixDetailsToday = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute`; // Werte heute let todayDayOfWeek = moment().isoWeekday() - 1; let idPrefixToday = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Jahr_${moment().year()}.KW_${moment().week().zeroPad(2)}.${todayDayOfWeek}_${weekDayNames[todayDayOfWeek]}`; if (!await existsStateAsync(`${idPrefixToday}.Gesamt.Elektrisch`) && moment().week() === 52) { // Bei Jahreswechsel kann noch zu KW von Vorjahr gezählt werden idPrefixToday = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Jahr_${moment().year() - 1}.KW_${moment().week().zeroPad(2)}.${todayDayOfWeek}_${weekDayNames[todayDayOfWeek]}`; } let stateTodayTotalEnergy = await getStateAsync(`${idPrefixToday}.Gesamt.Elektrisch`); let stateTodayTotalHeat = await getStateAsync(`${idPrefixToday}.Gesamt.Waerme`); let stateTodayHeatingEnergy = await getStateAsync(`${idPrefixToday}.Heizen.Elektrisch`); let stateTodayHeatingHeat = await getStateAsync(`${idPrefixToday}.Heizen.Waerme`); let stateTodayWWEnergy = await getStateAsync(`${idPrefixToday}.Warmwasser.Elektrisch`); let stateTodayWWHeat = await getStateAsync(`${idPrefixToday}.Warmwasser.Waerme`); // Werte gestern let stateYesterdayTotalEnergy = 0; let stateYesterdayTotalHeat = 0; let stateYesterdayHeatingEnergy = 0; let stateYesterdayHeatingHeat = 0; let stateYesterdayWWEnergy = 0; let stateYesterdayWWHeat = 0; if (dayOfWeek > 0) { let idPrefixYesterday = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Jahr_${moment().year()}.KW_${moment().week().zeroPad(2)}.${todayDayOfWeek - 1}_${weekDayNames[todayDayOfWeek - 1]}`; if (!await existsStateAsync(`${idPrefixYesterday}.Gesamt.Elektrisch`) && moment().week() === 52) { // Bei Jahreswechsel kann noch zu KW von Vorjahr gezählt werden idPrefixYesterday = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Jahr_${moment().year() - 1}.KW_${moment().week().zeroPad(2)}.${todayDayOfWeek - 1}_${weekDayNames[todayDayOfWeek - 1]}`; } stateYesterdayTotalEnergy = (await getStateAsync(`${idPrefixYesterday}.Gesamt.Elektrisch`)).val; stateYesterdayTotalHeat = (await getStateAsync(`${idPrefixYesterday}.Gesamt.Waerme`)).val; stateYesterdayHeatingEnergy = (await getStateAsync(`${idPrefixYesterday}.Heizen.Elektrisch`)).val; stateYesterdayHeatingHeat = (await getStateAsync(`${idPrefixYesterday}.Heizen.Waerme`)).val; stateYesterdayWWEnergy = (await getStateAsync(`${idPrefixYesterday}.Warmwasser.Elektrisch`)).val; stateYesterdayWWHeat = (await getStateAsync(`${idPrefixYesterday}.Warmwasser.Waerme`)).val; } await myIob.Objects.setAsync(`${idPrefixDetailsToday}.Gesamt.Elektrisch`, common, (stateTodayTotalEnergy.val - stateYesterdayTotalEnergy).maxDigits(3), scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDetailsToday}.Gesamt.Waerme`, common, (stateTodayTotalHeat.val - stateYesterdayTotalHeat).maxDigits(3), scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDetailsToday}.Heizen.Elektrisch`, common, (stateTodayHeatingEnergy.val - stateYesterdayHeatingEnergy).maxDigits(3), scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDetailsToday}.Heizen.Waerme`, common, (stateTodayHeatingHeat.val - stateYesterdayHeatingHeat).maxDigits(3), scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDetailsToday}.Warmwasser.Elektrisch`, common, (stateTodayWWEnergy.val - stateYesterdayWWEnergy).maxDigits(3), scriptName, debug, true); await myIob.Objects.setAsync(`${idPrefixDetailsToday}.Warmwasser.Waerme`, common, (stateTodayWWHeat.val - stateYesterdayWWHeat).maxDigits(3), scriptName, debug, true); } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } } /** * heutige Energie kumulieren * @param obj Objekt des listener */ async function kumuliereTodayEnergy(obj) { let logPrefix = `[kumuliereTodayEnergy]`; try { let delta = (obj.state.val - obj.oldState.val).maxDigits(3); if (delta > 0) { let common: iobJS.StateCommon = { type: "number", name: 'Statistik Energie', read: true, write: false, def: 0, unit: 'kWh', role: 'state' }; let targetId = obj.id.replace('.Heute.', '.Kumuliert.'); let result = delta; if (await existsStateAsync(targetId)) { let targetState = await getStateAsync(targetId); result = targetState.val + delta; } await myIob.Objects.setAsync(targetId, common, result, scriptName, debug, true); if (debug) console.debug(`${logPrefix} id: ${obj.id}, old: ${obj.oldState.val}, new: ${obj.state.val}, delta: ${delta}, result: ${result} target: ${targetId}`); } } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } } /** * heutige Energie Werte zurücksetzen => 0 */ async function resetTodayEnergy() { let logPrefix = `[resetTodayEnergy]`; try { let idPrefixDetailsToday = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Heute`; await setStateAsync(`${idPrefixDetailsToday}.Gesamt.Elektrisch`, 0, true); await setStateAsync(`${idPrefixDetailsToday}.Gesamt.Waerme`, 0, true); await setStateAsync(`${idPrefixDetailsToday}.Heizen.Elektrisch`, 0, true); await setStateAsync(`${idPrefixDetailsToday}.Heizen.Waerme`, 0, true); await setStateAsync(`${idPrefixDetailsToday}.Warmwasser.Elektrisch`, 0, true); await setStateAsync(`${idPrefixDetailsToday}.Warmwasser.Waerme`, 0, true); } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } } /** * alle Energie Werte älter als 2 KWs löschen */ async function deleteOldDetailsValues() { let logPrefix = `[deleteOldDetailsValues]`; try { let myMom = moment(); myMom = myMom.add(-2, 'weeks'); let id = `alias.0.Devices.Heizung.Haus.UG.Heizungsraum.Statistik.Energie.Details.Jahr_${myMom.year()}.KW_${myMom.week()}`; if (await existsObjectAsync(id)) { await deleteObjectAsync(id, true); console.log(`${logPrefix} channel '${id}' deleted`); } else { console.warn(`${logPrefix} channel '${id}' not exists!`); } } catch (err: any) { console.error(`${logPrefix} error: ${err.message}, stack: ${err.stack}`); } }Und mit diesen Werte stellt man dann fest das die Angabe der JAZ aus der Anlage extrem geschönt ist, sofern die Wärmemenge die die Anlage misst korrekt ist - hab mir keine Wärmemengenzähler eingebaut um das gegen zu pürfen

@mcbeath sagte in Viessmann-Adapter mit vcontrol:
@martybr
Also ich habe noch keinen Wert für momentanen Stromverbrauch gefunden. Suche noch!Suche aber auch noch das expansions Ventil in %, wenn einer was weiß

<command name="getKaeltekreis_Expansionsventil_Oeffnungsweite" protocmd="getaddr"> <addr>B424</addr> <len>2</len> <description>Kältekreis: Öffnungsweite des elektronischen Expansionsventils (Pos. N)</description> <unit>PR</unit> </command> -
