Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Praktische Anwendungen (Showcase)
    4. Füllstandsmessung per Pegelsonde.

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Füllstandsmessung per Pegelsonde.

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

      Ein Freund von mir will sich die andere Formel mal anschauen, ich kümmer mich jetzt erst mal um die Hardware.
      Das wird meine erste selbst gelötete Platine. 🍻

      1 Reply Last reply Reply Quote 1
      • K
        klassisch Most Active last edited by klassisch

        Einen liegenden Tank habe ich auch, siehe https://homematic-forum.de/forum/viewtopic.php?p=328133&sid=c9889fdb7499abc6e015d80692f97910#p328133 .
        Und die Formel hatte ich schon lange zuvor, als ich noch mit dem Maßstab arbeitete, hergeleitet und auch in xls implementiert. Die Herleitung war damals noch schneller als Suchen. Im obigen Post (bzw. Folgepost) ist das auch kurz beschrieben:

        "Die Umrechnung von Füllstandshöhe auf Volumen hängt von der Tankform ab. Im meinem Fall eines liegenden Erdtanks kann aus der Füllhöhe der Füllquerschnitt berechnet werden. Stichwort Fläche des Kreissegments, s. https://de.wikipedia.org/wiki/Kreissegment hier die vierte Formel, Fläche in Abhängigkeit vom Druchmesser und der Füllhöhe. Die ESP8266 können den arccos rechnen, die Resultate stimmen mit einer XLS-Referenzberechnung überein. Nach Multiplikation mit der lichten Tanklänge erhält man das Füllvolumen ohne Berücksichtigung der Klöpperböden."

        Wie beschrieben verwende ich die vierte Formel mit dem arccos(h). Die enthält alles, was wir kennen: Radius (bzw. Durchmesser) und Höhe vom Grund zum Flüssigkeitsspiegel (= Sehne)
        Die Abbildung in Wikipedia einfach auf den Kopf stellen, dann wird es klar was das mit dem Tank zu tun hat.
        https://de.wikipedia.org/wiki/Kreissegment#/media/Datei:Circular_segment.svg

        Im ESP8266 - Arduino-Code sieht das bei mir dann so aus:

        void calculateInventory() {
          currentLevel =  deltaPressure / cfg.fluidDensity + cfg.levelOffset;
          if (currentLevel > maxLevel) {
            currentLevel = maxLevel;
            if (currentLevel > maxLevel * 1.3) measError = 1; return;
          } // Meas error -> stop, no further calculation
          else measError = 0;
          // calculation for a cylindrical tank, horizontally oriented, Kloepperboden not regarded
          currentInventory = (pow(cfg.tankRadiusReal, 2) * acos(1 - currentLevel / cfg.tankRadiusReal) - sqrt( 2 * cfg.tankRadiusReal * currentLevel - pow(currentLevel, 2)) * (cfg.tankRadiusReal - currentLevel)) / 1000 * cfg.tankLengthReal;
          quantityToOrder = cfg.maxCapacity_90percent - currentInventory;
        } // end calculate inventory
        

        Also die Formel stumpf und ohne Optimierung reingeklopft. Wird bei mir auch nur einmal pro Nacht gemessen und gerechnet.
        Alle Variablen, die "cfg." davor haben, sind Teil eines Konfigurations-Structs, welches ich im EEPROM halte und persistent verstellen kann.

        Dabei bedeuten:

        • quantityToOrder: Zu bestellende Ölmenge. Dabei ist in meinem Fall (Erdtank) zu beachten, daß der Tank nicht mehr als 90% befüllt werden darf. Das regelt die eingebaute (thermische) Füllstandssonde, die an das Tankfahrzeug angeschlossen wird.
        • tankRadiusReal=79.00 - lichter Radius des Tanks in cm
        • tankLengthReal=502.75 - lichte Länge des Tanks in cm
        • maxCapacity_90percent=9472.00 - Max erlabte Fuellmenge bis zur 90Prozent Abschaltung
        • fluidDensity=0.86 - Dichte des Mediums, Heizoel =0,86
        • levelOffset=9.80 - Level-Offet in cm. >0 wenn Perlsonde höher als realer Tankgrund. Bei Euch wäre das die Höhe des Drucksensors über Grund

        Wie schon andernorts hier im Thread erwähnt: Die Sache schnurrt bei mir jetzt schon >3 Jahre und bei der letzten Füllung wurde der Tankwagen durch die eingebaute Abschaltsonde exakt bei der bestellten Füllmenge angehalten. Auf den Liter genau bei einem 10.000 Liter Tank. War sicher auch Zufall dabei (Der Tankwagen hätte auch einen Tag früher oder später kommen können), aber die Genauigkeit ist sicher ausreichend. Trotz des in meinem Fall "windigen" (=pneumatischen) Verfahrens.

        B 1 Reply Last reply Reply Quote 0
        • B
          BastelKlaus @klassisch last edited by

          @klassisch
          Danke für deinen Hinweis.
          Hättest du die letzten Beiträge genauer gelesen, geht es mir eher drum die Berechnung in EspEasy umzusetzen oder in IoBroker.
          Deine Formel ist mir, zugegeben durch Wiki bekannt und auch umsetzbar.
          Für EspEasy wäre es nötig, die Berechnung mit einer Polynomial Funktion 5. Grades zu machen, da hier acos nicht verfügbar ist.
          Alles nicht so Wild.

          Frohe Weihnachten.

          K 1 Reply Last reply Reply Quote 0
          • K
            klassisch Most Active @BastelKlaus last edited by

            @BastelKlaus Die Beiträge hatte ich gelese, aber EspEasy ist mir nicht geläufig. Als mir das zur Kenntnis kam, war ich schon weitgehend durch.
            Es wurde ja auch überlegt, da Ganze in Arduino für ESP8266 umzusetzen - zumindest hatte ich das so verstanden.

            Zur Reihenentwicklung von arccos findet sich hier etwas https://mathepedia.de/Arkussinus_und_Arkuskosinus.html . Die Fehler bei 5. Grad und Argumenten im Intervall [-1, 1] habe ich nicht allerdings noch nicht gerechnet.

            1 Reply Last reply Reply Quote 0
            • Eisbaeeer
              Eisbaeeer Developer last edited by

              Seit gestern ist die Version 1.4 auf Github verfügbar. Ich habe ein Array eingefügt, welches die Meßdaten glättet und beruhigt.
              Grüße Eisbaeeer

              1 Reply Last reply Reply Quote 0
              • B
                Beowolf last edited by

                Hallo Eisbaeeer,

                habe die neue Version ausprobiert.

                Läuft ganz gut, aber ich mußte die Zeile 311 von

                 percent = fuel * 0.132;
                

                auf

                percent = (fuel * dichte) / 10;
                

                Danach zeigte das LCD Display die richtige Prozentzahl an.

                Grüße
                Manfred

                Eisbaeeer 1 Reply Last reply Reply Quote 0
                • Eisbaeeer
                  Eisbaeeer Developer @Beowolf last edited by

                  @Beowolf uups. Kann sein, dass ich da noch nen Bug drin hab. War gestern auch ein Schnellschuß mit andauernden Störungen von extern 😉

                  1 Reply Last reply Reply Quote 0
                  • B
                    Beowolf last edited by

                    Was mich auch wundert, ist aber nicht so schlimm, ich habe jetzt nach ca. 5 Minuten eine "Uptime von 66 Tagen und 16 Minuten."

                    Eisbaeeer 1 Reply Last reply Reply Quote 0
                    • Eisbaeeer
                      Eisbaeeer Developer @Beowolf last edited by

                      @Beowolf Ja, da scheint auch noch ein Bug drin zu sein. Die Anzeige passt das noch nicht. Eventuell hab ich das noch eine falsche variablen Definition.

                      1 Reply Last reply Reply Quote 0
                      • L
                        ltathome last edited by

                        Hallöchen - lese schon ne ganze Weile mit - die Bautieile sind im Zulauf - mir fehlt noch die Sonde und das Ethernet-Shield. Ich habe mal versucht den Nano zu flashen und bekomme das hier:

                        avrdude: Version 6.3-20190619
                                 Copyright (c) 2000-2005 Brian Dean, http://www.bdmicro.com/
                                 Copyright (c) 2007-2014 Joerg Wunsch
                        
                                 System wide configuration file is "/home/lutz/.arduino15/packages/arduino/tools/avrdude/6.3.0-arduino17/etc/avrdude.conf"
                                 User configuration file is "/home/lutz/.avrduderc"
                                 User configuration file does not exist or is not a regular file, skipping
                        
                                 Using Port                    : /dev/ttyUSB0
                                 Using Programmer              : arduino
                                 Overriding Baud Rate          : 57600
                                 AVR Part                      : ATmega328P
                                 Chip Erase delay              : 9000 us
                                 PAGEL                         : PD7
                                 BS2                           : PC2
                                 RESET disposition             : dedicated
                                 RETRY pulse                   : SCK
                                 serial program mode           : yes
                                 parallel program mode         : yes
                                 Timeout                       : 200
                                 StabDelay                     : 100
                                 CmdexeDelay                   : 25
                                 SyncLoops                     : 32
                                 ByteDelay                     : 0
                                 PollIndex                     : 3
                                 PollValue                     : 0x53
                                 Memory Detail                 :
                        
                                                          Block Poll               Page                       Polled
                                   Memory Type Mode Delay Size  Indx Paged  Size   Size #Pages MinW  MaxW   ReadBack
                                   ----------- ---- ----- ----- ---- ------ ------ ---- ------ ----- ----- ---------
                                   eeprom        65    20     4    0 no       1024    4      0  3600  3600 0xff 0xff
                                   flash         65     6   128    0 yes     32768  128    256  4500  4500 0xff 0xff
                                   lfuse          0     0     0    0 no          1    0      0  4500  4500 0x00 0x00
                                   hfuse          0     0     0    0 no          1    0      0  4500  4500 0x00 0x00
                                   efuse          0     0     0    0 no          1    0      0  4500  4500 0x00 0x00
                                   lock           0     0     0    0 no          1    0      0  4500  4500 0x00 0x00
                                   calibration    0     0     0    0 no          1    0      0     0     0 0x00 0x00
                                   signature      0     0     0    0 no          3    0      0     0     0 0x00 0x00
                        
                                 Programmer Type : Arduino
                                 Description     : Arduino
                                 Hardware Version: 2
                                 Firmware Version: 1.16
                                 Vtarget         : 0.0 V
                                 Varef           : 0.0 V
                                 Oscillator      : Off
                                 SCK period      : 0.1 us
                        
                        avrdude: AVR device initialized and ready to accept instructions
                        
                        Reading | ################################################## | 100% 0.00s
                        
                        avrdude: Device signature = 0x1e950f (probably m328p)
                        avrdude: reading input file "/tmp/arduino_build_243251/Zisterne.ino.hex"
                        avrdude: writing flash (29122 bytes):
                        
                        Writing | ################################################## | 100% 8.48s
                        
                        avrdude: 29122 bytes of flash written
                        avrdude: verifying flash memory against /tmp/arduino_build_243251/Zisterne.ino.hex:
                        avrdude: load data flash data from input file /tmp/arduino_build_243251/Zisterne.ino.hex:
                        avrdude: input file /tmp/arduino_build_243251/Zisterne.ino.hex contains 29122 bytes
                        avrdude: reading on-chip flash data:
                        
                        Reading | ################################################## | 100% 6.53s
                        
                        avrdude: verifying ...
                        Beim Hochladen des Sketches ist ein Fehler aufgetreten
                        avrdude: verification error, first mismatch at byte 0x7000
                                 0xff != 0x19
                        avrdude: verification error; content mismatch
                        
                        avrdude done.  Thank you.
                        

                        Wenn man den Fehler googelt kommt ein Hinweis auf "zu groß" - welche Größe hat denndas binary bei euch? sind ggfls. die gebundenen Libs zu dick?

                        Eisbaeeer 1 Reply Last reply Reply Quote 0
                        • Eisbaeeer
                          Eisbaeeer Developer @ltathome last edited by

                          @ltathome Hast du das über die IDE hochgeladen? Siehr mir so aus, als ob du die compilierte Datei direkt hochlädst?

                          L 1 Reply Last reply Reply Quote 0
                          • L
                            ltathome @Eisbaeeer last edited by

                            @Eisbaeeer Ja - ich hatte zwischenzeitlich auch den Bootloader nochmal neu gebraten, weil ich sicher gehen wollte, dass optiboot drauf ist (kleiner).

                            Im Moment hab ich das gelöst, indem ich per #ifndef HAS_DISPLAY... die ganzen Serial-Ausgaben und Aufrufe abgeklemmt habe.

                            Der Sketch ist aktuell bei mir jetzt 28428 Bytes groß bis 0x7000 = 28672 habe ich also noch gut 200 Bytes platz...

                            L 1 Reply Last reply Reply Quote 0
                            • L
                              ltathome @ltathome last edited by ltathome

                              @ltathome Ich habe noch ein wenig experimentiert mit dem Code:

                              wenn man die Ermittlung der Uptime z.B. so macht und das Zusammenbauen des Strings nicht doppelt (an mehreren Stellen), dann kommt man mit der Code-Size runter (Fragmente):

                              ...
                              int secs = 0, mins = 0, hours = 0;
                              int days = 0;
                              char uptime[25];
                              ...
                              void set_uptime() {
                                  secs++;
                                  secs = secs % 60;
                                  if (secs == 0) {
                                      mins++;
                                      mins = mins % 60;
                                      if (mins == 0) {
                                          hours++;
                                          hours = hours % 24;
                                          if (hours == 0) {
                                              days++;
                                              days = days % 10000;   // Nach 9999 Tagen zurück auf 0 (das sind 27 Jahre....)
                                          }
                                      }
                                  }
                                  sprintf(uptime, "%4dd %2dh %2dm", days, hours, mins);
                              }
                              ... 
                                  // System 
                                  /*  
                                  String upsum;
                                  upsum = String(days);
                                  upsum = String(upsum + "d ");
                                  upsum = String(upsum + hours);
                                  upsum = String(upsum + "h ");
                                  upsum = String(upsum + mins);
                                  upsum = String(upsum + "m");
                                  upsum.toCharArray(buff, 25);
                                  */
                                  client.publish("Zisterne/Uptime", uptime); 
                              
                              Eisbaeeer 1 Reply Last reply Reply Quote 1
                              • Eisbaeeer
                                Eisbaeeer Developer @ltathome last edited by

                                @ltathome machst du einen pull-request?

                                L 1 Reply Last reply Reply Quote 0
                                • L
                                  ltathome @Eisbaeeer last edited by

                                  @Eisbaeeer kann ich gerne machen, wenn man mir sagt wie - bisher habe ich auschließlich gecloned. Damit ich mit meinen sonstigen Anpassungen (4-zeiliges Display) den Stand nicht verhunze, setz ich das nochmal ganz sauber separat auf.

                                  Eisbaeeer 1 Reply Last reply Reply Quote 0
                                  • Eisbaeeer
                                    Eisbaeeer Developer @ltathome last edited by Eisbaeeer

                                    @ltathome
                                    Wäre cool. Du könntest z.B. über

                                    #define 4rowdisplay // 4x20 display oder 2x16 display

                                    #if 4rowdisplay
                                    ... Code für 4 zeiliges Display
                                    #endif
                                    #if 2rowdisplay
                                    ... Code für 2 zeiliges Display
                                    #endif
                                    Das ganze konfigurierbar machen. 😉
                                    Einen Pull-request machst du ganz einfach aus dem fork heraus. Da gibt es einen Button.
                                    Ich kann dir da gerne behilflich sein.
                                    Gruß Eisbaeeer

                                    P.S. du kannst den Stand gar nicht verhundsen. Erstens muss ich den pull-request vorher bestätigen und zweitens gibt es in github eine versionierung. Also nur zu!

                                    L 1 Reply Last reply Reply Quote 0
                                    • L
                                      ltathome @Eisbaeeer last edited by

                                      @Eisbaeeer said in Füllstandsmessung per Pegelsonde.:
                                      na dann ....

                                      Ich hätte den Code für 4x20 fertig. Ich sehe da noch ein Problem - aber vllt. liegt das auch an meiner Unwissenheit....

                                      Ich habe dein Repo gecloned, in der IDE Zisterne.ino geöffnet - und dann mosert die IDE, dass sie gerne ein Verzeichnis "Zisterne" hätte, legt das Verzeichnis an und schiebt das File darein, der anschließende Compile mosert dann über ein fehlendes progress.h, was ich dadurch gelöst habe, dass ich das ebenfalls in den Ordner "zisterne" verschoben habe.

                                      Dies nur als Vorwarnung - welchen Button meinst du? was ist jetzt das korrekte vorgehen? und sollen wir das "irgendwie" per Chat lösen? wir spammen hier den Thread voll....

                                      1 Reply Last reply Reply Quote 0
                                      • L
                                        ltathome last edited by ltathome

                                        Das wäre die Version mit den Anpassungen (jetzt korrigiert):

                                        Zisterne.ino

                                        1 Reply Last reply Reply Quote 0
                                        • B
                                          BoBeRzE last edited by BoBeRzE

                                          Hallo Leute,

                                          ich bin nun auch mal dazu gekommen meine Zisterne mit der Pegelsonde zu überwachen, zumindest wollte ich heute alles zusammenbauen... Offensichtlich hab ich die Schaltung falsch aufgebaut. Mein Sonnoff SV ist gestorben. Den will bzw. wollte 😖 ich nutzen um ein elektronisches Ventil zu öffnen wenn der Füllstand zu hoch wird. Seht ihr den Fehler? Ungewollte Brücken auf der Rückseite sind nicht vorhanden. Schwarz ist immer Minus, Rot immer Plus

                                          IMG_20200314_204139.jpg

                                          IMG_20200314_204218.jpg

                                          IMG_20200314_204236.jpg

                                          Vielen Dank im Voraus

                                          1 Reply Last reply Reply Quote 0
                                          • B
                                            Beowolf last edited by Beowolf

                                            Wenn keine Module eingesteckt sind, sind dann alle Spannungen da wo sie sein sollen?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.1k
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            63
                                            604
                                            164078
                                            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