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

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Blockly
  5. Gaszähler auswerten - Problem

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    328

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.5k

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

Gaszähler auswerten - Problem

Geplant Angeheftet Gesperrt Verschoben Blockly
41 Beiträge 6 Kommentatoren 4.5k Aufrufe 4 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.
  • AsgothianA Asgothian

    @dasmoritz zeig nochmal das ganze Skript

    A.

    D Offline
    D Offline
    DasMoritz
    schrieb am zuletzt editiert von
    #31

    @asgothian

    Da ist es :-)

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

    AsgothianA paul53P 2 Antworten Letzte Antwort
    0
    • D DasMoritz

      @asgothian

      Da ist es :-)

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

      AsgothianA Offline
      AsgothianA Offline
      Asgothian
      Developer
      schrieb am zuletzt editiert von Asgothian
      #32

      @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

      ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
      "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

      D 1 Antwort Letzte Antwort
      0
      • D DasMoritz

        @asgothian

        Da ist es :-)

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

        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #33

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

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        1 Antwort Letzte Antwort
        0
        • AsgothianA 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 Offline
          D Offline
          DasMoritz
          schrieb am zuletzt editiert von
          #34

          @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);
          });
          
          
          AsgothianA 1 Antwort Letzte Antwort
          0
          • D DasMoritz

            @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);
            });
            
            
            AsgothianA Offline
            AsgothianA Offline
            Asgothian
            Developer
            schrieb am zuletzt editiert von
            #35

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

            ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
            "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

            D 1 Antwort Letzte Antwort
            0
            • AsgothianA Asgothian

              @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 Offline
              D Offline
              DasMoritz
              schrieb am zuletzt editiert von
              #36

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

              HomoranH AsgothianA 2 Antworten Letzte Antwort
              0
              • D DasMoritz

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

                HomoranH Nicht stören
                HomoranH Nicht stören
                Homoran
                Global Moderator Administrators
                schrieb am zuletzt editiert von
                #37

                @dasmoritz sagte in Gaszähler auswerten - Problem:

                Es kommen nun nur noch gelbe Warnmeldungen:

                Bitte als Text in Code-tags posten und dann mal in de js-Ansicht die entsprechende Stellen dazu posten (Zeile 29, Pos3 und Zeil 34, Pos 15)

                kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                1 Antwort Letzte Antwort
                0
                • D DasMoritz

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

                  AsgothianA Offline
                  AsgothianA Offline
                  Asgothian
                  Developer
                  schrieb am zuletzt editiert von
                  #38

                  @dasmoritz
                  Zumindest die 2. Warnung kann ich erklären - du hast einen debug Baustein mit einem Datenpunkt der wahrscheinlich nicht existiert oder nicht gefüllt ist

                  Screenshot 2021-11-11 at 13.00.53.png

                  Die erste ist mir noch nicht ganz klar.

                  A.

                  ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                  "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                  D 1 Antwort Letzte Antwort
                  0
                  • AsgothianA Asgothian

                    @dasmoritz
                    Zumindest die 2. Warnung kann ich erklären - du hast einen debug Baustein mit einem Datenpunkt der wahrscheinlich nicht existiert oder nicht gefüllt ist

                    Screenshot 2021-11-11 at 13.00.53.png

                    Die erste ist mir noch nicht ganz klar.

                    A.

                    D Offline
                    D Offline
                    DasMoritz
                    schrieb am zuletzt editiert von
                    #39

                    @asgothian

                    Moin,

                    nun passiert gar nichts mehr, da die seit 12:07 Heizung aus ist.
                    Müsste nicht zumindest in der grauen Theorie das Script weiterlaufen und damit den Wert "Impulse_600_Sek" immer weiter in Richtung 0,00 führen, jetzt wo die Heizung aus ist?

                    Der Wert ist mit dem letzten Impuls bei 0,0267 stehen geblieben.
                    d456d2ec-4dcf-4dc2-a308-7a569b912af8-image.png

                    Danke,
                    Moritz

                    paul53P 1 Antwort Letzte Antwort
                    0
                    • D DasMoritz

                      @asgothian

                      Moin,

                      nun passiert gar nichts mehr, da die seit 12:07 Heizung aus ist.
                      Müsste nicht zumindest in der grauen Theorie das Script weiterlaufen und damit den Wert "Impulse_600_Sek" immer weiter in Richtung 0,00 führen, jetzt wo die Heizung aus ist?

                      Der Wert ist mit dem letzten Impuls bei 0,0267 stehen geblieben.
                      d456d2ec-4dcf-4dc2-a308-7a569b912af8-image.png

                      Danke,
                      Moritz

                      paul53P Offline
                      paul53P Offline
                      paul53
                      schrieb am zuletzt editiert von paul53
                      #40

                      @dasmoritz
                      Nach den 180 s muss neben "Brenner aktiv auf falsch" auch "Impulse_600_Sek auf 0" gesetzt werden.

                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                      D 1 Antwort Letzte Antwort
                      0
                      • paul53P paul53

                        @dasmoritz
                        Nach den 180 s muss neben "Brenner aktiv auf falsch" auch "Impulse_600_Sek auf 0" gesetzt werden.

                        D Offline
                        D Offline
                        DasMoritz
                        schrieb am zuletzt editiert von
                        #41

                        @paul53 Das macht absolut Sinn, ist eingebaut.

                        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

                        405

                        Online

                        32.5k

                        Benutzer

                        81.7k

                        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