Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Zulauf einer Zisterne in Liter/h berechnen

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    17
    1
    503

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

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

Zulauf einer Zisterne in Liter/h berechnen

Scheduled Pinned Locked Moved Skripten / Logik
blocklyjavascript
52 Posts 8 Posters 7.3k Views 8 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • paul53P paul53

    @Aiouh
    Vorschlag:

    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 = 32; // Länge in dm
    const R = 10; // Radius in dm
    
    function u2h(U) {
       let h = a + b * U; // a und b durch konstante Zahlenwerte 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;
    
    on(idSpannung, function(dp) {
        h = u2h(dp.state.val);
        let V = h2V(h);
        let fluss = 3600000 * (V - lastV) / (dp.state.lc - dp.oldState.lc); // l/h
        lastV = V;
        setState(idFluss, Math.round(fluss * 100) / 100, true); // 2 Nachkommastellen
        if(timer) clearTimeout(timer);
        timer = setTimeout(function() {
           setState(idFluss, 0, true);
           timer = null;
        }, 600000); // 10 Minuten
    });
    
    A Offline
    A Offline
    Aiouh
    wrote on last edited by Aiouh
    #20

    @paul53
    Es tut sich was :). Alle Datenpunkte werden gefüllt, nur komme ich mit der Funktion u2h noch nicht klar. Wenn ich das mit meinem gefährlichen Halbwissen hier richtig verstehe berechnest Du die Höhe mit h = a + b * U wobei "U" für die Spannung steht !?
    Ich berechne die Höhe (in cm) mit h = (U-120) / 2.4
    Wenn ich meine Formel einsetze bekomme ich die korrkete Höhe, aber das Volumen nicht.
    Vermutlich weil ich nun cm und nicht dm bekomme.

    paul53P 1 Reply Last reply
    0
    • A Aiouh

      @paul53
      Es tut sich was :). Alle Datenpunkte werden gefüllt, nur komme ich mit der Funktion u2h noch nicht klar. Wenn ich das mit meinem gefährlichen Halbwissen hier richtig verstehe berechnest Du die Höhe mit h = a + b * U wobei "U" für die Spannung steht !?
      Ich berechne die Höhe (in cm) mit h = (U-120) / 2.4
      Wenn ich meine Formel einsetze bekomme ich die korrkete Höhe, aber das Volumen nicht.
      Vermutlich weil ich nun cm und nicht dm bekomme.

      paul53P Offline
      paul53P Offline
      paul53
      wrote on last edited by paul53
      #21

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

      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 Reply Last reply
      0
      • 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 Offline
        A Offline
        Aiouh
        wrote on last edited by Aiouh
        #22

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

        A 1 Reply Last reply
        0
        • A Aiouh

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

          A Offline
          A Offline
          Aiouh
          wrote on last edited by
          #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 Reply Last reply
          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
            wrote on last edited by 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 Reply Last reply
            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 Offline
              A Offline
              Aiouh
              wrote on last edited by
              #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 Reply Last reply
              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
                wrote on last edited by 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 Reply Last reply
                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 Offline
                  A Offline
                  Aiouh
                  wrote on last edited by
                  #27

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

                  A 1 Reply Last reply
                  0
                  • A Aiouh

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

                    A Offline
                    A Offline
                    Aiouh
                    wrote on last edited by 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 Reply Last reply
                    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
                      wrote on last edited by
                      #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 Replies Last reply
                      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 Offline
                        A Offline
                        Aiouh
                        wrote on last edited by
                        #30

                        @paul53 :+1:

                        1 Reply Last reply
                        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 Offline
                          A Offline
                          Aiouh
                          wrote on last edited by
                          #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 Reply Last reply
                          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
                            wrote on last edited by 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 Reply Last reply
                            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 Offline
                              A Offline
                              Aiouh
                              wrote on last edited by
                              #33

                              @paul53 Ja, die Höhe wird auch aufgezeichnet

                              paul53P 1 Reply Last reply
                              0
                              • A Aiouh

                                @paul53 Ja, die Höhe wird auch aufgezeichnet

                                paul53P Offline
                                paul53P Offline
                                paul53
                                wrote on last edited by 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 Replies Last reply
                                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 Offline
                                  A Offline
                                  Aiouh
                                  wrote on last edited by
                                  #35

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

                                  1 Reply Last reply
                                  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 Offline
                                    A Offline
                                    Aiouh
                                    wrote on last edited by 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 Reply Last reply
                                    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
                                      wrote on last edited by
                                      #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 Replies Last reply
                                      0
                                      • paul53P paul53

                                        @Aiouh sagte:

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

                                        Teste es.

                                        A Offline
                                        A Offline
                                        Aiouh
                                        wrote on last edited by
                                        #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 Reply Last reply
                                        0
                                        • paul53P paul53

                                          @Aiouh sagte:

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

                                          Teste es.

                                          A Offline
                                          A Offline
                                          Aiouh
                                          wrote on last edited by
                                          #39

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

                                          paul53P 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          648

                                          Online

                                          32.7k

                                          Users

                                          82.5k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe