NEWS
[gelöst] Osmose Wasser Aktuell & Max Verbrauch
-
@paul53
Du bist ne Wucht !!! Auch wenns einfach ist, muss man sowas erstmal wissen.
Es hat geklappt, beim Vlies und beim Osmose Verbrauch. Danke
Daten werden auch alle fleißig in der Datenbank geloggt.
Nur werden auch werte mit Wert - null - geloggt, das natürlich nicht so schön und dazu kommt noch das mein Flot Adapter nicht funktioniert. Hab schon Flot deinstalliert ob über iobroker und über ssh und auch über beide Wege neu installiert! keine Chance.
Wenn ich Flot aufrufen will, kommt eine Fehler Meldung auf dem neuen Tab:
File edit.html not found: permissionError
Wenn ich mir die Charts angucken will in einem Datenpunkt von dem sql Adapter kommt keine Grafik.
Hab schon überall im Netz nach dem Fehler gesucht, doch leider kein Erfolg. -
@Aphofis sagte:
Wenn ich Flot aufrufen will, kommt eine Fehler Meldung auf dem neuen Tab: File edit.html not found: permissionError
Mache dazu besser ein neues Thema auf, denn es geht in diesem Thema hier unter.
Bitte noch die Überschrift um [gelöst] ergänzen. -
Na klar mach ich das ! Wollte dir nur den Stand der Dinge mitteilen.
-
@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.
-
@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. -
@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. -
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 ?
-
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. -
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
-
@paul53
Meinst du so:
-
-
OK, dann hoffe ich, das jetzt alles reibungslos läuft.
-
Bis jetzt scheinen beide Steuerungen endlich wieder das zu tun was sie sollen.
Sie zählen fleißig. -
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); });
-
@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. -
@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. -
So sieht dann momentan die Zählung aus,
Wenn normal Osmose dosiert wird!Seid dem Umbau auf ESP8266 läuft alles perfekt
-
@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); });
-
@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.
-
@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; });