Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Gaszähler auswerten - Problem

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Gaszähler auswerten - Problem

    This topic has been deleted. Only users with topic management privileges can see it.
    • Homoran
      Homoran Global Moderator Administrators @DasMoritz last edited by

      @dasmoritz sagte in Gaszähler auswerten - Problem:

      Verstehe ich es nun richtig, dass die genannten Variablen Wert, Vorheriger Wert, Zeitstempel und vorheriger Zeitstempel Bezug zur Objekt-ID (von oben) haben müssen?

      nicht müssen - sondern haben

      @dasmoritz sagte in Gaszähler auswerten - Problem:

      Dann müsste ich im ioBroker ja sagen können "Nehme dir den Wert von ObjektID..." bzw. "Nehme dir den vorherigen Wert von ObjektID..." usw.

      genau das tut dieser Baustein in allen seinen Ausprägungen

      D 1 Reply Last reply Reply Quote 0
      • D
        DasMoritz @Homoran last edited by

        @homoran

        Okay, dann beende ich mal mein bestehendes Script und starte das obenstehende.

        Das die ObjektID auf die Impulse referenziert die der Wemos D1 in den ioBroker schreibt ist korrekt?

        Homoran Asgothian 2 Replies Last reply Reply Quote 0
        • Homoran
          Homoran Global Moderator Administrators @DasMoritz last edited by

          @dasmoritz sagte in Gaszähler auswerten - Problem:

          Das die ObjektID auf die Impulse referenziert die der Wemos D1 in den ioBroker schreibt ist korrekt?

          das verstehe ich jetzt nicht.
          die ObjektID ??? schreibt

          1 Reply Last reply Reply Quote 0
          • Asgothian
            Asgothian Developer @DasMoritz last edited by Asgothian

            @dasmoritz sagte in Gaszähler auswerten - Problem:

            Das die ObjektID auf die Impulse referenziert die der Wemos D1 in den ioBroker schreibt ist korrekt?

            Ja.

            Das ist die Objekt id für den Trigger.

            Nein - du musst 2 unterschiedliche Objekt-ID's auswählen.

            Eine für den Trigger, und eine wo die Werte aus der Umrechnung hinein sollen.

            A.

            sorry - hatte deinen Post missverstanden

            D 1 Reply Last reply Reply Quote 0
            • D
              DasMoritz @Asgothian last edited by DasMoritz

              @asgothian

              Moin,

              nur damit ich es hier nun nicht versaue:
              Der Wemos D1 beschreibt autark folgenden DP über das Script, welches ich im Wemos D1 hochgeladen habe: (Datenpunkt = Impulse)

              30bbaddc-e4ac-492f-be55-7633268845e7-image.png

              Exakt diesen DP hänge ich dann bei "Falls mache" so ein, korrekt?
              e96cf71e-449c-435c-8e58-78a2065ecabe-image.png

              Zudem habe ich manuell den Datenpunkt "Impulse_600_Sek" angelegt (jener Datenpunkt, der mir anzeigt wieviele Impulse ich pro Sekunde innerhalb der letzten 600 Sekunden bekommen habe) , so korrekt?

              b5bcaf44-d3eb-4c37-aeb1-0885e0e5c91f-image.png

              Ergänzend gibt es zudem den manuellen Datenpunkt "Impulse_Scriptneu", in den ich die "Pulse pro Sekunde" schreibe korrekt?
              c18dc893-005a-42dc-a347-f59982bfe70d-image.png

              Das ganze sieht dann im Skript so aus:
              bdb12f40-3c9d-4453-8c69-5250cad9d41d-image.png

              Im Spoiler einmal das aktualisierte Skript:

              
              
               var Z_C3_A4hlerliste, Zeitliste, timeout, Gesamtzeit, Gesamtpulse, Zaehler, Liste;
              
              
              Z_C3_A4hlerliste = [];
              Zeitliste = [];
              on({id: 'mqtt.0.SmartHome.Sensor.Haustechnikraum.Impulszaehler.Zaehler_0.Impulse', change: "ne"}, async function (obj) {
                var value = obj.state.val;
                var oldValue = obj.oldState.val;
                (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})();
                timeout = setTimeout(async function () {
                  // BrennerAktiv
                  setState("javascript.0.Gaszaehler.BrennerAktiv"/*BrennerAktiv*/, false, true);
                  // Pulse pro Sekunde
                  setState("javascript.0.Gaszaehler.Impulse_Scriptneu"/*Impulse_Scriptneu*/, 0, true);
                }, 180000);
                setState("javascript.0.Gaszaehler.BrennerAktiv"/*BrennerAktiv*/, true, true);
                Z_C3_A4hlerliste[0] = (obj.state ? obj.state.val : "") - (obj.oldState ? obj.oldState.val : "");
                Zeitliste[0] = ((obj.state ? obj.state.ts : "") - (obj.oldState ? obj.oldState.ts : "")) / 1000;
                Gesamtzeit = 0;
                Gesamtpulse = 0;
                Zaehler = 1;
                while (Gesamtzeit < 600) {
                  Gesamtpulse = (typeof Gesamtpulse == 'number' ? Gesamtpulse : 0) + Liste[(Zaehler - 1)];
                  Gesamtzeit = (typeof Gesamtzeit == 'number' ? Gesamtzeit : 0) + Zeitliste[(Zaehler - 1)];
                  Zaehler = (typeof Zaehler == 'number' ? Zaehler : 0) + 1;
                }
                // durchschnittliche Anzahl von Pulsen pro Sekunde
                // min. 1/120
                setState("javascript.0.Gaszaehler.Impulse_600_Sek"/*Impulse_600_Sek*/, (Math.min(Math.max(Gesamtpulse / Gesamtzeit, 1 / 120), 1)), true);
                Zeitliste = Zeitliste.slice(0, Zaehler);
                Z_C3_A4hlerliste = Z_C3_A4hlerliste.slice(0, Zaehler);
                console.log(getState("javascript.0.Gaszaehler.Impulse_600").val);
              });
              

              Soweit in Ordnung?

              Danke 🙂

              Asgothian 1 Reply Last reply Reply Quote 0
              • Asgothian
                Asgothian Developer @DasMoritz last edited by

                @dasmoritz

                Fast, Auch an dieser Stelle solltest Du den State "Impulse_600_Sek" aktualisieren.
                Screenshot 2021-11-11 at 08.58.40.png

                Die da erwartete Zahl sollte zwischen 0.5 (Ein Impuls alle 2 Sekunden) und 0.00833 (Ein Impuls alle 120 Sekunden) liegen.

                Das müsstest Du für deine Darstellung dann noch in kW umrechnen.

                D 1 Reply Last reply Reply Quote 0
                • D
                  DasMoritz @Asgothian last edited by

                  @asgothian

                  Hi,

                  bevor ich das tue...
                  Ich bekomme beim Ausführen des Skriptes (wie oben) die folgende Fehlermeldung:

                  09:16:44.821	error	javascript.0 (2028) script.js.Moritz_Script.Gaszähler.Gaszähler_Moritz: TypeError: Cannot read property '0' of undefined
                  09:16:44.821	error	javascript.0 (2028) at Object.<anonymous> (script.js.Moritz_Script.Gaszähler.Gaszähler_Moritz:23:77)
                  

                  Das muss nach meinem Verständnis diesen Block betreffen:

                    while (Gesamtzeit < 600) {
                      Gesamtpulse = (typeof Gesamtpulse == 'number' ? Gesamtpulse : 0) + Liste[(Zaehler - 1)];
                      Gesamtzeit = (typeof Gesamtzeit == 'number' ? Gesamtzeit : 0) + Zeitliste[(Zaehler - 1)];
                      Zaehler = (typeof Zaehler == 'number' ? Zaehler : 0) + 1;
                  

                  als Blockly:
                  dd17b46c-40e1-40a9-97a7-9819e8bac2fd-image.png

                  Asgothian 1 Reply Last reply Reply Quote 0
                  • Asgothian
                    Asgothian Developer @DasMoritz last edited by

                    @dasmoritz sagte in Gaszähler auswerten - Problem:

                    @asgothian

                    Hi,

                    bevor ich das tue...
                    Ich bekomme beim Ausführen des Skriptes (wie oben) die folgende Fehlermeldung:

                    09:16:44.821	error	javascript.0 (2028) script.js.Moritz_Script.Gaszähler.Gaszähler_Moritz: TypeError: Cannot read property '0' of undefined
                    09:16:44.821	error	javascript.0 (2028) at Object.<anonymous> (script.js.Moritz_Script.Gaszähler.Gaszähler_Moritz:23:77)
                    

                    Das muss nach meinem Verständnis diesen Block betreffen:

                      while (Gesamtzeit < 600) {
                        Gesamtpulse = (typeof Gesamtpulse == 'number' ? Gesamtpulse : 0) + Liste[(Zaehler - 1)];
                        Gesamtzeit = (typeof Gesamtzeit == 'number' ? Gesamtzeit : 0) + Zeitliste[(Zaehler - 1)];
                        Zaehler = (typeof Zaehler == 'number' ? Zaehler : 0) + 1;
                    

                    als Blockly:
                    dd17b46c-40e1-40a9-97a7-9819e8bac2fd-image.png

                    Da hast du recht - da ist mir ein Fehler unterlaufen :

                    dieses
                    Screenshot 2021-11-11 at 09.30.45.png

                    muss auf
                    Screenshot 2021-11-11 at 09.33.10.png

                    erweitert werden.

                    A.

                    D 1 Reply Last reply Reply Quote 0
                    • D
                      DasMoritz @Asgothian last edited by

                      @asgothian

                      ist angepasst:
                      2e031d29-f7cc-45cb-833b-d5fc22c6c73b-image.png

                      Es kommt jedoch weiterhin der gleiche Fehler.
                      cf6abb8e-0f75-486f-9d8b-00b2701666a5-image.png

                      Asgothian 1 Reply Last reply Reply Quote 0
                      • T
                        tomba0815 last edited by tomba0815

                        Hallo,
                        wenn das auch nicht zu dem konkreten Problem passt ...
                        Ich hatte meinen Gaszähler auch bis vor einem Jahr mit einem Reed-Kontakt ausgelesen und ähnliche Probleme wie du.
                        Bin dann umgestiegen auf das hier:
                        https://forum.iobroker.net/topic/23577/wasserzähler-selfmade
                        Funktioniert ohne größere Probleme, Hardwarekosten sind sehr gering.
                        Evtl. wäre das ja auch etwas für dich ??

                        Grüße
                        Thomas

                        D 1 Reply Last reply Reply Quote 0
                        • D
                          DasMoritz @tomba0815 last edited by

                          @tomba0815 Hi,

                          Danke, spannend.
                          Ich möchte erstmal meinen Gasverbrauch digital auslesen können.
                          Das ganze soll eigentlich als Vorbereitung für eine Wärmepumpe dienen um zu erfassen, wie hoch meine Heizlast im Winter ist.

                          Die Heizung läuft momentan maximal auf 3kW (technisch limitiert), sodass die Daten mich vorrangig interessieren.

                          Aber: Das ist schon super spannend.

                          1 Reply Last reply Reply Quote 0
                          • Asgothian
                            Asgothian Developer @DasMoritz last edited by

                            @dasmoritz

                            Ich war noch nicht wach.. es fehlt noch eine Abfrage, dann muss es gehen. Wenn wir Teile der Liste leeren wollen müssen wir sicherstellen das wir auch genügend Einträge in der Liste haben.

                            Screenshot 2021-11-11 at 10.51.51.png

                            D 1 Reply Last reply Reply Quote 0
                            • D
                              DasMoritz @Asgothian last edited by

                              @asgothian

                              Hi,

                              alles fein, ich bin unendlich dankbar für deine Hilfe.

                              Ich habe das nun sehr weit unten im Skript eingebaut, in der Hoffnung es ist an der richtigen Stelle:
                              fb35a8af-fd12-4743-bbc9-a47ad52e533c-image.png

                              Weiterhin gleicher Fehler.

                              Asgothian 1 Reply Last reply Reply Quote 0
                              • Asgothian
                                Asgothian Developer @DasMoritz last edited by

                                @dasmoritz zeig nochmal das ganze Skript

                                A.

                                D 1 Reply Last reply Reply Quote 0
                                • D
                                  DasMoritz @Asgothian last edited by

                                  @asgothian

                                  Da ist es 🙂

                                  0038103f-35b0-4a6e-a408-b37ee29d9137-image.png

                                  Asgothian paul53 2 Replies Last reply Reply Quote 0
                                  • Asgothian
                                    Asgothian Developer @DasMoritz last edited by Asgothian

                                    @dasmoritz hmm.. bitte auch noch mal den generierten JS Code - da passt etwas nicht zusammen

                                    A.

                                    Nachtrag: Ich glaube ich hab den Fehler:
                                    An stelle von
                                    Screenshot 2021-11-11 at 11.19.50.png

                                    müsstest Du den Baustein so einstellen, jeweils für beide listen.

                                    Screenshot 2021-11-11 at 11.19.36.png

                                    D 1 Reply Last reply Reply Quote 0
                                    • paul53
                                      paul53 @DasMoritz last edited by

                                      @dasmoritz
                                      Wenn auf Wertänderung getriggert wird, muss man zur Berechnung der Leistung "letzte Änderung" und "vorherige letzte Änderung" verwenden.
                                      Das Skript ist viel zu kompliziert, denn die Leistung berechnet man mit

                                      Leistung = Faktor * (Wert - vorheriger Wert) / (letzte Änderung - vorherige letzte Änderung)
                                      

                                      , egal wie viele Impulse zwischen zwei Trigger-Ereignissen gezählt wurden.

                                      1 Reply Last reply Reply Quote 0
                                      • D
                                        DasMoritz @Asgothian last edited by

                                        @asgothian

                                        Oh man, weiterhin der gleiche Fehler.
                                        Hier noch einmal der aktuelle Blockly und der Code:

                                        68213aaa-7eb9-40fc-91bb-07dcb728fee0-image.png

                                        var Z_C3_A4hlerliste, Zeitliste, timeout, Gesamtzeit, Gesamtpulse, Zaehler, Liste;
                                        
                                        
                                        Z_C3_A4hlerliste = [];
                                        Zeitliste = [];
                                        on({id: 'mqtt.0.SmartHome.Sensor.Haustechnikraum.Impulszaehler.Zaehler_0.Impulse', change: "ne"}, async function (obj) {
                                          var value = obj.state.val;
                                          var oldValue = obj.oldState.val;
                                          (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})();
                                          timeout = setTimeout(async function () {
                                            // BrennerAktiv
                                            setState("javascript.0.Gaszaehler.BrennerAktiv"/*BrennerAktiv*/, false, true);
                                            // Pulse pro Sekunde
                                            setState("javascript.0.Gaszaehler.Impulse_Scriptneu"/*Impulse_Scriptneu*/, 0, true);
                                          }, 180000);
                                          setState("javascript.0.Gaszaehler.BrennerAktiv"/*BrennerAktiv*/, true, true);
                                          Z_C3_A4hlerliste.unshift((obj.state ? obj.state.val : "") - (obj.oldState ? obj.oldState.val : ""));
                                          Zeitliste.unshift(((obj.state ? obj.state.ts : "") - (obj.oldState ? obj.oldState.ts : "")) / 1000);
                                          Gesamtzeit = 0;
                                          Gesamtpulse = 0;
                                          Zaehler = 1;
                                          while (Gesamtzeit < 600 && Zaehler <= Zeitliste.length) {
                                            Gesamtpulse = (typeof Gesamtpulse == 'number' ? Gesamtpulse : 0) + Liste[(Zaehler - 1)];
                                            Gesamtzeit = (typeof Gesamtzeit == 'number' ? Gesamtzeit : 0) + Zeitliste[(Zaehler - 1)];
                                            Zaehler = (typeof Zaehler == 'number' ? Zaehler : 0) + 1;
                                          }
                                          // durchschnittliche Anzahl von Pulsen pro Sekunde
                                          // min. 1/120
                                          setState("javascript.0.Gaszaehler.Impulse_600_Sek"/*Impulse_600_Sek*/, (Math.min(Math.max(Gesamtpulse / Gesamtzeit, 1 / 120), 1)), true);
                                          if (Zaehler <= Zeitliste.length) {
                                            Zeitliste = Zeitliste.slice(0, Zaehler);
                                            Z_C3_A4hlerliste = Z_C3_A4hlerliste.slice(0, Zaehler);
                                          }
                                          console.log(getState("javascript.0.Gaszaehler.Impulse_600").val);
                                        });
                                        
                                        
                                        Asgothian 1 Reply Last reply Reply Quote 0
                                        • Asgothian
                                          Asgothian Developer @DasMoritz last edited by

                                          @dasmoritz

                                          Ok. Wald, Bäume, Einstellungen:

                                          Screenshot 2021-11-11 at 11.38.30.png

                                          An dieser Stelle muss der Punkt "Liste" auf "Zählerliste" umgestellt werden.

                                          A.

                                          D 1 Reply Last reply Reply Quote 0
                                          • D
                                            DasMoritz @Asgothian last edited by

                                            @asgothian

                                            Ich glaube wir haben einen "Durchbruch".
                                            Es kommen nun nur noch gelbe Warnmeldungen:

                                            72c6d94b-c18d-44b9-ab24-5775b468fb54-image.png

                                            Der Datenpunkt Impulse_600_Sek wird auch beschrieben:
                                            19928a29-3f41-4071-b6e2-1ed950dcbbc3-image.png

                                            Alles andere ist "Rechnerei" (hoffe ich), dass sollte ich wohl hinbekommen.

                                            Homoran Asgothian 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            928
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            6
                                            41
                                            2643
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo