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. Blockly
  5. [gelöst] Osmose Wasser Aktuell & Max Verbrauch

NEWS

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.7k

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

[gelöst] Osmose Wasser Aktuell & Max Verbrauch

Geplant Angeheftet Gesperrt Verschoben Blockly
79 Beiträge 2 Kommentatoren 3.1k Aufrufe 1 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • AphofisA Offline
    AphofisA Offline
    Aphofis
    schrieb am zuletzt editiert von Aphofis
    #39

    @paul53
    Kannst du mir einen Riesen gefallen tun und mal drüber gucken
    Beide Steuerungen für Vlies Verbrauch in cm und osmose Verbrauch in ml spinnen.
    Ich habe neue datenpunkte angelegt in datenpunkt Ordnern und in den Steuerungen alles sauber neu verknüpft.
    Doch nach dem ich beide Steuerungen eingeschaltet hatte, und Osmose oder Vlies läuft
    Wird cm_Max auf den Wert von cm_Aktuell gestellt und cm_pro_Tag cm_pro_Tag_count werden aufgerundet auf den cm_Aktuell wert.
    Da stimmt was nicht und ich verstehe es nicht.
    Hab schon beide Steuerungen mehrfach kontrolliert und deaktiviert, werte manuell geändert Scripte gestartet und immer wieder werden die Werte nicht ergänzt sondern mit dem falschen Wert aktualisiert.
    Das wäre sehr nett wenn du mir helfen könntest.

    var cm_pro_Tag, cm_komulativ, Differenz, cm_Aktuell;
    
    
    cm_pro_Tag = getState("Aqua_Control.0.Vliesfilter.cm_pro_Tag").val;
    cm_komulativ = getState("Aqua_Control.0.Vliesfilter.cm_Max").val;
    on({id: 'rpi2.0.gpio.20.state', change: "ne"}, function (obj) {
      var value = obj.state.val;
      var oldValue = obj.oldState.val;
      if (!(obj.state ? obj.state.val : "")) {
        Differenz = (obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "");
        cm_Aktuell = Differenz * getState("Aqua_Control.0.Vliesfilter.cm_multiplikator").val;
        setState("Aqua_Control.0.Vliesfilter.cm_Aktuell"/*cm_Aktuell*/, Math.round(cm_Aktuell*100)/100, true);
        cm_komulativ = (typeof cm_komulativ == 'number' ? cm_komulativ : 0) + cm_Aktuell;
        cm_pro_Tag = (typeof cm_pro_Tag == 'number' ? cm_pro_Tag : 0) + cm_Aktuell;
        setState("Aqua_Control.0.Vliesfilter.cm_Max"/*cm_Max*/, Math.round(cm_komulativ*100)/100, true);
        setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag"/*cm_pro_Tag*/, (Math.round(cm_pro_Tag)), true);
        setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag_count"/*cm_pro_Tag_count*/, (Math.round(cm_pro_Tag)), true);
        sendTo("telegram.0", "send", {
            text: (['Vliesverbrauch Aktuell ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_Aktuell").val*100)/100,' cm','\n','Vlies Tagesverbrauch ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_pro_Tag").val*100)/100,' cm','\n','Vliesverbrauch gesamt ',Math.round((getState("Aqua_Control.0.Vliesfilter.cm_Max").val / 100)*100)/100,' Meter'].join(''))
        });
        console.log((['Vliesverbrauch Aktuell ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_Aktuell").val*100)/100,' cm'].join('')));
        console.log((['Vliesverbrauch Gesamt ',Math.round((getState("Aqua_Control.0.Vliesfilter.cm_Max").val / 100)*100)/100,'  cm'].join('')));
      }
    });
    schedule("0 0 * * *", function () {
      cm_pro_Tag = 0;
      setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag"/*cm_pro_Tag*/, 0, true);
      setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag_count"/*cm_pro_Tag_count*/, 0, true);
    });
    
    

    Und noch komischer ist, in telegram werden die richtigen Werte angezeigt. Hatte auch mal unter Objekte den Experten Modus eingeschaltet nicht das die alten datenpunkte noch da sind aber sind sie nicht das da irgendwas durcheinander gekommen ist.

    paul53P 1 Antwort Letzte Antwort
    0
    • AphofisA Aphofis

      @paul53
      Kannst du mir einen Riesen gefallen tun und mal drüber gucken
      Beide Steuerungen für Vlies Verbrauch in cm und osmose Verbrauch in ml spinnen.
      Ich habe neue datenpunkte angelegt in datenpunkt Ordnern und in den Steuerungen alles sauber neu verknüpft.
      Doch nach dem ich beide Steuerungen eingeschaltet hatte, und Osmose oder Vlies läuft
      Wird cm_Max auf den Wert von cm_Aktuell gestellt und cm_pro_Tag cm_pro_Tag_count werden aufgerundet auf den cm_Aktuell wert.
      Da stimmt was nicht und ich verstehe es nicht.
      Hab schon beide Steuerungen mehrfach kontrolliert und deaktiviert, werte manuell geändert Scripte gestartet und immer wieder werden die Werte nicht ergänzt sondern mit dem falschen Wert aktualisiert.
      Das wäre sehr nett wenn du mir helfen könntest.

      var cm_pro_Tag, cm_komulativ, Differenz, cm_Aktuell;
      
      
      cm_pro_Tag = getState("Aqua_Control.0.Vliesfilter.cm_pro_Tag").val;
      cm_komulativ = getState("Aqua_Control.0.Vliesfilter.cm_Max").val;
      on({id: 'rpi2.0.gpio.20.state', change: "ne"}, function (obj) {
        var value = obj.state.val;
        var oldValue = obj.oldState.val;
        if (!(obj.state ? obj.state.val : "")) {
          Differenz = (obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "");
          cm_Aktuell = Differenz * getState("Aqua_Control.0.Vliesfilter.cm_multiplikator").val;
          setState("Aqua_Control.0.Vliesfilter.cm_Aktuell"/*cm_Aktuell*/, Math.round(cm_Aktuell*100)/100, true);
          cm_komulativ = (typeof cm_komulativ == 'number' ? cm_komulativ : 0) + cm_Aktuell;
          cm_pro_Tag = (typeof cm_pro_Tag == 'number' ? cm_pro_Tag : 0) + cm_Aktuell;
          setState("Aqua_Control.0.Vliesfilter.cm_Max"/*cm_Max*/, Math.round(cm_komulativ*100)/100, true);
          setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag"/*cm_pro_Tag*/, (Math.round(cm_pro_Tag)), true);
          setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag_count"/*cm_pro_Tag_count*/, (Math.round(cm_pro_Tag)), true);
          sendTo("telegram.0", "send", {
              text: (['Vliesverbrauch Aktuell ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_Aktuell").val*100)/100,' cm','\n','Vlies Tagesverbrauch ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_pro_Tag").val*100)/100,' cm','\n','Vliesverbrauch gesamt ',Math.round((getState("Aqua_Control.0.Vliesfilter.cm_Max").val / 100)*100)/100,' Meter'].join(''))
          });
          console.log((['Vliesverbrauch Aktuell ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_Aktuell").val*100)/100,' cm'].join('')));
          console.log((['Vliesverbrauch Gesamt ',Math.round((getState("Aqua_Control.0.Vliesfilter.cm_Max").val / 100)*100)/100,'  cm'].join('')));
        }
      });
      schedule("0 0 * * *", function () {
        cm_pro_Tag = 0;
        setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag"/*cm_pro_Tag*/, 0, true);
        setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag_count"/*cm_pro_Tag_count*/, 0, true);
      });
      
      

      Und noch komischer ist, in telegram werden die richtigen Werte angezeigt. Hatte auch mal unter Objekte den Experten Modus eingeschaltet nicht das die alten datenpunkte noch da sind aber sind sie nicht das da irgendwas durcheinander gekommen ist.

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

      @Aphofis
      Was ist der Unterschied zwischen "cm_pro_Tag" und "cm_pro_Tag_count" ? Ich kann keinen Unterschied erkennen.
      Für Telegram und Log verwende die Variablen cm_Aktuell, cm_komulativ und cm_pro_Tag, denn das Einlesen der Datenpunkte liefert einen veralteten Wert vom vorherigen Trigger.

      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

      AphofisA 1 Antwort Letzte Antwort
      0
      • paul53P paul53

        @Aphofis
        Was ist der Unterschied zwischen "cm_pro_Tag" und "cm_pro_Tag_count" ? Ich kann keinen Unterschied erkennen.
        Für Telegram und Log verwende die Variablen cm_Aktuell, cm_komulativ und cm_pro_Tag, denn das Einlesen der Datenpunkte liefert einen veralteten Wert vom vorherigen Trigger.

        AphofisA Offline
        AphofisA Offline
        Aphofis
        schrieb am zuletzt editiert von
        #41

        @paul53
        count war eigntl gedacht um zu zählen wie oft bzw wie lange osmose oder der vlies filter am tag läuft also wie lange auf true stand und wie oft true an war.
        dH. ich muss count raus nehmen !?
        Die werte kommen doch aus den Datenpunkten doch wenn ich die beiden scripte stoppe dann die Daten in den Datenpunkten so einstelle wie es gehört und die Scripte wieder starte schmeissen beide die Daten raus bei max und bei tages verbrauch.

        1 Antwort Letzte Antwort
        0
        • AphofisA Offline
          AphofisA Offline
          Aphofis
          schrieb am zuletzt editiert von
          #42

          Vliesverbrauch sieht dann so aus:

          var cm_pro_Tag, cm_komulativ, Differenz, cm_Aktuell;
          
          
          cm_pro_Tag = getState("Aqua_Control.0.Vliesfilter.cm_pro_Tag").val;
          cm_komulativ = getState("Aqua_Control.0.Vliesfilter.cm_Max").val;
          on({id: 'rpi2.0.gpio.20.state', change: "ne"}, function (obj) {
            var value = obj.state.val;
            var oldValue = obj.oldState.val;
            if (!(obj.state ? obj.state.val : "")) {
              Differenz = (obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "");
              cm_Aktuell = Differenz * getState("Aqua_Control.0.Vliesfilter.cm_multiplikator").val;
              setState("Aqua_Control.0.Vliesfilter.cm_Aktuell"/*cm_Aktuell*/, Math.round(cm_Aktuell*100)/100, true);
              cm_komulativ = (typeof cm_komulativ == 'number' ? cm_komulativ : 0) + cm_Aktuell;
              cm_pro_Tag = (typeof cm_pro_Tag == 'number' ? cm_pro_Tag : 0) + cm_Aktuell;
              setState("Aqua_Control.0.Vliesfilter.cm_Max"/*cm_Max*/, Math.round(cm_komulativ*100)/100, true);
              setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag"/*cm_pro_Tag*/, (Math.round(cm_pro_Tag)), true);
              sendTo("telegram.0", "send", {
                  text: (['Vliesverbrauch Aktuell ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_Aktuell").val*100)/100,' cm','\n','Vlies Tagesverbrauch ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_pro_Tag").val*100)/100,' cm','\n','Vliesverbrauch gesamt ',Math.round((getState("Aqua_Control.0.Vliesfilter.cm_Max").val / 100)*100)/100,' Meter'].join(''))
              });
              console.log((['Vliesverbrauch Aktuell ',Math.round(getState("Aqua_Control.0.Vliesfilter.cm_Aktuell").val*100)/100,' cm'].join('')));
              console.log((['Vliesverbrauch Gesamt ',Math.round((getState("Aqua_Control.0.Vliesfilter.cm_Max").val / 100)*100)/100,'  cm'].join('')));
            }
          });
          schedule("0 0 * * *", function () {
            cm_pro_Tag = 0;
            setState("Aqua_Control.0.Vliesfilter.cm_pro_Tag"/*cm_pro_Tag*/, 0, true);
          });
          

          Osmose Verbrauch:

          var ml_pro_Tag, ml_Kumulativ, Differenz, ml_Aktuell;
          
          
          ml_pro_Tag = getState("Aqua_Control.0.Osmose_System.ml_pro_Tag").val;
          ml_Kumulativ = getState("Aqua_Control.0.Osmose_System.Osmose_Max").val;
          // Magnetventil
          on({id: 'rpi2.0.gpio.21.state', change: "ne"}, function (obj) {
            var value = obj.state.val;
            var oldValue = obj.oldState.val;
            if (!(obj.state ? obj.state.val : "")) {
              Differenz = (obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "");
              ml_Aktuell = Differenz * getState("Aqua_Control.0.Osmose_System.ml_multiplikator").val;
              setState("Aqua_Control.0.Osmose_System.Osmose_Aktuell"/*Osmose_Aktuell*/, Math.round(ml_Aktuell*100)/100, true);
              ml_Kumulativ = (typeof ml_Kumulativ == 'number' ? ml_Kumulativ : 0) + ml_Aktuell;
              ml_pro_Tag = (typeof ml_pro_Tag == 'number' ? ml_pro_Tag : 0) + ml_Aktuell;
              setState("Aqua_Control.0.Osmose_System.Osmose_Max"/*Osmose_Max*/, Math.round(ml_Kumulativ*100)/100, true);
              setState("Aqua_Control.0.Osmose_System.Osmose_Gesamtverbrauch"/*Osmose_Gesamtverbrauch*/, Math.round((ml_Kumulativ / 1000)*1000)/1000, true);
              setState("Aqua_Control.0.Osmose_System.ml_pro_Tag"/*ml_pro_Tag*/, (Math.round(ml_pro_Tag)), true);
              console.log((['Dosierung aktuell ',Math.round(ml_Aktuell),' ml'].join('')));
              console.log((['Dosierung Gesamt ',Math.round((ml_Kumulativ / parseFloat(1000))*1000)/1000,' Liter'].join('')));
              sendTo("telegram.0", "send", {
                  text: (['Osmose Dosierung aktuell ',Math.round(getState("Aqua_Control.0.Osmose_System.Osmose_Aktuell").val),' ml','\n','Osmose Tages Dosierung ',Math.round((getState("Aqua_Control.0.Osmose_System.ml_pro_Tag").val / 1000)*100)/100,' Liter','\n','Osmose Gesamtverbrauch ',Math.round(getState("Aqua_Control.0.Osmose_System.Osmose_Gesamtverbrauch").val),' Liter'].join(''))
              });
            }
          });
          schedule("0 0 * * *", function () {
            ml_pro_Tag = 0;
            setState("Aqua_Control.0.Osmose_System.ml_pro_Tag"/*ml_pro_Tag*/, 0, true);
          });
          

          wäre es dann so korrekt und die steuerungen nehmen beim starten die werte aus den datenpunkten ?

          1 Antwort Letzte Antwort
          0
          • AphofisA Offline
            AphofisA Offline
            Aphofis
            schrieb am zuletzt editiert von
            #43

            Ich habe jetzt ml_pr_Tag_count und cm_pro_Tag_count raus geschmissen aus den steuerungen und zum testen nicht das magnet ventil oder den vlies motor manuell betätigt sondern die beiden schwimmer und siehe da, es funktioniert wieder.
            Was ich nur nicht verstehe wieso ging es die ganze Zeit und jetzt nicht mehr.
            Kann es mit den neu angelegten und neu verknüpften Datenpunkten zu tun haben !?
            Hatte ja vorher alle scripte gestoppt und dann die datenpunkt änderungen vorgenommen.
            Da ja noch reichlich Steuerungen dazu kommen musste ich aufräumen.
            Sonst wird es nachher ein unübersichtlicher Haufen Datenpunkte.
            Dazu kommen noch zwei TDS ppm Meter dann eine Leitwert Sonde, eine PH Sonde und wenns klappt die Steuerung Zeitgesteuert zu dem Tunze Controller senden.

            paul53P 1 Antwort Letzte Antwort
            0
            • AphofisA Aphofis

              Ich habe jetzt ml_pr_Tag_count und cm_pro_Tag_count raus geschmissen aus den steuerungen und zum testen nicht das magnet ventil oder den vlies motor manuell betätigt sondern die beiden schwimmer und siehe da, es funktioniert wieder.
              Was ich nur nicht verstehe wieso ging es die ganze Zeit und jetzt nicht mehr.
              Kann es mit den neu angelegten und neu verknüpften Datenpunkten zu tun haben !?
              Hatte ja vorher alle scripte gestoppt und dann die datenpunkt änderungen vorgenommen.
              Da ja noch reichlich Steuerungen dazu kommen musste ich aufräumen.
              Sonst wird es nachher ein unübersichtlicher Haufen Datenpunkte.
              Dazu kommen noch zwei TDS ppm Meter dann eine Leitwert Sonde, eine PH Sonde und wenns klappt die Steuerung Zeitgesteuert zu dem Tunze Controller senden.

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

              @Aphofis

              Wandle am Besten den Wert vom Multiplikator nach Zahl, weil auch ein String in den Datenpunkt gelangen kann. Also:

              setze Aktuell auf Differenz * nach Zahl Wert vom Multiplikator

              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

              AphofisA 1 Antwort Letzte Antwort
              1
              • paul53P paul53

                @Aphofis

                Wandle am Besten den Wert vom Multiplikator nach Zahl, weil auch ein String in den Datenpunkt gelangen kann. Also:

                setze Aktuell auf Differenz * nach Zahl Wert vom Multiplikator

                AphofisA Offline
                AphofisA Offline
                Aphofis
                schrieb am zuletzt editiert von
                #45

                @paul53
                Meinst du so:

                Bildschirmfoto 2019-08-16 um 22.00.06.png
                Bildschirmfoto 2019-08-16 um 22.00.51.png

                paul53P 1 Antwort Letzte Antwort
                0
                • AphofisA Aphofis

                  @paul53
                  Meinst du so:

                  Bildschirmfoto 2019-08-16 um 22.00.06.png
                  Bildschirmfoto 2019-08-16 um 22.00.51.png

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

                  @Aphofis sagte:

                  Meinst du so:

                  Ja.

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  1 Antwort Letzte Antwort
                  0
                  • AphofisA Offline
                    AphofisA Offline
                    Aphofis
                    schrieb am zuletzt editiert von
                    #47

                    OK, dann hoffe ich, das jetzt alles reibungslos läuft.

                    1 Antwort Letzte Antwort
                    0
                    • AphofisA Offline
                      AphofisA Offline
                      Aphofis
                      schrieb am zuletzt editiert von
                      #48

                      Bis jetzt scheinen beide Steuerungen endlich wieder das zu tun was sie sollen.
                      Sie zählen fleißig. :blush:

                      1 Antwort Letzte Antwort
                      0
                      • AphofisA Offline
                        AphofisA Offline
                        Aphofis
                        schrieb am zuletzt editiert von
                        #49

                        Bis auf Osmose Verbrauch, die Verbrauchssteuerung haut manchmal komische werte rein.
                        Es werden normal immer so 50-300 ml dosiert am stück und manchmal steht dann in der aktuellen dosierung 4000ml aufwärts aber auch nur zwischendurch.
                        Woran kann das liegen !?

                        var ml_pro_Tag, ml_Kumulativ, Differenz, ml_Aktuell;
                        
                        
                        ml_pro_Tag = getState("Aqua_Control.0.Osmose_System.ml_pro_Tag").val;
                        ml_Kumulativ = getState("Aqua_Control.0.Osmose_System.Osmose_Max").val;
                        // Magnetventil
                        on({id: 'rpi2.0.gpio.21.state', change: "ne"}, function (obj) {
                          var value = obj.state.val;
                          var oldValue = obj.oldState.val;
                          if (!(obj.state ? obj.state.val : "")) {
                            Differenz = (obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "");
                            ml_Aktuell = Differenz * parseFloat(getState("Aqua_Control.0.Osmose_System.ml_multiplikator").val);
                            setState("Aqua_Control.0.Osmose_System.Osmose_Aktuell"/*Osmose_Aktuell*/, Math.round(ml_Aktuell*100)/100, true);
                            ml_Kumulativ = (typeof ml_Kumulativ == 'number' ? ml_Kumulativ : 0) + ml_Aktuell;
                            ml_pro_Tag = (typeof ml_pro_Tag == 'number' ? ml_pro_Tag : 0) + ml_Aktuell;
                            setState("Aqua_Control.0.Osmose_System.Osmose_Max"/*Osmose_Max*/, Math.round(ml_Kumulativ*100)/100, true);
                            setState("Aqua_Control.0.Osmose_System.Osmose_Gesamtverbrauch"/*Osmose_Gesamtverbrauch*/, Math.round((ml_Kumulativ / 1000)*1000)/1000, true);
                            setState("Aqua_Control.0.Osmose_System.ml_pro_Tag"/*ml_pro_Tag*/, (Math.round(ml_pro_Tag)), true);
                            console.log((['Dosierung aktuell ',Math.round(ml_Aktuell),' ml'].join('')));
                            console.log((['Dosierung Gesamt ',Math.round((ml_Kumulativ / parseFloat(1000))*1000)/1000,' Liter'].join('')));
                            sendTo("telegram.0", "send", {
                                text: (['Osmose Dosierung aktuell ',Math.round(getState("Aqua_Control.0.Osmose_System.Osmose_Aktuell").val),' ml','\n','Osmose Tages Dosierung ',Math.round((getState("Aqua_Control.0.Osmose_System.ml_pro_Tag").val / 1000)*100)/100,' Liter','\n','Osmose Gesamtverbrauch ',Math.round(getState("Aqua_Control.0.Osmose_System.Osmose_Gesamtverbrauch").val),' Liter'].join(''))
                            });
                          }
                        });
                        schedule("0 0 * * *", function () {
                          ml_pro_Tag = 0;
                          setState("Aqua_Control.0.Osmose_System.ml_pro_Tag"/*ml_pro_Tag*/, 0, true);
                        });
                        
                        paul53P 1 Antwort Letzte Antwort
                        0
                        • AphofisA Aphofis

                          Bis auf Osmose Verbrauch, die Verbrauchssteuerung haut manchmal komische werte rein.
                          Es werden normal immer so 50-300 ml dosiert am stück und manchmal steht dann in der aktuellen dosierung 4000ml aufwärts aber auch nur zwischendurch.
                          Woran kann das liegen !?

                          var ml_pro_Tag, ml_Kumulativ, Differenz, ml_Aktuell;
                          
                          
                          ml_pro_Tag = getState("Aqua_Control.0.Osmose_System.ml_pro_Tag").val;
                          ml_Kumulativ = getState("Aqua_Control.0.Osmose_System.Osmose_Max").val;
                          // Magnetventil
                          on({id: 'rpi2.0.gpio.21.state', change: "ne"}, function (obj) {
                            var value = obj.state.val;
                            var oldValue = obj.oldState.val;
                            if (!(obj.state ? obj.state.val : "")) {
                              Differenz = (obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "");
                              ml_Aktuell = Differenz * parseFloat(getState("Aqua_Control.0.Osmose_System.ml_multiplikator").val);
                              setState("Aqua_Control.0.Osmose_System.Osmose_Aktuell"/*Osmose_Aktuell*/, Math.round(ml_Aktuell*100)/100, true);
                              ml_Kumulativ = (typeof ml_Kumulativ == 'number' ? ml_Kumulativ : 0) + ml_Aktuell;
                              ml_pro_Tag = (typeof ml_pro_Tag == 'number' ? ml_pro_Tag : 0) + ml_Aktuell;
                              setState("Aqua_Control.0.Osmose_System.Osmose_Max"/*Osmose_Max*/, Math.round(ml_Kumulativ*100)/100, true);
                              setState("Aqua_Control.0.Osmose_System.Osmose_Gesamtverbrauch"/*Osmose_Gesamtverbrauch*/, Math.round((ml_Kumulativ / 1000)*1000)/1000, true);
                              setState("Aqua_Control.0.Osmose_System.ml_pro_Tag"/*ml_pro_Tag*/, (Math.round(ml_pro_Tag)), true);
                              console.log((['Dosierung aktuell ',Math.round(ml_Aktuell),' ml'].join('')));
                              console.log((['Dosierung Gesamt ',Math.round((ml_Kumulativ / parseFloat(1000))*1000)/1000,' Liter'].join('')));
                              sendTo("telegram.0", "send", {
                                  text: (['Osmose Dosierung aktuell ',Math.round(getState("Aqua_Control.0.Osmose_System.Osmose_Aktuell").val),' ml','\n','Osmose Tages Dosierung ',Math.round((getState("Aqua_Control.0.Osmose_System.ml_pro_Tag").val / 1000)*100)/100,' Liter','\n','Osmose Gesamtverbrauch ',Math.round(getState("Aqua_Control.0.Osmose_System.Osmose_Gesamtverbrauch").val),' Liter'].join(''))
                              });
                            }
                          });
                          schedule("0 0 * * *", function () {
                            ml_pro_Tag = 0;
                            setState("Aqua_Control.0.Osmose_System.ml_pro_Tag"/*ml_pro_Tag*/, 0, true);
                          });
                          
                          paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von
                          #50

                          @Aphofis sagte:

                          Woran kann das liegen !?

                          Nicht am Skript, denn im Skript passieren keine zufälligen Sachen.
                          Hast Du den Datenpunkt 'rpi2.0.gpio.21.state' historisiert ? Falls nicht, solltest Du es machen.

                          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

                          AphofisA 1 Antwort Letzte Antwort
                          0
                          • paul53P paul53

                            @Aphofis sagte:

                            Woran kann das liegen !?

                            Nicht am Skript, denn im Skript passieren keine zufälligen Sachen.
                            Hast Du den Datenpunkt 'rpi2.0.gpio.21.state' historisiert ? Falls nicht, solltest Du es machen.

                            AphofisA Offline
                            AphofisA Offline
                            Aphofis
                            schrieb am zuletzt editiert von Aphofis
                            #51

                            @paul53
                            ja wird in der Datenbank geloggt, nur Flot Adapter funktioniert immer noch nicht.
                            Wie gesagt, wenn ich die Geräte über einen ESP laufen lasse denke ich werden auch keine komischen werte mehr zustande kommen. ich denke das passiert wenn der Pi neu startet. spinnt die Relais Karte und alle Relais leuchten obwohl standard sind alle relais auf low getriggert und sind somit beim start eigntl false.

                            1 Antwort Letzte Antwort
                            0
                            • AphofisA Offline
                              AphofisA Offline
                              Aphofis
                              schrieb am zuletzt editiert von Aphofis
                              #52

                              So sieht dann momentan die Zählung aus,
                              Wenn normal Osmose dosiert wird!

                              3F8ADEF3-0D9A-4144-9E09-BB4B6A1DBBC4.jpeg

                              Seid dem Umbau auf ESP8266 läuft alles perfekt

                              1 Antwort Letzte Antwort
                              0
                              • AphofisA Offline
                                AphofisA Offline
                                Aphofis
                                schrieb am zuletzt editiert von
                                #53

                                @paul53
                                Ich hatte das Script ja umgemodelt auch auf meine Triton Lösungszählung.
                                Dazu wollte ich einen Zähler mit einem Datenpunkt nutzen der jeden Tag um 23:59 den ml_pro_Tag datenpunkt vom Verbrauch von dem Füllstand abzieht. Damit ich zb bei Rest 500 ml eine Meldung rausgeben kann das ich neue Triton Lösungen kaufen muss. Bzw damit ich weiss wie viel Lösung noch übrig ist.
                                Wäre das so korrekt?

                                var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                
                                
                                Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                schedule("59 23 * * *", function () {
                                  Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                  setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                });
                                
                                paul53P 1 Antwort Letzte Antwort
                                0
                                • AphofisA Aphofis

                                  @paul53
                                  Ich hatte das Script ja umgemodelt auch auf meine Triton Lösungszählung.
                                  Dazu wollte ich einen Zähler mit einem Datenpunkt nutzen der jeden Tag um 23:59 den ml_pro_Tag datenpunkt vom Verbrauch von dem Füllstand abzieht. Damit ich zb bei Rest 500 ml eine Meldung rausgeben kann das ich neue Triton Lösungen kaufen muss. Bzw damit ich weiss wie viel Lösung noch übrig ist.
                                  Wäre das so korrekt?

                                  var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                  
                                  
                                  Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                  schedule("59 23 * * *", function () {
                                    Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                    setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                  });
                                  
                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  schrieb am zuletzt editiert von
                                  #54

                                  @Aphofis sagte:

                                  Wäre das so korrekt?

                                  Nein, Zeile 4 muss als erstes innerhalb des Schedule ausgeführt werden, da der Wert sonst nur einmal bei Skriptstart ermittelt wird.

                                  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

                                  AphofisA 1 Antwort Letzte Antwort
                                  0
                                  • paul53P paul53

                                    @Aphofis sagte:

                                    Wäre das so korrekt?

                                    Nein, Zeile 4 muss als erstes innerhalb des Schedule ausgeführt werden, da der Wert sonst nur einmal bei Skriptstart ermittelt wird.

                                    AphofisA Offline
                                    AphofisA Offline
                                    Aphofis
                                    schrieb am zuletzt editiert von
                                    #55

                                    @paul53
                                    also so?

                                    var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                    
                                    
                                    Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                    schedule("59 23 * * *", function () {
                                      setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                      Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                    });
                                    
                                    paul53P 1 Antwort Letzte Antwort
                                    0
                                    • AphofisA Aphofis

                                      @paul53
                                      also so?

                                      var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                      
                                      
                                      Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                      schedule("59 23 * * *", function () {
                                        setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                        Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                      });
                                      
                                      paul53P Offline
                                      paul53P Offline
                                      paul53
                                      schrieb am zuletzt editiert von
                                      #56

                                      @Aphofis sagte:

                                      also so?

                                      Nein, so:

                                      var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                       
                                       
                                      schedule("59 23 * * *", function () {
                                        Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                        Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                        setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                      });
                                      

                                      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

                                      AphofisA 1 Antwort Letzte Antwort
                                      0
                                      • paul53P paul53

                                        @Aphofis sagte:

                                        also so?

                                        Nein, so:

                                        var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                         
                                         
                                        schedule("59 23 * * *", function () {
                                          Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                          Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                          setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                        });
                                        
                                        AphofisA Offline
                                        AphofisA Offline
                                        Aphofis
                                        schrieb am zuletzt editiert von Aphofis
                                        #57

                                        @paul53
                                        OK hab ich !

                                        var Triton_L_C3_B6sung_2_F_C3_BCllstand, Abzug;
                                        
                                        
                                        schedule("59 23 * * *", function () {
                                          Triton_L_C3_B6sung_2_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand").val;
                                          Abzug = Triton_L_C3_B6sung_2_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand").val;
                                          setState("Aqua_Control.0.Triton.Lösung_2.Verbrauch.Triton_Lösung_2_Füllstand"/*Triton_Lösung_2_Füllstand*/, Abzug, true);
                                        });
                                        
                                        1 Antwort Letzte Antwort
                                        0
                                        • AphofisA Offline
                                          AphofisA Offline
                                          Aphofis
                                          schrieb am zuletzt editiert von
                                          #58

                                          @paul53
                                          Ich hatte das so erstellt, nur leider wird so nix von dem Füllstand Datenpunkt (5000ml) abgezogen.

                                          var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                          
                                          
                                          schedule("59 23 * * *", function () {
                                            Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                            Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                            setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                          });
                                          

                                          vorher war es so:

                                          var Triton_L_C3_B6sung_1_F_C3_BCllstand, Abzug;
                                          
                                          
                                          Triton_L_C3_B6sung_1_F_C3_BCllstand = getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand").val;
                                          schedule("59 23 * * *", function () {
                                            Abzug = Triton_L_C3_B6sung_1_F_C3_BCllstand - getState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_pro_Tag").val;
                                            setState("Aqua_Control.0.Triton.Lösung_1.Verbrauch.Triton_Lösung_1_Füllstand"/*Triton_Lösung_1_Füllstand*/, Abzug, true);
                                          });
                                          

                                          Da wurde vom Füllstand Datenpunkt abgezogen. vllt sollte ich nicht ml_pro_Tag abziehen sindern jedes mal nur ml_Aktuell dann ist es vllt einfacher ohne die Zeit Steuerung um 23:59

                                          paul53P 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

                                          856

                                          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