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. Zulauf einer Zisterne in Liter/h berechnen

NEWS

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.6k

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

Zulauf einer Zisterne in Liter/h berechnen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
blocklyjavascript
52 Beiträge 8 Kommentatoren 6.7k Aufrufe 8 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.
  • paul53P paul53

    @Aiouh sagte:

    Vermutlich weil ich nun cm und nicht dm bekomme.

    Ja. Mit h = (U - 120) / 24 sollte die Höhe in dm berechnet werden. Die Länge und den Radius des Zylinders hast Du richtig in dm eingetragen ? Die Formel zur Volumenberechung braucht alle Werte in dm.

    A Online
    A Online
    Aiouh
    schrieb am zuletzt editiert von Aiouh
    #22

    @paul53 Perfekt !
    Ja, Radius und Länge hab ich in dm.
    Danke Dir

    A 1 Antwort Letzte Antwort
    0
    • A Aiouh

      @paul53 Perfekt !
      Ja, Radius und Länge hab ich in dm.
      Danke Dir

      A Online
      A Online
      Aiouh
      schrieb am zuletzt editiert von
      #23

      @paul53
      Die Anzeige des Tankvolumens klappt nun gut. Nachdem es heute endlich mal wieder etwas Regen gab, habe ich festgestellt, dass das mit der Durchflussmessung noch nicht klappt.
      Die kleinste Volumen Auflösung die ich systembedingt hinbekomme (+/-10mV) sind 29 Liter, was für mich völlig OK ist.
      Die Durchflussmenge pendelt jedoch zwischen 0 und 1000, offenbar so wie das letzte digit springt.
      Hab ich da noch was übersehen?

      Spannung vom Geber (408 =4,08V)
      408 	true 	modbus.2 	2020-06-04 19:42:06.895 	
      409 	true 	modbus.2 	2020-06-04 19:42:17.889 	
      408 	true 	modbus.2 	2020-06-04 19:42:56.992 	
      409 	true 	modbus.2 	2020-06-04 19:43:08.092 	
      408 	true 	modbus.2 	2020-06-04 19:43:18.889 	
      409 	true 	modbus.2 	2020-06-04 19:43:29.889 	
      408 	true 	modbus.2 	2020-06-04 19:43:58.990 	
      409 	true 	modbus.2 	2020-06-04 19:44:19.888 	
      408 	true 	modbus.2 	2020-06-04 19:44:49.889 	
      409 	true 	modbus.2 	2020-06-04 19:45:00.955 	
      408 	true 	modbus.2 	2020-06-04 19:48:46.886 	
      409 	true 	modbus.2 	2020-06-04 19:48:57.886
      
      Volumen in Liter
      8055 	true 	javascript.0 	2020-06-04 19:42:06.905 	
      8084 	true 	javascript.0 	2020-06-04 19:42:17.897 	
      8055 	true 	javascript.0 	2020-06-04 19:42:57.005 	
      8084 	true 	javascript.0 	2020-06-04 19:43:08.101 	
      8055 	true 	javascript.0 	2020-06-04 19:43:18.896 	
      8084 	true 	javascript.0 	2020-06-04 19:43:29.896 	
      8055 	true 	javascript.0 	2020-06-04 19:43:58.999 	
      8084 	true 	javascript.0 	2020-06-04 19:44:19.894 	
      8055 	true 	javascript.0 	2020-06-04 19:44:49.896 	
      8084 	true 	javascript.0 	2020-06-04 19:45:01.026 	
      8055 	true 	javascript.0 	2020-06-04 19:48:46.894 	
      8084 	true 	javascript.0 	2020-06-04 19:48:57.894
      
      
      Durchfluss 
      0 	true 	javascript.0 	2020-06-04 19:42:06.905 	
      1000 	true 	javascript.0 	2020-06-04 19:42:17.897 	
      0 	true 	javascript.0 	2020-06-04 19:42:57.005 	
      1000 	true 	javascript.0 	2020-06-04 19:43:08.101 	
      0 	true 	javascript.0 	2020-06-04 19:43:18.896 	
      1000 	true 	javascript.0 	2020-06-04 19:43:29.896 	
      0 	true 	javascript.0 	2020-06-04 19:43:58.999 	
      1000 	true 	javascript.0 	2020-06-04 19:44:19.894 	
      0 	true 	javascript.0 	2020-06-04 19:44:49.896 	
      1000 	true 	javascript.0 	2020-06-04 19:45:01.027 	
      0 	true 	javascript.0 	2020-06-04 19:48:46.894 	
      1000 	true 	javascript.0 	2020-06-04 19:48:57.895
      
      paul53P 1 Antwort Letzte Antwort
      0
      • A Aiouh

        @paul53
        Die Anzeige des Tankvolumens klappt nun gut. Nachdem es heute endlich mal wieder etwas Regen gab, habe ich festgestellt, dass das mit der Durchflussmessung noch nicht klappt.
        Die kleinste Volumen Auflösung die ich systembedingt hinbekomme (+/-10mV) sind 29 Liter, was für mich völlig OK ist.
        Die Durchflussmenge pendelt jedoch zwischen 0 und 1000, offenbar so wie das letzte digit springt.
        Hab ich da noch was übersehen?

        Spannung vom Geber (408 =4,08V)
        408 	true 	modbus.2 	2020-06-04 19:42:06.895 	
        409 	true 	modbus.2 	2020-06-04 19:42:17.889 	
        408 	true 	modbus.2 	2020-06-04 19:42:56.992 	
        409 	true 	modbus.2 	2020-06-04 19:43:08.092 	
        408 	true 	modbus.2 	2020-06-04 19:43:18.889 	
        409 	true 	modbus.2 	2020-06-04 19:43:29.889 	
        408 	true 	modbus.2 	2020-06-04 19:43:58.990 	
        409 	true 	modbus.2 	2020-06-04 19:44:19.888 	
        408 	true 	modbus.2 	2020-06-04 19:44:49.889 	
        409 	true 	modbus.2 	2020-06-04 19:45:00.955 	
        408 	true 	modbus.2 	2020-06-04 19:48:46.886 	
        409 	true 	modbus.2 	2020-06-04 19:48:57.886
        
        Volumen in Liter
        8055 	true 	javascript.0 	2020-06-04 19:42:06.905 	
        8084 	true 	javascript.0 	2020-06-04 19:42:17.897 	
        8055 	true 	javascript.0 	2020-06-04 19:42:57.005 	
        8084 	true 	javascript.0 	2020-06-04 19:43:08.101 	
        8055 	true 	javascript.0 	2020-06-04 19:43:18.896 	
        8084 	true 	javascript.0 	2020-06-04 19:43:29.896 	
        8055 	true 	javascript.0 	2020-06-04 19:43:58.999 	
        8084 	true 	javascript.0 	2020-06-04 19:44:19.894 	
        8055 	true 	javascript.0 	2020-06-04 19:44:49.896 	
        8084 	true 	javascript.0 	2020-06-04 19:45:01.026 	
        8055 	true 	javascript.0 	2020-06-04 19:48:46.894 	
        8084 	true 	javascript.0 	2020-06-04 19:48:57.894
        
        
        Durchfluss 
        0 	true 	javascript.0 	2020-06-04 19:42:06.905 	
        1000 	true 	javascript.0 	2020-06-04 19:42:17.897 	
        0 	true 	javascript.0 	2020-06-04 19:42:57.005 	
        1000 	true 	javascript.0 	2020-06-04 19:43:08.101 	
        0 	true 	javascript.0 	2020-06-04 19:43:18.896 	
        1000 	true 	javascript.0 	2020-06-04 19:43:29.896 	
        0 	true 	javascript.0 	2020-06-04 19:43:58.999 	
        1000 	true 	javascript.0 	2020-06-04 19:44:19.894 	
        0 	true 	javascript.0 	2020-06-04 19:44:49.896 	
        1000 	true 	javascript.0 	2020-06-04 19:45:01.027 	
        0 	true 	javascript.0 	2020-06-04 19:48:46.894 	
        1000 	true 	javascript.0 	2020-06-04 19:48:57.895
        
        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von paul53
        #24

        @Aiouh
        Der Wert schwankt offenbar, wobei er auch kleiner wird. Ergänze mal um eine Abfrage

            let V = h2V(h);
            if(V > lastV) {
                let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
                lastV = V;
                lc = dp.state.lc;
                setState(idFluss, Math.round(fluss * 100) / 100, true); // 2 Nachkommastellen
            }
        

        und vor dem Trigger:

        var lc = getState(idSpannung).lc;
        

        Die 10 Minuten, nach denen der Zufluss auf 0 gesetzt wird, könnten zu kurz sein.

        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

        A 1 Antwort Letzte Antwort
        0
        • paul53P paul53

          @Aiouh
          Der Wert schwankt offenbar, wobei er auch kleiner wird. Ergänze mal um eine Abfrage

              let V = h2V(h);
              if(V > lastV) {
                  let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
                  lastV = V;
                  lc = dp.state.lc;
                  setState(idFluss, Math.round(fluss * 100) / 100, true); // 2 Nachkommastellen
              }
          

          und vor dem Trigger:

          var lc = getState(idSpannung).lc;
          

          Die 10 Minuten, nach denen der Zufluss auf 0 gesetzt wird, könnten zu kurz sein.

          A Online
          A Online
          Aiouh
          schrieb am zuletzt editiert von
          #25

          @paul53
          Nachdem es wieder angefangen hat zu regnen tut sich was, das sieht gut aus.
          e144e44f-53c2-4703-a445-d14f509d87ac-grafik.png

          Was mir noch aufgefallen ist: Der letzte Durchflusswert nach Ende Zufluss scheint jetzt so lange stehen zu bleiben bis erneut Wasser zufliesst. Der Wert geht nicht auf Null.
          Bespiel:
          Den letzten Zufluss hatte ich am 5.6. um 14:50 Uhr, der Stand von 109.91 blieb bis heute Nacht 00:06 Uhr stehen, als es zum ersten mal wieder geregnet hat.

          109.91 	true 	influxdb.0 	2020-06-05 14:50:13.837 	
          0.77 	true 	javascript.0 	2020-06-07 00:06:39.974
          

          Hab ich vielleicht was mit dem Code verbaselt? Sieht jetzt so aus.

          const idSpannung = 'modbus.2.holdingRegisters.9_Zisterne_Füllhöhe_U';
          const idHoehe = 'javascript.0.Eigene_Datenpunkte.Zisterne_Füllhöhe';
          const idVol = 'javascript.0.Eigene_Datenpunkte.Zisterne_Volumen';
          const idFluss = 'javascript.0.Eigene_Datenpunkte.Zisterne_Zufluss';
          
          const L = 49.8; // Länge in dm
          const R = 8; // Radius in dm
           
          function u2h(U) {
             let h = (U-120) /24; // a und b durch konstante Werte ersetzen
             setState(idHoehe, Math.round(h * 100) / 10, true); // in cm mit 1 Nachkommastelle
             return h; // in dm
          }
          
          function h2V(h) {
             let V = L * (R * R * Math.acos(1 - h / R) - (R - h) * Math.sqrt(h * (2 * R - h)));
             setState(idVol, Math.round(V), true);
             return V; // in l
          }
          
          var h = u2h(getState(idSpannung).val);
          var lastV = h2V(h);
          var timer = null;
          var lc = getState(idSpannung).lc; 
          
          on(idSpannung, function(dp) {
              h = u2h(dp.state.val);
              let V = h2V(h);
              if(V > lastV) {
                let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
              lastV = V;
              lc = dp.state.lc;
              setState(idFluss, Math.round(fluss * 100) / 100, true); // 2 Nachkommastellen
              }
          });
          
          paul53P 1 Antwort Letzte Antwort
          0
          • A Aiouh

            @paul53
            Nachdem es wieder angefangen hat zu regnen tut sich was, das sieht gut aus.
            e144e44f-53c2-4703-a445-d14f509d87ac-grafik.png

            Was mir noch aufgefallen ist: Der letzte Durchflusswert nach Ende Zufluss scheint jetzt so lange stehen zu bleiben bis erneut Wasser zufliesst. Der Wert geht nicht auf Null.
            Bespiel:
            Den letzten Zufluss hatte ich am 5.6. um 14:50 Uhr, der Stand von 109.91 blieb bis heute Nacht 00:06 Uhr stehen, als es zum ersten mal wieder geregnet hat.

            109.91 	true 	influxdb.0 	2020-06-05 14:50:13.837 	
            0.77 	true 	javascript.0 	2020-06-07 00:06:39.974
            

            Hab ich vielleicht was mit dem Code verbaselt? Sieht jetzt so aus.

            const idSpannung = 'modbus.2.holdingRegisters.9_Zisterne_Füllhöhe_U';
            const idHoehe = 'javascript.0.Eigene_Datenpunkte.Zisterne_Füllhöhe';
            const idVol = 'javascript.0.Eigene_Datenpunkte.Zisterne_Volumen';
            const idFluss = 'javascript.0.Eigene_Datenpunkte.Zisterne_Zufluss';
            
            const L = 49.8; // Länge in dm
            const R = 8; // Radius in dm
             
            function u2h(U) {
               let h = (U-120) /24; // a und b durch konstante Werte ersetzen
               setState(idHoehe, Math.round(h * 100) / 10, true); // in cm mit 1 Nachkommastelle
               return h; // in dm
            }
            
            function h2V(h) {
               let V = L * (R * R * Math.acos(1 - h / R) - (R - h) * Math.sqrt(h * (2 * R - h)));
               setState(idVol, Math.round(V), true);
               return V; // in l
            }
            
            var h = u2h(getState(idSpannung).val);
            var lastV = h2V(h);
            var timer = null;
            var lc = getState(idSpannung).lc; 
            
            on(idSpannung, function(dp) {
                h = u2h(dp.state.val);
                let V = h2V(h);
                if(V > lastV) {
                  let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
                lastV = V;
                lc = dp.state.lc;
                setState(idFluss, Math.round(fluss * 100) / 100, true); // 2 Nachkommastellen
                }
            });
            
            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von paul53
            #26

            @Aiouh sagte:

            Sieht jetzt so aus.

            Es fehlt der letzte Teil mit dem Timeout:

            on(idSpannung, function(dp) {
                h = u2h(dp.state.val);
                let V = h2V(h);
                if(V > lastV) {
                   let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
                   lastV = V;
                   lc = dp.state.lc;
                   setState(idFluss, Math.round(fluss), true); 
                   if(timer) clearTimeout(timer);
                   timer = setTimeout(function() {
                      setState(idFluss, 0, true);
                      timer = null;
                   }, 1800000); // 30 Minuten
                }
            });
            

            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

            A 1 Antwort Letzte Antwort
            0
            • paul53P paul53

              @Aiouh sagte:

              Sieht jetzt so aus.

              Es fehlt der letzte Teil mit dem Timeout:

              on(idSpannung, function(dp) {
                  h = u2h(dp.state.val);
                  let V = h2V(h);
                  if(V > lastV) {
                     let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
                     lastV = V;
                     lc = dp.state.lc;
                     setState(idFluss, Math.round(fluss), true); 
                     if(timer) clearTimeout(timer);
                     timer = setTimeout(function() {
                        setState(idFluss, 0, true);
                        timer = null;
                     }, 1800000); // 30 Minuten
                  }
              });
              
              A Online
              A Online
              Aiouh
              schrieb am zuletzt editiert von
              #27

              @paul53
              Hallo, jetzt scheint alles zu klappen.
              Vielen Dank für Deine Hilfe UND Geduld :blush:

              A 1 Antwort Letzte Antwort
              0
              • A Aiouh

                @paul53
                Hallo, jetzt scheint alles zu klappen.
                Vielen Dank für Deine Hilfe UND Geduld :blush:

                A Online
                A Online
                Aiouh
                schrieb am zuletzt editiert von Aiouh
                #28

                @paul53
                Hallo, ich hab da noch eine Bitte :grin: ...
                Mein liegender Tank hat zwar nur einen Durchmesser von 160cm, durch das Domschacht Volumen und das Entnahmerohr erhöht sich jedoch die gemessene maximale Höhe des Wassers, wodurch das angezeigte Tankvolumen daneben liegt. (Der Überlauf liegt höher als der Domschacht)
                Wie bekomme ich das hin, dass jede Höhe über "2 x R" einfach ignoriert wird und darüber einfach das maximale Volumen angezeigt wird ? Falls es keine Mühe macht wäre ich dankbar wenn das im gleichen Skript eingebaut wäre, ansonsten bastle ich mal mit Blockly an dem Wert Füllhöhe_U herum.

                paul53P 1 Antwort Letzte Antwort
                0
                • A Aiouh

                  @paul53
                  Hallo, ich hab da noch eine Bitte :grin: ...
                  Mein liegender Tank hat zwar nur einen Durchmesser von 160cm, durch das Domschacht Volumen und das Entnahmerohr erhöht sich jedoch die gemessene maximale Höhe des Wassers, wodurch das angezeigte Tankvolumen daneben liegt. (Der Überlauf liegt höher als der Domschacht)
                  Wie bekomme ich das hin, dass jede Höhe über "2 x R" einfach ignoriert wird und darüber einfach das maximale Volumen angezeigt wird ? Falls es keine Mühe macht wäre ich dankbar wenn das im gleichen Skript eingebaut wäre, ansonsten bastle ich mal mit Blockly an dem Wert Füllhöhe_U herum.

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

                  @Aiouh sagte in:

                  jede Höhe über "2 x R" einfach ignoriert wird

                  function u2h(U) {
                     let h = (U-120) /24;
                     if(h > 2 * R) h = 2 * R;
                     setState(idHoehe, Math.round(h * 100) / 10, true); // in cm mit 1 Nachkommastelle
                     return h; // in dm
                  }
                  

                  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

                  A 2 Antworten Letzte Antwort
                  0
                  • paul53P paul53

                    @Aiouh sagte in:

                    jede Höhe über "2 x R" einfach ignoriert wird

                    function u2h(U) {
                       let h = (U-120) /24;
                       if(h > 2 * R) h = 2 * R;
                       setState(idHoehe, Math.round(h * 100) / 10, true); // in cm mit 1 Nachkommastelle
                       return h; // in dm
                    }
                    
                    A Online
                    A Online
                    Aiouh
                    schrieb am zuletzt editiert von
                    #30

                    @paul53 :+1:

                    1 Antwort Letzte Antwort
                    0
                    • paul53P paul53

                      @Aiouh sagte in:

                      jede Höhe über "2 x R" einfach ignoriert wird

                      function u2h(U) {
                         let h = (U-120) /24;
                         if(h > 2 * R) h = 2 * R;
                         setState(idHoehe, Math.round(h * 100) / 10, true); // in cm mit 1 Nachkommastelle
                         return h; // in dm
                      }
                      
                      A Online
                      A Online
                      Aiouh
                      schrieb am zuletzt editiert von
                      #31

                      @paul53
                      Das Ganze läuft mittlerweile ganz gut, mit einer Ausnahme...
                      Ich bekomme immer wieder mal falsche Werte, irgendwo zwischen 0 bis ca 500 unterhalb des aktuellen Wertes. Bisher lösche ich die händisch aus der InfluxDB.
                      Würde meine zusätzliche Zeile " if ((V < (lastV - 500)) V = lastV; " funktionieren?
                      Ich möchte damit einfach Werte ignorieren die plötzlich mindestens 500 l niedriger liegen.

                      function u2h(U) {
                         let h = (U-120) /24;
                         if(h > 2 * R) h = 2 * R;
                         if ((V < (lastV - 500)) V = lastV;
                         setState(idHoehe, Math.round(h * 100) / 10, true); // in cm mit 1 Nachkommastelle
                         return h; // in dm
                      }
                      
                      
                      paul53P 1 Antwort Letzte Antwort
                      0
                      • A Aiouh

                        @paul53
                        Das Ganze läuft mittlerweile ganz gut, mit einer Ausnahme...
                        Ich bekomme immer wieder mal falsche Werte, irgendwo zwischen 0 bis ca 500 unterhalb des aktuellen Wertes. Bisher lösche ich die händisch aus der InfluxDB.
                        Würde meine zusätzliche Zeile " if ((V < (lastV - 500)) V = lastV; " funktionieren?
                        Ich möchte damit einfach Werte ignorieren die plötzlich mindestens 500 l niedriger liegen.

                        function u2h(U) {
                           let h = (U-120) /24;
                           if(h > 2 * R) h = 2 * R;
                           if ((V < (lastV - 500)) V = lastV;
                           setState(idHoehe, Math.round(h * 100) / 10, true); // in cm mit 1 Nachkommastelle
                           return h; // in dm
                        }
                        
                        
                        paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von paul53
                        #32

                        @Aiouh sagte:

                        Würde meine zusätzliche Zeile " if ((V < (lastV - 500)) V = lastV; " funktionieren?

                        Nein, das ist die falsche Stelle. Wird auch die Höhe aufgezeichnet ?

                        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

                        A 1 Antwort Letzte Antwort
                        0
                        • paul53P paul53

                          @Aiouh sagte:

                          Würde meine zusätzliche Zeile " if ((V < (lastV - 500)) V = lastV; " funktionieren?

                          Nein, das ist die falsche Stelle. Wird auch die Höhe aufgezeichnet ?

                          A Online
                          A Online
                          Aiouh
                          schrieb am zuletzt editiert von
                          #33

                          @paul53 Ja, die Höhe wird auch aufgezeichnet

                          paul53P 1 Antwort Letzte Antwort
                          0
                          • A Aiouh

                            @paul53 Ja, die Höhe wird auch aufgezeichnet

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

                            @Aiouh sagte:

                            Ja, die Höhe wird auch aufgezeichnet

                            Da die Höhe zuerst ermittel wird, müsste man dort schon eine entsprechende Beschränkung einbauen. Das neu berechnete Volumen liegt zu dem Zeitpunkt noch nicht vor.
                            Einfacher wäre eine Auswertung der Spannungsänderung.

                            on(idSpannung, function(dp) {
                                if(dp.state.val > dp.oldState.val - 20) {
                            

                            Das setzt voraus, dass die starke Abweichung jeweils nur bei einem Messwert auftritt und danach der Messwert wieder stimmt.

                            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

                            A 2 Antworten Letzte Antwort
                            0
                            • paul53P paul53

                              @Aiouh sagte:

                              Ja, die Höhe wird auch aufgezeichnet

                              Da die Höhe zuerst ermittel wird, müsste man dort schon eine entsprechende Beschränkung einbauen. Das neu berechnete Volumen liegt zu dem Zeitpunkt noch nicht vor.
                              Einfacher wäre eine Auswertung der Spannungsänderung.

                              on(idSpannung, function(dp) {
                                  if(dp.state.val > dp.oldState.val - 20) {
                              

                              Das setzt voraus, dass die starke Abweichung jeweils nur bei einem Messwert auftritt und danach der Messwert wieder stimmt.

                              A Online
                              A Online
                              Aiouh
                              schrieb am zuletzt editiert von
                              #35

                              @paul53 Danke, das werde ich mal versuchen. Bisher war immer nur ein Messwert falsch, dann kamen wieder viele korrekte.

                              1 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @Aiouh sagte:

                                Ja, die Höhe wird auch aufgezeichnet

                                Da die Höhe zuerst ermittel wird, müsste man dort schon eine entsprechende Beschränkung einbauen. Das neu berechnete Volumen liegt zu dem Zeitpunkt noch nicht vor.
                                Einfacher wäre eine Auswertung der Spannungsänderung.

                                on(idSpannung, function(dp) {
                                    if(dp.state.val > dp.oldState.val - 20) {
                                

                                Das setzt voraus, dass die starke Abweichung jeweils nur bei einem Messwert auftritt und danach der Messwert wieder stimmt.

                                A Online
                                A Online
                                Aiouh
                                schrieb am zuletzt editiert von Aiouh
                                #36

                                @paul53 Hallo, ich habe mich nochmal hingesetzt und in der Datenbank nachgeschaut.
                                Die Grafik hatte zwar Zwischenwerte angezeigt, lag wohl am Zoom factor, in der Datenbank waren die falschen Werte immer "0". Nachdem ich händisch alle Nullwerte entfernt habe ist die Grafik wieder perfekt.
                                Folgende Überlegung:
                                Wenn die Spannung unter 120 liegt, das ist quasi die Null-Höhe, soll einfach der letzte Spannungswert verwendet werden.
                                Würde das mit dem Syntax "if(V <120) V = lastV;" klappen?

                                on(idSpannung, function(dp) {
                                    h = u2h(dp.state.val);
                                    let V = h2V(h);
                                    if(V <120) V = lastV;
                                    if(V > lastV) {
                                       let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
                                       lastV = V;
                                       lc = dp.state.lc;
                                
                                paul53P 1 Antwort Letzte Antwort
                                0
                                • A Aiouh

                                  @paul53 Hallo, ich habe mich nochmal hingesetzt und in der Datenbank nachgeschaut.
                                  Die Grafik hatte zwar Zwischenwerte angezeigt, lag wohl am Zoom factor, in der Datenbank waren die falschen Werte immer "0". Nachdem ich händisch alle Nullwerte entfernt habe ist die Grafik wieder perfekt.
                                  Folgende Überlegung:
                                  Wenn die Spannung unter 120 liegt, das ist quasi die Null-Höhe, soll einfach der letzte Spannungswert verwendet werden.
                                  Würde das mit dem Syntax "if(V <120) V = lastV;" klappen?

                                  on(idSpannung, function(dp) {
                                      h = u2h(dp.state.val);
                                      let V = h2V(h);
                                      if(V <120) V = lastV;
                                      if(V > lastV) {
                                         let fluss = 3600000 * (V - lastV) / (dp.state.lc - lc); // l/h
                                         lastV = V;
                                         lc = dp.state.lc;
                                  
                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  schrieb am zuletzt editiert von
                                  #37

                                  @Aiouh sagte:

                                  Würde das mit dem Syntax "if(V <120) V = lastV;" klappen?

                                  Teste es.

                                  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

                                  A 2 Antworten Letzte Antwort
                                  0
                                  • paul53P paul53

                                    @Aiouh sagte:

                                    Würde das mit dem Syntax "if(V <120) V = lastV;" klappen?

                                    Teste es.

                                    A Online
                                    A Online
                                    Aiouh
                                    schrieb am zuletzt editiert von
                                    #38

                                    @paul53 hmmm, bis jetzt bekomme ich zumindest mal normale Werte, habe soweit also nichts "kaputt gemacht". Bin gespannt wie es die nächsten Tage aussieht

                                    1 Antwort Letzte Antwort
                                    0
                                    • paul53P paul53

                                      @Aiouh sagte:

                                      Würde das mit dem Syntax "if(V <120) V = lastV;" klappen?

                                      Teste es.

                                      A Online
                                      A Online
                                      Aiouh
                                      schrieb am zuletzt editiert von
                                      #39

                                      @paul53 Funktioniert mit einer Ausnahme. Jede Nacht um 0:00Uhr bekomme ich "0".
                                      1cd51175-f5a2-4f44-8744-9b2f724a6900-image.png

                                      paul53P 1 Antwort Letzte Antwort
                                      0
                                      • A Aiouh

                                        @paul53 Funktioniert mit einer Ausnahme. Jede Nacht um 0:00Uhr bekomme ich "0".
                                        1cd51175-f5a2-4f44-8744-9b2f724a6900-image.png

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

                                        @Aiouh sagte:

                                        Jede Nacht um 0:00Uhr bekomme ich "0".

                                        Da es im Script keinen Bezug zur Uhrzeit gibt, musst Du wohl die Ursache an der Quelle suchen.

                                        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

                                        A 1 Antwort Letzte Antwort
                                        0
                                        • paul53P paul53

                                          @Aiouh sagte:

                                          Jede Nacht um 0:00Uhr bekomme ich "0".

                                          Da es im Script keinen Bezug zur Uhrzeit gibt, musst Du wohl die Ursache an der Quelle suchen.

                                          A Online
                                          A Online
                                          Aiouh
                                          schrieb am zuletzt editiert von
                                          #41

                                          @paul53 korrekt, werde auch nach der Ursache suchen. Bin aber schon mal happy dass "meine Zeile" zu funktionieren scheint. :grinning:

                                          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

                                          748

                                          Online

                                          32.5k

                                          Benutzer

                                          81.8k

                                          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