Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Fehler beim Auslesen

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Fehler beim Auslesen

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 last edited by

      //createState('Oelstand', 0);
      
      var Hoehe = 'hm-rpc.1.LEQ02XXXXX.21.VALUE'; //Fuellhoehe des Oeltanks
      var Dichte = 0.84;
      var Flaeche = 4;
      
      on (Hoehe, function (dp) {
         var Oelstand = dp.state.val * Flaeche;
         setState('Oelstand', Oelstand);
         log('Ölstand: ' + Oelstand);
         log('Höhe: ' + dp.state.val);
      });
      
      1 Reply Last reply Reply Quote 0
      • Mr. Burns
        Mr. Burns last edited by

        Funktioniert! Vielen Dank.

        Wenn ich einmal dabei bin. Hat jemand schon mal eine Mittelwertbildung geschrieben?

        Also addiere x Werte, und teile das Ergebnis durch x?

        Gruß

        Thomas

        P.S. Kann mir einer erklären warum mein Weg falsch und der von Paul richtig war?

        Vielleicht versteh ich dann irgendwann was ich da eigentlich programmiere :-D.

        1 Reply Last reply Reply Quote 0
        • paul53
          paul53 last edited by

          @Mr. Burns:

          Hat jemand schon mal eine Mittelwertbildung geschrieben? `
          Ja, für http://www.iobroker.net/?page_id=3670&lang=de.
          @Mr. Burns:

          Kann mir einer erklären warum mein Weg falsch und der von Paul richtig war? `

             setState('Oelstand', getState(Hoehe).val * getState(Flaeche).val);
          

          getState(id) kann nur auf einen Datenpunkt angewendet werden, nicht auf eine Skriptvariable (Flaeche).

             log(Oelstand);
          log(Hoehe);
          

          Die Skriptvariable Oelstand wird nicht aktualisiert, sondern enthält ihren Initialisierungswert.

          Die Skriptvariable Hoehe enthält den ID-String des Datenpunktes, nicht den Wert.

          1 Reply Last reply Reply Quote 0
          • Mr. Burns
            Mr. Burns last edited by

            Danke für deine Erklärung. So ganz verstanden hab ich es nicht, aber dafür fehlen mir wahrscheinlich die Grundlagen.

            Das die Scriptvariable nicht gelesen werden muss bevor ich sie weiterverarbeite versteh ich noch…ist ja schon da. Aber weshalb kann ich das einlesen des Datenpunktes überspringen...

            Dein Script zur Mittelwertbildung hatte ich zwischenzeitlich auch gefunden...ist aber zu hoch für mich. Ich benötige eine feste Anzahl von werten (z.B 10 o. 20) welche gemittelt werden sollen. Da meine Werte nicht zeitabhängig gelesen Werten, sondern auf Änderung getriggert sind müßte ich das Script umschreiben...Ich werd mal den langen Weg mit zwischenvariablen versuchen und gucken wie weit ich komme.

            Danke für die Hilfe!

            Thomas

            1 Reply Last reply Reply Quote 0
            • paul53
              paul53 last edited by

              @Mr. Burns:

              Aber weshalb kann ich das einlesen des Datenpunktes überspringen… `
              Welchen Datenpunkt meinst Du ? Wo wird etwas übersprungen ?

              1 Reply Last reply Reply Quote 0
              • Mr. Burns
                Mr. Burns last edited by

                Hi,

                Der Datenpunkt:

                var Hoehe = 'hm-rpc.1.LEQ02XXXXX.21.VALUE'; //Fuellhoehe des Oeltanks
                

                muss der nicht eingelesen werden bevor dieser weiterverarbeitet werden kann…getState?

                Hab mir die Geschichte mit dem Mittelwert noch mal angesehen.

                Wenn ich Zeitvariable (n, über T oder tc wegen der umwandlung in Ganzzahlen) durch einen festen wert ersetze und den intervall Trigger durch einen ON Trigger ersetze müsste es doch eigentlich funktionieren oder...? Ich bin beruflich unterwegs und kann nicht so gut testen (VPN geht nicht überall)...

                Gruß

                Thomas

                1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 last edited by

                  @Mr. Burns:

                  …muss der nicht eingelesen werden bevor dieser weiterverarbeitet werden kann...getState? `

                  on(id, function(mein_Datenpunkt) {...callback-Funktion...});
                  

                  übergibt ebenfalls den Zustand (state) des Datenpunktes an das Objekt (hier: mein_Datenpunkt), das in der callback-Funktion ausgewertet werden kann.

                  mein_Datenpunkt.state.val
                  

                  innerhalb der callback-Funktion entspricht

                  getState(id).val
                  

                  an beliebiger Stelle des Skripts. getState(id).val verursacht aber eine höhere CPU-Belastung, da (im Prinzip) ein zusätzlicher Datenbankzugriff erfolgt.

                  1 Reply Last reply Reply Quote 0
                  • Mr. Burns
                    Mr. Burns last edited by

                    Ich möchte mich sehr für die Hilfe bedanken und das Thema hiermit abschließen.

                    Das auslesen umrechnen und die Mittelwertbildung des Öltanks über eine Pneumatische Füllstandsmessung…funktioniert.

                    `// Oelstand errechnen und gleitenden Mittelwert von "x" werten bilden
                    
                    // Konstanten
                    var T = 100;         // Anzahl der Werte
                    var Dichte = 0.84;  // Heizöldichte
                    var Flaeche = 4;    // Fläche des Öltanks (bei einer Rechteckigigen oder Zylindrischen Form) in m2
                    
                    // IDs aller benötigten Datenpunkte
                    var Hoehe   = 'hm-rpc.1.LEQ02XXXXX.21.VALUE';
                    var average = 'vis.Keller.Oelstand';
                    var listid = 'vis.Keller.Oelstand-Liste';
                    
                    var n = Math.round(T); // Anzahl der Werte
                    var list  = new Array(n);
                    
                    function calc() {
                      list.pop();
                      var x = getState(Hoehe).val * Flaeche / Dichte;
                      list.unshift(x);
                      setState(listid, list.toString());
                      var sum = 0.0;
                      for (var i = 0; i < n; i++) {
                        var s = parseFloat(list[i]); 
                       sum = sum + s;
                      }
                      setState(average, parseFloat((sum / n).toFixed(1)));
                      //log (n);
                    }   
                    
                    // Script start: Liste aus String-Datenpunkt einlesen
                    var slist = getState(listid).val;
                    if (slist) {
                       list = slist.split(",");
                    } else {
                       // 1\. Script start: Liste und String-Datenpunkt füllen
                       var x = getState(Hoehe).val * Flaeche / Dichte;
                       for (var i = 0; i < n; i++) list[i] = x;
                       calc();
                    }
                    
                    // Triggert die Funktion bei Änderung der Eingangsgröße
                    on (Hoehe, function (dp) {
                        calc();
                    });`[/i][/i]
                    
                    1 Reply Last reply Reply Quote 0
                    • C
                      Centurytt last edited by

                      @Mr. Burns:

                      Ich möchte mich sehr für die Hilfe bedanken und das Thema hiermit abschließen.

                      Das auslesen umrechnen und die Mittelwertbildung des Öltanks über eine Pneumatische Füllstandsmessung…funktioniert.

                      `// Oelstand errechnen und gleitenden Mittelwert von "x" werten bilden
                       
                      // Konstanten
                      var T = 100;         // Anzahl der Werte
                      var Dichte = 0.84;  // Heizöldichte
                      var Flaeche = 4;    // Fläche des Öltanks (bei einer Rechteckigigen oder Zylindrischen Form) in m2
                       
                      // IDs aller benötigten Datenpunkte
                      var Hoehe   = 'hm-rpc.1.LEQ02XXXXX.21.VALUE';
                      var average = 'vis.Keller.Oelstand';
                      var listid = 'vis.Keller.Oelstand-Liste';
                       
                      var n = Math.round(T); // Anzahl der Werte
                      var list  = new Array(n);
                       
                      function calc() {
                        list.pop();
                        var x = getState(Hoehe).val * Flaeche / Dichte;
                        list.unshift(x);
                        setState(listid, list.toString());
                        var sum = 0.0;
                        for (var i = 0; i < n; i++) {
                          var s = parseFloat(list[i]); 
                         sum = sum + s;
                        }
                        setState(average, parseFloat((sum / n).toFixed(1)));
                        //log (n);
                      }   
                      
                      // Script start: Liste aus String-Datenpunkt einlesen
                      var slist = getState(listid).val;
                      if (slist) {
                         list = slist.split(",");
                      } else {
                         // 1\. Script start: Liste und String-Datenpunkt füllen
                         var x = getState(Hoehe).val * Flaeche / Dichte;
                         for (var i = 0; i < n; i++) list[i] = x;
                         calc();
                      }
                      
                      // Triggert die Funktion bei Änderung der Eingangsgröße
                      on (Hoehe, function (dp) {
                          calc();
                      });`
                      
                      Hi,
                      
                      was hast du da im Einsatz (Hardware zum Füllstand anzeigen) ? würde mich auch interessier das zu realisieren.
                      
                      Danke
                      
                      lg
                      
                      Tom[/i][/i]
                      ``` ` 
                      1 Reply Last reply Reply Quote 0
                      • Mr. Burns
                        Mr. Burns last edited by

                        Hi,

                        Einen Drucktransmitter 4..20mA, einen Wandler von 4..20mA auf 0..10V, Eingang auf das 12/14 Modul.

                        Ich hab ein Röhrchen, welches bis zum Tankboden geht. Oben ist ein T-Stück, an welchem der Drucktransmitter sitzt. auf dem anderem Anschluss des T-Stücks ist eine Membranpumpe (alte Aquarium Luftpumpe) und ein Nadelventil. Nach der Einperlmethode messe ich den Druck am Boden des Tanks.

                        Mittlerweile messe ich aber direkt über eine SPS und übergebe den Wert an den ioBroker.

                        Parallel messe ich noch den Durchfluss über ein Braun Ölzähler, auch an direkt an der SPS…

                        Gruß

                        Thomas

                        1 Reply Last reply Reply Quote 0
                        • First post
                          Last post

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        674
                        Online

                        31.7k
                        Users

                        79.9k
                        Topics

                        1.3m
                        Posts

                        5
                        13
                        1297
                        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