NEWS
Set State ( Timestamp ) Zeitverzögert [gelöst].
-
Nein habe mich falsch ausgedrückt. Er soll nur zwischen 500 und 800 dosieren. Wenn er unter 500 ist oder über 800 dann soll er nicht mehr Dosieren und ein Störung erzeugen. So soll es richtig sein.
Eine frage habe ich noch. Kann ich die maximal Tagesmenge Zeit so zurücksetzen oder wäre das nicht so richtig ?
// Reset der TagesCounter bei einem Datumswechsel
schedule ("30 0 0 * * *", function() {
var chlor_time = 0;
setState(idDayTimeChlor, chlor_time);
// Reset Kennzeichen Tagesmenge überschritten
setState(idDayTimeChlorOver, false);
-
Er soll nur zwischen 500 und 800 dosieren. `
Das kann nicht sein, denn dann liegt der Zielwert außerhalb des Bereiches ! Außerdem stimmen dann die Vergleiche (Vorzeichen) nicht !Kann ich die maximal Tagesmenge Zeit so zurücksetzen oder wäre das nicht so richtig ?
// Reset der TagesCounter bei einem Datumswechsel
schedule ("30 0 0 * * *", function() {
var chlor_time = 0;
setState(idDayTimeChlor, chlor_time);
// Reset Kennzeichen Tagesmenge überschritten
setState(idDayTimeChlorOver, false); `
Es muss erst die Tagesmenge im Datenpunkt idDayTimeChlor gespeichert werden, bevor die Variable zurück gesetzt wird. Für "Tagesmenge überschritten" fehlt ein Vergleich.var chlor_time; // Reset der TagesCounter bei einem Datumswechsel schedule ("30 0 0 * * *", function() { // 30 s nach Mitternacht setState(idDayTimeChlor, chlor_time); // Reset Kennzeichen Tagesmenge überschritten if(chlor_time < Vergleichswert) setState(idDayTimeChlorOver, false); else setState(idDayTimeChlorOver, true); chlor_time = 0; });
-
Ich dacht so,
` > // Check, ob die Tagesdosierung Chlor noch nicht überschritten
if (getState(idDayTimeChlor).val >= maxTimeChlor) {
log('Tagesmenge Chlor erreicht -> keine Dosierung');
dosingOK = false;
}
// Ist der Zielwert bereits überschritten?
if (orpIstWert > orpZielwert) {
log('Dosierung Target ORP erreicht ->keine Dosierung');
dosingOK = false;
// in die globale Variable speichern
if (getState(idDayTimeChlorOver).val === false) {
setState(idDayTimeChlorOver, true);
}
// Fortschreibung Tagesdosierung Chlor
var chlor_time = getState(idDayTimeChlor).val;
chlor_time += dosingTime;
setState(idDayTimeChlor, chlor_time);
// Reset der TagesCounter bei einem Datumswechsel
schedule ("30 0 0 * * *", function() { // 30 s nach Mitternacht
setState(idDayTimeChlor, chlor_time);
// Reset Kennzeichen Tagesmenge überschritten
if(chlor_time < Vergleichswert) setState(idDayTimeChlorOver, false);
else setState(idDayTimeChlorOver, true);
chlor_time = 0;
}); `
sollte so laufen oder ?
-
Code bitte in Code tags posten, da sonst schlecht lesbar (Formatierung verschwindet) !
Besser:
// Check, ob die Tagesdosierung Chlor noch nicht überschritten if (chlor_time >= maxTimeChlor) { log('Tagesmenge Chlor erreicht -> keine Dosierung'); dosingOK = false; setState(idDayTimeChlorOver, true); }
// Ist der Zielwert bereits überschritten?
if (orpIstWert > orpZielwert) {
log('Dosierung Target ORP erreicht ->keine Dosierung');
dosingOK = false;
// in die globale Variable speichern
if (getState(idDayTimeChlorOver).val === false) {
setState(idDayTimeChlorOver, true);
} `
Das wird doch schon geprüft durchif (orpZielwert <= orpIstWert) dosingTime = 0;
Das Einlesen des Wertes von idDayTimeChlor ist nicht erforderlich, wenn chlor_time eine globale Variable ist.
// Fortschreibung Tagesdosierung Chlor chlor_time += dosingTime; setState(idDayTimeChlor, chlor_time);
und
// Reset der TagesCounter bei einem Datumswechsel schedule ("30 0 0 * * *", function() { // 30 s nach Mitternacht // Reset Kennzeichen Tagesmenge überschritten setState(idDayTimeChlorOver, false); chlor_time = 0; setState(idDayTimeChlor, chlor_time); });
-
Ich wollte die Zeit selber bestimmen. Sprich beispielweise Max Chlor Dosieren 80 sec. am Tag. Dann nicht mehr Dosieren.
` > var idDayTimeChlor = "hm-rega.0.Chor_Zeit_Tagesmenge"; // Tagesmenge Chlor
var maxTimeChlor = "80"; // Chlor Tagesmenge in sec. `
-
Ich wollte die Zeit selber bestimmen. `
??
@kasperfunsurfer:var maxTimeChlor = "80"; // Chlor Tagesmenge in sec. `
Weil damit gerechnet wird, muss es eine Zahl sein (kein String !).const maxTimeChlor = 80; // Chlor Tagesmenge in sec.
-
` > // IDS der Elemente IOBroker
const idChlorAcidAlternative = "hm-rega.0.Dosierung_Umschaltung_Chlor/Acid";
const idPHWert = "parser.0.Pool-ph";
const idORPWert = "parser.0.Pool-orp";
const idPumpeChlor = "hm-rpc.0.MEQ0454385.1.STATE";
const idPoolPumpe = "hm-rpc.1.NEQ1810472.13.STATE";
const idDosingAuto = "hm-rega.0.25168";
const maxTimeChlor = 80; // Chlor Tagesmenge in sec.
const idDayTimeChlor = "hm-rega.0.Chor_Zeit_Tagesmenge"; // Tagesmenge Chlor ?????????????????
// Zielwerte
const idPHZielwert = "8,1";
const orpZielwert = 850;
// interne Variablen
var timer;
var acid;
var dosingOK = false;
setTimeout(function() {
dosingOK = getState(idPoolPumpe).val;
}, 120000);
// Umschaltung Chlor / Acid im Wechsel
function Dosierung() {
acid = false;
setState(idChlorAcidAlternative, "chlor");
timer = setInterval(function() {
acid = !acid;
if(acid) setState(idChlorAcidAlternative, "acid");
else setState(idChlorAcidAlternative, "chlor");
// DosingTime abhängig von ORP-Differenz festlegen
var orpIstWert = parseFloat(getState(idORPWert).val); // parseFloat, falls ORPWert ein String ist
var dosingTime = 80;
if (orpZielwert - orpIstWert < 100) dosingTime =60;
if (orpZielwert - orpIstWert < 60) dosingTime = 50;
if (orpZielwert - orpIstWert < 40) dosingTime = 45;
if (orpZielwert - orpIstWert < 20) dosingTime = 35;
if (orpZielwert - orpIstWert < 10) dosingTime = 20;
if (orpZielwert - orpIstWert < 5) dosingTime = 10;
if (orpZielwert <= orpIstWert) dosingTime = 0;
// Chlor-Dosierung starten
if (dosingOK && dosingTime > 0 && !getState(idPumpeChlor).val) {
setState(idPumpeChlor, true);
setTimeout(function(){
setState(idPumpeChlor, false);
}, dosingTime * 1000);
}
}, 60000); // alle 1 Minuten
}
// Skriptstart
if(getState(idDosingAuto).val) Dosierung();
on(idDosingAuto, function(dp) {
if(dp.state.val) {
Dosierung();
} else {
if(timer) clearInterval(timer);
setState(idPumpeChlor, false);
}
});
// Dosierung wird nach 2 Minuten freigegeben
on(idPoolPumpe, function(dp) {
if(dp.state.val) {
setTimeout(function() {
dosingOK = true;
}, 120000);
} else {
dosingOK = false;
setState(idPumpeChlor, false);
}
});
// Check, ob die Tagesdosierung Chlor noch nicht überschritten
if (chlor_time >= maxTimeChlor) {
log('Tagesmenge Chlor erreicht -> keine Dosierung');
dosingOK = false;
setState(idDayTimeChlorOver, true);
}
// Fortschreibung Tagesdosierung Chlor
chlor_time += dosingTime;
setState(idDayTimeChlor, chlor_time);
// Reset der TagesCounter bei einem Datumswechsel
schedule ("30 0 0 * * *", function() { // 30 s nach Mitternacht
// Reset Kennzeichen Tagesmenge überschritten
setState(idDayTimeChlorOver, false);
chlor_time = 0;
setState(idDayTimeChlor, chlor_time);
}); `
So richtig ?
Oder muss der Wert noch mal in eine Variable geschrieben werden ?? ( const idDayTimeChlor = "hm-rega.0.Chor_Zeit_Tagesmenge"; // Tagesmenge Chlor )
-
Du hast den Code als Zitat pepostet. Bitte noch einmal in Code tags (der Button rechts neben dem Zitat-Button).
-
Upps Sorry
// IDS der Elemente IOBroker const idChlorAcidAlternative = "hm-rega.0.Dosierung_Umschaltung_Chlor/Acid"; const idPHWert = "parser.0.Pool-ph"; const idORPWert = "parser.0.Pool-orp"; const idPumpeChlor = "hm-rpc.0.MEQ0454385.1.STATE"; const idPoolPumpe = "hm-rpc.1.NEQ1810472.13.STATE"; const idDosingAuto = "hm-rega.0.25168"; const maxTimeChlor = 80; // Chlor Tagesmenge in sec. const idDayTimeChlor = "hm-rega.0.Chor_Zeit_Tagesmenge"; // Tagesmenge Chlor ????????????????? // Zielwerte const idPHZielwert = "8,1"; const orpZielwert = 850; // interne Variablen var timer; var acid; var dosingOK = false; setTimeout(function() { dosingOK = getState(idPoolPumpe).val; }, 120000); // Umschaltung Chlor / Acid im Wechsel function Dosierung() { acid = false; setState(idChlorAcidAlternative, "chlor"); timer = setInterval(function() { acid = !acid; if(acid) setState(idChlorAcidAlternative, "acid"); else setState(idChlorAcidAlternative, "chlor"); // DosingTime abhängig von ORP-Differenz festlegen var orpIstWert = parseFloat(getState(idORPWert).val); // parseFloat, falls ORPWert ein String ist var dosingTime = 80; if (orpZielwert - orpIstWert < 100) dosingTime =60; if (orpZielwert - orpIstWert < 60) dosingTime = 50; if (orpZielwert - orpIstWert < 40) dosingTime = 45; if (orpZielwert - orpIstWert < 20) dosingTime = 35; if (orpZielwert - orpIstWert < 10) dosingTime = 20; if (orpZielwert - orpIstWert < 5) dosingTime = 10; if (orpZielwert <= orpIstWert) dosingTime = 0; // Chlor-Dosierung starten if (dosingOK && dosingTime > 0 && !getState(idPumpeChlor).val) { setState(idPumpeChlor, true); setTimeout(function(){ setState(idPumpeChlor, false); }, dosingTime * 1000); } }, 60000); // alle 1 Minuten } // Skriptstart if(getState(idDosingAuto).val) Dosierung(); on(idDosingAuto, function(dp) { if(dp.state.val) { Dosierung(); } else { if(timer) clearInterval(timer); setState(idPumpeChlor, false); } }); // Dosierung wird nach 2 Minuten freigegeben on(idPoolPumpe, function(dp) { if(dp.state.val) { setTimeout(function() { dosingOK = true; }, 120000); } else { dosingOK = false; setState(idPumpeChlor, false); } }); // Check, ob die Tagesdosierung Chlor noch nicht überschritten if (chlor_time >= maxTimeChlor) { log('Tagesmenge Chlor erreicht -> keine Dosierung'); dosingOK = false; setState(idDayTimeChlorOver, true); } // Fortschreibung Tagesdosierung Chlor chlor_time += dosingTime; setState(idDayTimeChlor, chlor_time); // Reset der TagesCounter bei einem Datumswechsel schedule ("30 0 0 * * *", function() { // 30 s nach Mitternacht // Reset Kennzeichen Tagesmenge überschritten setState(idDayTimeChlorOver, false); chlor_time = 0; setState(idDayTimeChlor, chlor_time); });
-
Die Teile "Fortschreibung Tagesdosierung Chlor" und "Check, ob die Tagesdosierung Chlor noch nicht überschritten" müssen innerhalb des Intervalls ausgeführt werden (in dieser Reihenfolge).
if (orpZielwert <= orpIstWert) dosingTime = 0; // Fortschreibung Tagesdosierung Chlor chlor_time += dosingTime; // Check, ob die Tagesdosierung Chlor noch nicht überschritten if (chlor_time >= maxTimeChlor) { log('Tagesmenge Chlor erreicht -> keine Dosierung'); dosingTime = 0; setState(idDayTimeChlorOver, true); } else setState(idDayTimeChlor, chlor_time); // Chlor-Dosierung starten
-
So Korrekt ?
// IDS der Elemente IOBroker const idChlorAcidAlternative = "hm-rega.0.Dosierung_Umschaltung_Chlor/Acid"; const idPHWert = "parser.0.Pool-ph"; const idORPWert = "parser.0.Pool-orp"; const idPumpeChlor = "hm-rpc.0.MEQ0454385.1.STATE"; const idPoolPumpe = "hm-rpc.1.NEQ1810472.13.STATE"; const idDosingAuto = "hm-rega.0.25168"; const maxTimeChlor = 80; // Chlor Tagesmenge in sec. const idDayTimeChlor = "hm-rega.0.Chor_Zeit_Tagesmenge"; // Tagesmenge Chlor ????????????????? // Zielwerte const idPHZielwert = "8,1"; const orpZielwert = 850; // interne Variablen var timer; var acid; var dosingOK = false; setTimeout(function() { dosingOK = getState(idPoolPumpe).val; }, 120000); // Umschaltung Chlor / Acid im Wechsel function Dosierung() { acid = false; setState(idChlorAcidAlternative, "chlor"); timer = setInterval(function() { acid = !acid; if(acid) setState(idChlorAcidAlternative, "acid"); else setState(idChlorAcidAlternative, "chlor"); // DosingTime abhängig von ORP-Differenz festlegen var orpIstWert = parseFloat(getState(idORPWert).val); // parseFloat, falls ORPWert ein String ist var dosingTime = 80; if (orpZielwert - orpIstWert < 100) dosingTime =60; if (orpZielwert - orpIstWert < 60) dosingTime = 50; if (orpZielwert - orpIstWert < 40) dosingTime = 45; if (orpZielwert - orpIstWert < 20) dosingTime = 35; if (orpZielwert - orpIstWert < 10) dosingTime = 20; if (orpZielwert - orpIstWert < 5) dosingTime = 10; if (orpZielwert <= orpIstWert) dosingTime = 0; // Fortschreibung Tagesdosierung Chlor chlor_time += dosingTime; // Check, ob die Tagesdosierung Chlor noch nicht überschritten if (chlor_time >= maxTimeChlor) { log('Tagesmenge Chlor erreicht -> keine Dosierung'); dosingTime = 0; setState(idDayTimeChlorOver, true); } else setState(idDayTimeChlor, chlor_time); // Chlor-Dosierung starten if (dosingOK && dosingTime > 0 && !getState(idPumpeChlor).val) { setState(idPumpeChlor, true); setTimeout(function(){ setState(idPumpeChlor, false); }, dosingTime * 1000); } }, 60000); // alle 1 Minuten } // Skriptstart if(getState(idDosingAuto).val) Dosierung(); on(idDosingAuto, function(dp) { if(dp.state.val) { Dosierung(); } else { if(timer) clearInterval(timer); setState(idPumpeChlor, false); } }); // Dosierung wird nach 2 Minuten freigegeben on(idPoolPumpe, function(dp) { if(dp.state.val) { setTimeout(function() { dosingOK = true; }, 120000); } else { dosingOK = false; setState(idPumpeChlor, false); } }); // Reset der TagesCounter bei einem Datumswechsel schedule ("30 0 0 * * *", function() { // 30 s nach Mitternacht // Reset Kennzeichen Tagesmenge überschritten setState(idDayTimeChlorOver, false); chlor_time = 0; setState(idDayTimeChlor, chlor_time); });
-
idDayTimeChlorOver ist nicht deklariert !
@kasperfunsurfer:So Korrekt ? `
Teste es. -
Läuft leider nicht.
Folgende Meldung: 22:46:01.805 [error] javascript.0 at Object. (script.js.Skript1ändern:46:7)
Anbei nochmal das Script.
// IDS der Elemente IOBroker const idChlorAcidAlternative = "hm-rega.0.Dosierung_Umschaltung_Chlor/Acid"; const idPHWert = "parser.0.Pool-ph"; const idORPWert = "parser.0.Pool-orp"; const idPumpeChlor = "hm-rpc.0.MEQ0454385.1.STATE"; const idPoolPumpe = "hm-rpc.1.NEQ1810472.13.STATE"; const idDosingAuto = "hm-rega.0.25168"; const idDayTimeChlor = "hm-rega.0.Chor_Zeit_Tagesmenge"; // Tagesmenge Chlor const idDayTimeChlorOver = "hm-rega.0.25721"; // Maximale Tagesmenge Chlor ereicht // Zielwerte const idPHZielwert = "8,1"; const orpZielwert = 850; const maxTimeChlor = 80; // Chlor Tagesmenge in sec. // interne Variablen var timer; var acid; var dosingOK = false; setTimeout(function() { dosingOK = getState(idPoolPumpe).val; }, 120000); // Umschaltung Chlor / Acid im Wechsel function Dosierung() { acid = false; setState(idChlorAcidAlternative, "chlor"); timer = setInterval(function() { acid = !acid; if(acid) setState(idChlorAcidAlternative, "acid"); else setState(idChlorAcidAlternative, "chlor"); // DosingTime abhängig von ORP-Differenz festlegen var orpIstWert = parseFloat(getState(idORPWert).val); // parseFloat, falls ORPWert ein String ist var dosingTime = 80; if (orpZielwert - orpIstWert < 100) dosingTime =60; if (orpZielwert - orpIstWert < 60) dosingTime = 50; if (orpZielwert - orpIstWert < 40) dosingTime = 45; if (orpZielwert - orpIstWert < 20) dosingTime = 35; if (orpZielwert - orpIstWert < 10) dosingTime = 20; if (orpZielwert - orpIstWert < 5) dosingTime = 10; if (orpZielwert <= orpIstWert) dosingTime = 0; // Fortschreibung Tagesdosierung Chlor chlor_time += dosingTime; // Check, ob die Tagesdosierung Chlor noch nicht überschritten if (chlor_time >= maxTimeChlor) { log('Tagesmenge Chlor erreicht -> keine Dosierung'); dosingTime = 0; setState(idDayTimeChlorOver, true); } else setState(idDayTimeChlor, chlor_time); // Chlor-Dosierung starten if (dosingOK && dosingTime > 0 && !getState(idPumpeChlor).val) { setState(idPumpeChlor, true); setTimeout(function(){ setState(idPumpeChlor, false); }, dosingTime * 1000); } }, 60000); // alle 1 Minuten } // Skriptstart if(getState(idDosingAuto).val) Dosierung(); on(idDosingAuto, function(dp) { if(dp.state.val) { Dosierung(); } else { if(timer) clearInterval(timer); setState(idPumpeChlor, false); } }); // Dosierung wird nach 2 Minuten freigegeben on(idPoolPumpe, function(dp) { if(dp.state.val) { setTimeout(function() { dosingOK = true; }, 120000); } else { dosingOK = false; setState(idPumpeChlor, false); } }); // Reset der TagesCounter bei einem Datumswechsel schedule ("30 0 0 * * *", function() { // Reset Kennzeichen Tagesmenge überschritten setState(idDayTimeChlorOver, false); chlor_time = 0; setState(idDayTimeChlor, chlor_time); });
-
chlor_time ist nicht deklariert. Unter "interne Variablen" ergänzen:
var chlor_time = getState(idDayTimeChlor).val;
-
Guten Morgen,
jetzt läuft es soweit. Das Problem ist jetzt nur das idDayTimeChlor immer hochzählt. Sprich beim Wechsel von Acid auf Chlor wird Zeit Addiert ohne das die Pumpe läuft.
-
Guten Morgen,
jetzt läuft es soweit. Das Problem ist jetzt nur das idDayTimeChlor immer hochzählt. Sprich beim Wechsel von Acid auf Chlor wird Zeit Addiert ohne das die Pumpe läuft. `
habe schon selber rausgefunden die reinfolge war nicht richtig.
// Chlor-Dosierung starten if (dosingOK && dosingTime > 0 && !getState(idPumpeChlor).val) { setState(idPumpeChlor, true); // Fortschreibung Tagesdosierung Chlor chlor_time += dosingTime; // Dosierung starten und Timer setzen setTimeout(function(){ setState(idPumpeChlor, false); }, dosingTime * 1000); } }, 60000); // alle 1 Minuten }
-
Kann ich das so einfügen oder sollte man da noch was ändern ?
Und von der Reinfolge her nach // Skriptstart ?
const idPoolPumpeAuto = "hm-rega.0.19785"; // Abfrage Pool Auto/Hand const idStoerung = "hm-rega.0.25719"; //Dosierung ist noch nicht abgeschaltet??? if ((getState(idPumpeChlor).val === true) || (getState(idPumpePH).val === true)) { log('Dosierung läuft noch?'); if (getState(idStoerung).val === false) { setState(idStoerung, true); } return; } // Check, ob Pumpe im Automatik Betrieb if (getState(idPoolPumpeAuto).val === false) { log('PoolPumpe nicht im Automatik Betrieb -> keine Dosierung'); dosingOK = false; return; }
-
Die Störung wurde im letzten Skript noch nicht gesetzt. Anstelle der Abfrage, schalte besser die Pumpen zusammen mit der Störung ab.
if(Bedingung1 || Bedingung2 || Bedingung3) { dosingTime = 0; setState(idStörung, true); setState(idPumpeChlor, false); setState(idPumpePH, false); } else setState(idStörung, false);
Den Automatikbetrieb der Poolpumpe checke, wenn die Poolpumpe schaltet.
// Dosierung wird nach 2 Minuten freigegeben on(idPoolPumpe, function(dp) { if(dp.state.val && getState(idPoolPumpeAuto).val) { setTimeout(function() { dosingOK = true; }, 120000); } else { dosingOK = false; setState(idPumpeChlor, false); setState(idPumpePH, false) } });
-
// Dosierung wird nach 2 Minuten freigegeben on(idPoolPumpe, function(dp) { if(dp.state.val && getState(idPoolPumpeAuto).val) { setTimeout(function() { dosingOK = true; }, 120000); } else { dosingOK = false; setState(idPumpeChlor, false); setState(idPumpePH, false) } });
Das klappt leider so nicht. Wenn die Pool Pumpe läuft und später auf Hand geschaltet wird sollte die Dosierung aufhören macht sie so aber nicht.
Müßte das ganz nicht hier rein irgendwie
// Chlor-Dosierung starten if (dosingOK && dosingTime > 0 && !getState(idPumpeChlor).val) { setState(idPumpeChlor, true);
oder
// Skriptstart if(getState(idDosingAuto).val) Dosierung();
-
Wenn die Pool Pumpe läuft und später auf Hand geschaltet wird sollte die Dosierung aufhören macht sie so aber nicht. `
Dann braucht es eine zusätzlichen Trigger.on(idPoolPumpeAuto, function(dp) { if(dp.state.val && getState(idPoolPumpe).val) { dosingOK = true; } else { dosingOK = false; setState(idPumpeChlor, false); setState(idPumpePH, false) } });
Beim Skriptstart muss man beides (Pumpe läuft / Pumpe Auto) berücksichtigen.
var timerPool; var dosingOK = false; if(getState(idPoolPumpeAuto).val;) { timerPool = setTimeout(function() { dosingOK = getState(idPoolPumpe).val; }, 120000); }
Den Timer timerPool stoppen, wenn die Poolpumpe innerhalb der 2 Minuten Verzögerung schaltet.
// Dosierung wird nach 2 Minuten freigegeben on(idPoolPumpe, function(dp) { if(timerPool) clearTimeout(timerPool); if(dp.state.val && getState(idPoolPumpeAuto).val) { timerPool = setTimeout(function() { dosingOK = true; }, 120000); } else { dosingOK = false; setState(idPumpeChlor, false); setState(idPumpePH, false) } });