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. [gelöst] Mittelwert ohne feste Abtastrate

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.2k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    946

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

[gelöst] Mittelwert ohne feste Abtastrate

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
10 Beiträge 3 Kommentatoren 1.3k Aufrufe 1 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 Offline
    M Offline
    Marc_St
    schrieb am zuletzt editiert von
    #1

    Liebes Forum,

    ich möchte ein Mittelwert der als Variable vorliegenden (und gelochten) Leistung meines Heizungs-Brenners erstellen. Dazu habe ich viel im Forum gefunden, komme aber nicht weiter. Denn gefundene Anleitungen und Skripte basieren auf der Annahme einer konstanten Abtastrate. Klar ist es denn relativ einfach, aus einem alle 60s geloggten Wert den Mittelwert auszurechnen. Ich logge meine Heizung aber per Modbus und erhalte neue Werte nur bei Änderungen. Für einen zu mittelöden Zeitraum können also unterschiedlich viele Werte vorliegen.

    Gibt es da eine Funktion? Kann mir jemand einen Tipp geben?

    Danke und beste Grüße!

    Marc

    1 Antwort Letzte Antwort
    0
    • paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von
      #2

      Du musst das Integral bilden: Aufsummieren von oldState.val * (state.lc - oldState.lc) und dann zu einem bestimmten Zeitpunkt durch die Gesamtzeit dividieren.

      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
      • paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #3

        Beispiel: Wenn die Daten aus dem https://github.com/ioBroker/ioBroker.history/blob/master/README.md ausgewertet werden sollen (2. Beispiel in Doku), dann kann die Auswertung etwa so erfolgen:

        `}, function (result) {
            var integral = 0;
            for (var i = 0; i < result.result.length; i++) {
                if(i + 1 < result.result.length) integral = integral + result.result[i].val * (result.result[i].ts - result.result[i].ts);
        	else integral = integral + result.result[i].val * (end - result.result[i].ts);
            }
            setState(idMittel, integral / (end - result.result[0].ts), true);
        });`[/i][/i][/i][/i][/i]
        

        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
        1
        • M Offline
          M Offline
          Marc_St
          schrieb am zuletzt editiert von
          #4

          Super - danke! Ich bastel selbst gerade, und da kommt dein zweites Posting genau richtig. Sehr nett!

          Viele Grüße!

          1 Antwort Letzte Antwort
          0
          • M Offline
            M Offline
            Marc_St
            schrieb am zuletzt editiert von
            #5

            Es klappt alles. Danke! :D

            Ich gehe immer mehr dazu über, Funktionen aus Homematic in iobroker zu überführen und dann nur noch die Ergebnisse in HM-Variablen zu schreiben.

            1 Antwort Letzte Antwort
            0
            • paul53P Offline
              paul53P Offline
              paul53
              schrieb am zuletzt editiert von
              #6

              @Marc_St:

              Ich gehe immer mehr dazu über, Funktionen aus Homematic in iobroker zu überführen `
              Das habe ich vor 2 Jahren gemacht.
              @Marc_St:

              Es klappt alles. `
              Dann markiere bitte das Thema im Betreff des ersten Beitrags als [gelöst].

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

                Sorry, aber doch noch einmal ich dazu. Die Funktion führt bei mir teilweise zu folgendem Fehler:

                javascript.0 TypeError: Cannot read property 'ts' of undefined at Object.cb (script.js.common.HM_Inkjektoren.Brennerleistung_24h:19:63) at Object.change (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:3386:71) at Socket. (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInMemClient.js:52:30) at Socket.Emitter.emit (/opt/iobroker/node_modules/component-emitter/index.js:133:20) at Socket.onevent (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:278:10) at Socket.onpacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:236:12) at Manager. (/opt/iobroker/node_modules/component-bind/index.js:21:15) at Manager.Emitter.emit (/opt/iobroker/node_modules/component-emitter/index.js:133:20) at Manager.ondecoded (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/manager.js:345:8) at Decoder. (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                

                Mit einigen Experimente bin ich zum Ergebnis gekommen, dass das Problem immer dann auftritt, wenn in em zu betrachtenden Zeitraum keine Daten vorlagen, z.B. weil der Brenner die letzten 24h einfach aus war.

                Ist das ein Bug?

                Gibt es da einen Workaround?

                Viele Grüße

                1 Antwort Letzte Antwort
                0
                • paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von
                  #8

                  @Marc_St:

                  Gibt es da einen Workaround? `
                  Gleiche Werte aufzeichnen(s): 86400 (24 h)

                  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
                  • M Offline
                    M Offline
                    Marc_St
                    schrieb am zuletzt editiert von
                    #9

                    Perfekt, danke! Es reicht also tatsächlich aus, wenn eine 0 gespeichert ist.

                    1 Antwort Letzte Antwort
                    0
                    • paul53P paul53

                      Beispiel: Wenn die Daten aus dem https://github.com/ioBroker/ioBroker.history/blob/master/README.md ausgewertet werden sollen (2. Beispiel in Doku), dann kann die Auswertung etwa so erfolgen:

                      `}, function (result) {
                          var integral = 0;
                          for (var i = 0; i < result.result.length; i++) {
                              if(i + 1 < result.result.length) integral = integral + result.result[i].val * (result.result[i].ts - result.result[i].ts);
                      	else integral = integral + result.result[i].val * (end - result.result[i].ts);
                          }
                          setState(idMittel, integral / (end - result.result[0].ts), true);
                      });`[/i][/i][/i][/i][/i]
                      
                      D Offline
                      D Offline
                      duffy6
                      schrieb am zuletzt editiert von duffy6
                      #10

                      @paul53

                      Ich habe mich auch gerade damit beschäftigt und meine, dass da ein kleiner Fehler drinsteckt:
                      Es sollte heißen:

                      if(i + 1 < result.result.length) integral = integral + result.result[i].val * (result.result[i+1].ts - result.result[i].ts);

                      Mein Dank gebührt trotzdem @paul53. Ohne ihn hätte ich den Ansatz nicht gefunden!

                      Mein Code sieht komplett dann so aus (für die Nachwelt):

                      var end = Date.now();
                      sendTo('history.0', 'getHistory', {
                          id: 'mqtt.0.heizung.HzAnlage.Laststellung',
                          options: {
                              start:      end - 86400000,
                              end:        end,
                              aggregate: 'none'
                      
                          }
                      }, function (result) {
                          var integral = 0;
                          console.log("Anzahl: "+result.result.length);
                          for (var i=0; i < result.result.length; i++) {
                          console.log(i+"---"+result.result[i].ts + "---"+ result.result[i].val);
                          }  
                      
                      // Test
                      for (var i=0; i < result.result.length; i++) {
                          // var zeitdiff = 0;
                          // zeitdiff = result.result[i+1].ts - result.result[i].ts;
                          // console.log(i+"--diff--" + zeitdiff);
                           
                      
                      if (i + 1 < result.result.length) {
                          integral = integral + ( result.result[i].val * (result.result[i+1].ts - result.result[i].ts)    ) ;
                      } else {
                          integral = integral + result.result[i].val * (end - result.result[i].ts);
                      } // Else Ende
                      
                      }  // Schleifen Ende 
                      
                      var gesamtzeit = end - result.result[0].ts;
                      console.log("Gesamtzeit in sek: " + gesamtzeit/1000 + " = "+ gesamtzeit/(1000*60) + " min = " + gesamtzeit/(1000*60*60) + " h");
                      var mittelwert = integral / gesamtzeit;
                      console.log("Mittelwert: " + mittelwert);
                      
                      // Hier Zuweisung an eine iobroker Variable
                      
                      }); // function ende
                      
                      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

                      663

                      Online

                      32.6k

                      Benutzer

                      82.2k

                      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