NEWS
[Vorlage] Anwesenheitssimulation - Script
-
Mein Programm? Das ist doch deins.
Hier der obere Teil von meinen Einstellungen.
//..........Anwesenheitssimulation AWS //..........Initiales Datum: 28.12.2015 //..........Autor: Looxer01 //..........Forum ioBroker //..........https://forum.iobroker.net/topic/1671/vorlage-anwesenheitssimulation-script //..........Version 1.00 25.07.2024. Script modernisiert // // Das Script wird aktiviert, wenn das Flag "Anwesenheitssteuerung gesetzt wird" // Funktionsweise ist im Forum unter dem o.g. Link erklärt. // HIER Einstellungen vornehmen............................................................................................ /* List of Keywords "sunrise": sunrise (top edge of the sun appears on the horizon) "sunriseEnd": sunrise ends (bottom edge of the sun touches the horizon) "goldenHourEnd":morning golden hour (soft light, best time for photography) ends "solarNoon": solar noon (sun is in the highest position) "goldenHour": evening golden hour starts "sunsetStart": sunset starts (bottom edge of the sun touches the horizon) "sunset": sunset (sun disappears below the horizon, evening civil twilight starts) "dusk": dusk (evening nautical twilight starts) "nauticalDusk": nautical dusk (evening astronomical twilight starts) "night": night starts (dark enough for astronomical observations) "nightEnd": night ends (morning astronomical twilight starts) "nauticalDawn": nautical dawn (morning nautical twilight starts) "dawn": dawn (morning nautical twilight ends, morning civil twilight starts) "nadir": nadir (darkest moment of the night, sun is in the lowest position) */ // Bittte Gross und Kleinschreibung beachten // Einstellungen der Aktivzeiten je IDGruppe von bis /* const Zeiten = { Gruppe1: { von: "goldenHour", bis: "18:30:00" }, Gruppe2: { von: "20:15:00", bis: "23:30:00" }, Gruppe3: { von: "23:30:00", bis: "01:00:00" }, Gruppe4: { von: "20:00:00", bis: "03:00:00" }, Gruppe5: { von: "19:00:00", bis: "23:00:00" } }; */ const Zeiten = { Gruppe1: { von: "sunset", bis: "sunrise" }, /* Gruppe2: { von: "20:15:00", bis: "23:30:00" }, Gruppe3: { von: "23:30:00", bis: "01:00:00" }, Gruppe4: { von: "20:00:00", bis: "03:00:00" }, Gruppe5: { von: "19:00:00", bis: "23:00:00" } */ }; // Einstellungen der zufaelligen Einschaltdauer je IDGruppe von bis const Einschaltdauer = { Gruppe1: { von: 1, bis: 5 }, /* Gruppe2: { von: 10, bis: 30 }, Gruppe3: { von: 5, bis: 10 }, Gruppe4: { von: 5, bis: 10 }, Gruppe5: { von: 10, bis: 30 } */ }; // Maximale Startverzoegerung in Minuten je Gruppe const StartDelay = { Gruppe1: 1, Gruppe2: 5, Gruppe3: 5, Gruppe4: 5, Gruppe5: 0 }; // Check-schedule Einstellungen const CronInterval = { Gruppe1: 1, Gruppe2: 15, Gruppe3: 15, Gruppe4: 5, Gruppe5: 9999 }; // Homematic Geraete je IDGruppe const Geraete = { Gruppe1: [ "javascript.0.TEST.Gruppe11", // Licht Terrassentuere "javascript.0.TEST.Gruppe12", // Licht WZ Esstisch "javascript.0.TEST.Gruppe13", // Licht Flur oben unten; "javascript.0.TEST.Gruppe14", // Licht Kinderbad "javascript.0.TEST.Gruppe15" // Licht Hobbyraum ], /* Gruppe1: [ "hm-rpc.1.00351F298A58E3.3.STATE", // Licht Terrassentuere "hm-rpc.1.0034DF298E7B6C.3.STATE", // Licht WZ Esstisch "hm-rpc.0.JEQ0038530.1.STATE", // Licht Flur oben unten; "hm-rpc.1.0008A0C992F8B6.3.STATE", // Licht Kinderbad "hm-rpc.1.0008A2698B8247.3.STATE" // Licht Hobbyraum ], Gruppe2: [ "hm-rpc.0.JEQ0038535.1.STATE", // Licht Flur oben Wand; "hm-rpc.1.0034DF298E7B6C.3.STATE", // Licht Wohnzimmer Esstisch "hm-rpc.1.00351F298A58E3.3.STATE" // Licht Terrassentuere ], Gruppe3: [ "hm-rpc.0.JEQ0038535.1.STATE", // Licht Flur oben Wand; "hm-rpc.0.JEQ0038530.1.STATE", // Licht Flur oben unten; "hm-rpc.0.JEQ0039785.1.STATE" // Licht Kinderbad ], Gruppe4: [ "hm-rpc.1.0025A0C9A3AD70.18.STATE", // Licht aussen Steinterrasse "hm-rpc.1.0008A0C992F8B6.3.STATE", // Licht Kinderbad "hm-rpc.1.00259F2995EF4B.10.STATE" // Pool Nebenlicht ], Gruppe5: [] */ }; // Experteneinstellungen const Config = { logflag: true, // schreibe aktivitäten in externes LOG ausflag: true, // Wenn AWS deaktiviert wird, dann werden alle Teilnehmer ausgeschaltet IDAWSaktiv: "javascript.0.Anwesenheitssteuerung.AWSAktiv", // AWS wird aktiviert, wenn der Datenpunkt true ist / wird benoetigt z.B. bei Abwesenheit mit automatischer Aktivierung LogPath: "/opt/iobroker/log/AWSLog.csv", // Pfad fuer externes log IgnoreWhenOn: false, // bei true: Ignoriert den Schaltvorgang, wenn das Geraet bereits eingeschaltet war EinschaltFlag: true, // nicht dimmergeraete werden einschalten AusschaltFlag: false, // nicht dimmergeraete werden ausschalten DimmAusschalt: 0, // Dimmer Ausschaltwert DimmEinschalt: 100, // Dimmer Einschaltwert debug: true, // ausführliche Ablaufmeldungen wenn auf true SwitchTimes: [] // nicht aendern }; // Ende der Einstellungen
-
@beowolf
ja, genau. es geht mir um den Einstellungsbereich
War aber nicht in deiner message enthalten
Vermutlich brauch ich auch noch das Log mit "debug" aktiviert -
@looxer01 Ich habe mit der Version 1.0 und 1.1 das Problem, dass die Lichter auch tagsüber angeschalten werden. Die Schaltzeiten habe ich vom alten Script übernommen nicht kopiert sondern eingetragen
Gruppe1: { von: "dusk", bis: "23:45:00" }, Gruppe5: { von: "05:30:00", bis: "sunrise" }
Daten von den Astrowerten sehen wie folgt aus:
Astrokeyword sunrise: Datum: 29:07 ----- Uhrzeit 05:22 Astrokeyword dusk: Datum: 29:07 ----- Uhrzeit 21:47
-
Hm. Jetzt kommen nur diese Meldungen. Die sind soweit ja auch ok.
Mal abwarten. Event. habe ich bei dem ersten Versuch auch etwas bei dem Übertragen der Einstellungen etwas übersehen.
javascript.0 2024-07-29 12:01:16.838 warn script.js.common.Anwesenheitstest: Object "javascript.0.TEST.Gruppe15" does not exist javascript.0 2024-07-29 12:01:16.838 warn script.js.common.Anwesenheitstest: Object "javascript.0.TEST.Gruppe14" does not exist javascript.0 2024-07-29 12:01:16.838 warn script.js.common.Anwesenheitstest: Object "javascript.0.TEST.Gruppe13" does not exist javascript.0 2024-07-29 12:01:16.837 warn script.js.common.Anwesenheitstest: Object "javascript.0.TEST.Gruppe12" does not exist javascript.0 2024-07-29 12:01:16.837 warn script.js.common.Anwesenheitstest: Object "javascript.0.TEST.Gruppe11" does not exist
-
du hast teilweise 5 Gruppen und teilweise nur eine Gruppe definiert.
Das verursacht wahrscheinlich Probleme. Alle Gruppen sollen die gleiche Anzahl von Mitgliedern haben.
In diesem Fall ist startdelay und cronintervall mit 5 Gruppen definiert. Der Rest aber nur mit einerDu solltest auch die letzte Version verwenden.
vG Looxer
// Maximale Startverzoegerung in Minuten je Gruppe const StartDelay = { Gruppe1: 1, Gruppe2: 5, Gruppe3: 5, Gruppe4: 5, Gruppe5: 0 }; // Check-schedule Einstellungen const CronInterval = { Gruppe1: 1, Gruppe2: 15, Gruppe3: 15, Gruppe4: 5, Gruppe5: 9999 };
-
@spike2
Gruppe 5 kann ich erklären
von 5:30 bis 5:22
Da 5:22 kleiner ist als 5:30 wird der nächste Tag angenommen.
Damit geht der schedule von 5:30 heute bis 5:22 morgenDas ist mit Absicht so programmiert. Es kann ja auch einen fall geben von 23:00 bis 03:00.
Da nehme ich halt an, dass 3:00 am nächsten Tag gemeint ist.vG Looxer
-
@looxer01 Ups, ohh man manchmal sieht man das garnicht und sucht komplett wo anders.
Ist mir beim kopieren nicht mal aufgefallen
Danke für den Hinweis -
-
@beowolf
Die Meldungen im externen log sehen ja ok aus.
Es scheint dass die schedules oft kollidieren. Das heißt, dass das Programm eine Schaltung vornehmen möchte und feststellt, dass das Gerät schon eingeschaltet ist.
Es gibt zwei Reaktionen:- lösche die alte Planung und fahre mit der neuen Planung fort (also Gerät bleibt eingeschaltet und schaltet nach neuer Planung aus (IgnoreWhenOn = false)
- Das Programm ignoriert einfach, dass das Gerät eingeschaltet war und setzt also die alte Planung fort
IgnoreWhenOn = true
Wenn es noch Fehlermeldungen vom Javascript Adapter gab, dann synchronisiere bitte alle Gruppen.
ich habe dazu folgendes als Doku in's Programm (nächste Version) geschrieben:
// ACHTUNG: Bei der Einstellung der Gruppen- bzw Gruppenmittlgieder muss darauf geachtet werden, dass all Mitglieder gleich viele Eintragungen haben
// z.B. 5 Guppen in den Zeiten - Einschaltdauer - StartDealy - Cron-Interrvall und Geräte - all müssen die gleiche Anzahl von Zeilen erhalten.
// Zeilen dürfen aber entfernt oder auch hinzugefügt werden, müssen dann aber in allen Einstellungen identisch gehalten werden
// Ebenso müssen die Namen alle mappen: Wenn "Gruppe1" definiert ist, dann müssen alle anderen ebenfalls "Gruppe1" enthaltenScheint, dass du mir eine Testversion der Einstellungen geschickt hast. Im log stehen ja andere Daten.
vG Looxer
-
Hi,
die Funktionalität des Scriptes ist soweit ausentwickelt. (für den Moment)
Ich habe noch ein bischen Sanitäres gemacht im Coding, das Logging verbessert
und eine check routine eingeführt, falls die Gruppen Definitionen inkonsistent eingestellt werden.
Es gibt dann eine harte Fehlermeldung und Programmabbruch.Die Version 1.20 ist hochgeladen und steht im ersten Post zum Download bereit.
vG Looxer