Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Viessmann-Adapter mit vcontrol

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.4k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.0k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.5k

Viessmann-Adapter mit vcontrol

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
354 Beiträge 18 Kommentatoren 99.0k Aufrufe 17 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • M MartyBr

    @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.

    blauholstenB Offline
    blauholstenB Offline
    blauholsten
    Developer
    schrieb am zuletzt editiert von
    #323

    @martybr

    Das letztere wäre der korrekte Weg. Der Andere geht aber auch

    Entwickler vom: - Viessman Adapter
    - Alarm Adapter

    M 1 Antwort Letzte Antwort
    0
    • M MartyBr

      @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.

      M Offline
      M Offline
      McBeath
      schrieb am zuletzt editiert von
      #324

      @martybr
      Komisch, hatte ich eben schon mal probiert, aber jetz funktioniert alles :fearful: :grin:

      1 Antwort Letzte Antwort
      0
      • blauholstenB blauholsten

        @martybr

        Das letztere wäre der korrekte Weg. Der Andere geht aber auch

        M Offline
        M Offline
        MartyBr
        schrieb am zuletzt editiert von
        #325

        @blauholsten
        Ick wes. Das erste ist einfacher, das zweite der richtige weg, ist aber aufwendiger.

        Gruß
        Martin


        Intel NUCs mit Proxmox / Iobroker als VM unter Debian
        Raspeberry mit USB Leseköpfen für Smartmeter
        Homematic und Homematic IP

        1 Antwort Letzte Antwort
        0
        • M MartyBr

          @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.

          M Offline
          M Offline
          McBeath
          schrieb am zuletzt editiert von
          #326

          @martybr
          Konntest du mit meinen Datenpunkten an deiner Pumpe was mit Auslesen? :flushed:

          M 1 Antwort Letzte Antwort
          0
          • M McBeath

            @martybr
            Konntest du mit meinen Datenpunkten an deiner Pumpe was mit Auslesen? :flushed:

            M Offline
            M Offline
            MartyBr
            schrieb am zuletzt editiert von
            #327

            @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.

            Gruß
            Martin


            Intel NUCs mit Proxmox / Iobroker als VM unter Debian
            Raspeberry mit USB Leseköpfen für Smartmeter
            Homematic und Homematic IP

            M 1 Antwort Letzte Antwort
            0
            • M MartyBr

              @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.

              M Offline
              M Offline
              McBeath
              schrieb am zuletzt editiert von
              #328

              @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 :flushed: Da hätte ich gerne nähere Infos drüber :grin:
              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 :joy:

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

              M 1 Antwort Letzte Antwort
              0
              • M McBeath

                @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 :flushed: Da hätte ich gerne nähere Infos drüber :grin:
                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 :joy:

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

                M Offline
                M Offline
                MartyBr
                schrieb am zuletzt editiert von
                #329

                @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
                Bildschirmfoto 2023-12-06 um 06.43.24.png

                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.

                Gruß
                Martin


                Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                Raspeberry mit USB Leseköpfen für Smartmeter
                Homematic und Homematic IP

                M 1 Antwort Letzte Antwort
                0
                • M MartyBr

                  @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
                  Bildschirmfoto 2023-12-06 um 06.43.24.png

                  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.

                  M Offline
                  M Offline
                  McBeath
                  schrieb am zuletzt editiert von
                  #330

                  @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.

                  M 1 Antwort Letzte Antwort
                  0
                  • M McBeath

                    @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.

                    M Offline
                    M Offline
                    MartyBr
                    schrieb am zuletzt editiert von
                    #331

                    @mcbeath Welchen Datenpunkt fragst du ab?

                    Gruß
                    Martin


                    Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                    Raspeberry mit USB Leseköpfen für Smartmeter
                    Homematic und Homematic IP

                    M 1 Antwort Letzte Antwort
                    0
                    • M MartyBr

                      @mcbeath Welchen Datenpunkt fragst du ab?

                      M Offline
                      M Offline
                      McBeath
                      schrieb am zuletzt editiert von
                      #332

                      @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. :joy:

                      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 :grin:

                      M 1 Antwort Letzte Antwort
                      0
                      • M McBeath

                        @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. :joy:

                        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 :grin:

                        M Offline
                        M Offline
                        MartyBr
                        schrieb am zuletzt editiert von
                        #333

                        @mcbeath
                        Das Ergebnis zählt doch, oder? Der Weg zur Erkenntnis ist manchmal steinig, sagte schon Konfuzius :grinning: :grinning:

                        Gruß
                        Martin


                        Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                        Raspeberry mit USB Leseköpfen für Smartmeter
                        Homematic und Homematic IP

                        M 1 Antwort Letzte Antwort
                        0
                        • M MartyBr

                          @mcbeath
                          Das Ergebnis zählt doch, oder? Der Weg zur Erkenntnis ist manchmal steinig, sagte schon Konfuzius :grinning: :grinning:

                          M Offline
                          M Offline
                          McBeath
                          schrieb am zuletzt editiert von McBeath
                          #334

                          @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 :flushed:
                          Hast du auch solche Spitzen bei dir?
                          Wie Oft fragst du den COP ab? Habe zz. 10sec drin.

                          COP.png

                          Passt zu meinen immer wieder aftretenden Einbrüchen der Sek_VL...! :thinking_face:
                          COP.png

                          ScroungerS M 2 Antworten Letzte Antwort
                          0
                          • M McBeath

                            @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 :flushed:
                            Hast du auch solche Spitzen bei dir?
                            Wie Oft fragst du den COP ab? Habe zz. 10sec drin.

                            COP.png

                            Passt zu meinen immer wieder aftretenden Einbrüchen der Sek_VL...! :thinking_face:
                            COP.png

                            ScroungerS Offline
                            ScroungerS Offline
                            Scrounger
                            Developer
                            schrieb am zuletzt editiert von Scrounger
                            #335

                            @mcbeath
                            Der COP schießt bei der Abtauung auf 20 hoch, ist zumindest bei mir so

                            78578a62-cef6-4fe0-9272-1d8db7620b85-grafik.png

                            <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                            <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                            M M L 4 Antworten Letzte Antwort
                            0
                            • M McBeath

                              @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 :flushed:
                              Hast du auch solche Spitzen bei dir?
                              Wie Oft fragst du den COP ab? Habe zz. 10sec drin.

                              COP.png

                              Passt zu meinen immer wieder aftretenden Einbrüchen der Sek_VL...! :thinking_face:
                              COP.png

                              M Offline
                              M Offline
                              MartyBr
                              schrieb am zuletzt editiert von
                              #336

                              @mcbeath
                              Nein, der COP meiner WP geht auf max. 7 bis 8 hoch. Ich habe aber eine Sole-WP.

                              Gruß
                              Martin


                              Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                              Raspeberry mit USB Leseköpfen für Smartmeter
                              Homematic und Homematic IP

                              1 Antwort Letzte Antwort
                              0
                              • ScroungerS Scrounger

                                @mcbeath
                                Der COP schießt bei der Abtauung auf 20 hoch, ist zumindest bei mir so

                                78578a62-cef6-4fe0-9272-1d8db7620b85-grafik.png

                                M Offline
                                M Offline
                                MartyBr
                                schrieb am zuletzt editiert von
                                #337

                                @scrounger
                                Hast du einen DP für den Stromverbrauch deiner WP? In der ViessmannApi kommt ich den Wert auslesen, er muss also existieren.

                                Gruß
                                Martin


                                Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                                Raspeberry mit USB Leseköpfen für Smartmeter
                                Homematic und Homematic IP

                                M ScroungerS 2 Antworten Letzte Antwort
                                0
                                • M MartyBr

                                  @scrounger
                                  Hast du einen DP für den Stromverbrauch deiner WP? In der ViessmannApi kommt ich den Wert auslesen, er muss also existieren.

                                  M Offline
                                  M Offline
                                  McBeath
                                  schrieb am zuletzt editiert von
                                  #338

                                  @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ß :point_up:

                                  1 Antwort Letzte Antwort
                                  0
                                  • ScroungerS Scrounger

                                    @mcbeath
                                    Der COP schießt bei der Abtauung auf 20 hoch, ist zumindest bei mir so

                                    78578a62-cef6-4fe0-9272-1d8db7620b85-grafik.png

                                    M Offline
                                    M Offline
                                    McBeath
                                    schrieb am zuletzt editiert von
                                    #339

                                    @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 :joy:

                                    1 Antwort Letzte Antwort
                                    0
                                    • M MartyBr

                                      @scrounger
                                      Hast du einen DP für den Stromverbrauch deiner WP? In der ViessmannApi kommt ich den Wert auslesen, er muss also existieren.

                                      ScroungerS Offline
                                      ScroungerS Offline
                                      Scrounger
                                      Developer
                                      schrieb am zuletzt editiert von Scrounger
                                      #340

                                      @martybr

                                      Ja hab ich. Gibt zwei Wege:

                                      1. 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.

                                      2. 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:
                                      f15d4cc3-6b8e-4a78-89da-dbe962f7f386-grafik.png

                                      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ß :point_up:

                                      		<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>
                                      

                                      <a href="https://github.com/Scrounger/ioBroker.linkeddevices">LinkedDevices Adapter</a>

                                      <a href="https://github.com/Scrounger/ioBroker.vis-materialdesign">Material Design Widgets</a>

                                      M 1 Antwort Letzte Antwort
                                      1
                                      • ScroungerS Scrounger

                                        @martybr

                                        Ja hab ich. Gibt zwei Wege:

                                        1. 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.

                                        2. 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:
                                        f15d4cc3-6b8e-4a78-89da-dbe962f7f386-grafik.png

                                        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ß :point_up:

                                        		<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>
                                        
                                        M Offline
                                        M Offline
                                        MartyBr
                                        schrieb am zuletzt editiert von
                                        #341

                                        @scrounger
                                        VIELEN Dank für die Infos. An dem Shelly hatte ich auch schon gedacht, aber dann die Werte in der ViessmannApi gesehen. Die liefern ja "sekündlich" die Verbrauchswerte. Damit müssten sie auf aus der Steuerung auslesbar sein.

                                        Ich teste dann deine Datenpunkte. Die JAZ etc. habe ich ja schon in meiner vito.xml, den Rest nehmen ich dann mal auf.

                                        Gruß
                                        Martin


                                        Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                                        Raspeberry mit USB Leseköpfen für Smartmeter
                                        Homematic und Homematic IP

                                        1 Antwort Letzte Antwort
                                        0
                                        • ScroungerS Scrounger

                                          @mcbeath
                                          Der COP schießt bei der Abtauung auf 20 hoch, ist zumindest bei mir so

                                          78578a62-cef6-4fe0-9272-1d8db7620b85-grafik.png

                                          L Online
                                          L Online
                                          legro
                                          schrieb am zuletzt editiert von
                                          #342

                                          @scrounger sagte in Viessmann-Adapter mit vcontrol:

                                          Der COP schießt bei der Abtauung auf 20 hoch, ist zumindest bei mir so

                                          Ich kann zwar nur mit maximalem COP≈10 punkten, aber ja, es sind die Enteisungsphasen, in denen der COP derart unsinnig nach oben geht.

                                          Nach über vier Jahren Leidenszeit unter Qivicon/MSH vor den Telekomikern zu ioBroker geflüchtet.
                                          Raspberry Pi 4 mit 8GB + ArgonOneM.2 + 120GB SSD + Coordinator CC26X2R1 + ioBroker + piVCCU3

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          525

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe