Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Vorlage] Anwesenheitssimulation - Script

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] Anwesenheitssimulation - Script

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

      Hi,

      wie kann man dieses Skript "debuggen"? Ich hab zwei Probleme und keine Ahnung, wo ich schauen muss.

      a) Ich benutze "Anwesenheitsliste aus TR064 bauen" von "Looxer01 01.01.2017". Es wird korrekt ermittelt, welches Handy zuhause an der FB angemeldet ist. Trotzdem springt die AWS an, auch wenn ein Handy in der FB angemeldet ist. Wenn zwei Handys angemeldet sind springt sie nicht an.

      b) Wenn man zurückkommt, zwei Handys in der FB angemeldet sind, geht die Lightshow trotzdem weiter. var ausflag = true; dann sollten doch eigentlich alle "Timer" gelöscht werden. Oder?

      Für jeden Hinweis dankbar.

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

        Ich habe da mal eine Frage.

        In dem Original-Skript steht zwischen den Zeilen 521 bis 548 folgendes:

             // Wenn jetzt noch die VON Zeit kleiner also die BIS Zeit ist muss die BIS Zeit evt auf den nächsten Tag gelegt werden. (oder auch sie ist abgelaufen)
            if (upper < lower) {                                    // Die von Zeit ist groesser als die bis Zeit
                if(astrovonDown) {                                  // im Falle von Astrovon kann es sein, dass die bis Zeit in den nächsten Tag geht
                    if( upper.getHours()  < ErlieastSunDown ) {     // Uewberpruefen ob die BisZeit kleiner als der Schwellwert ist
                        upper.setDate(upper.getDate() + 1);         // 1 Tag (24 Stunden ) addieren da der bis Wert wahrscheinlich am nächsten Tag liegen muss 
                        if (debug) { log("Routine IsTimeInRange - Gruppe"+ Gruppe +" bei Astrovon die zeitbis started Morgen - AstroZeit Sonnenuntergang VON ist "+ lower ,"info");}
                    }
                }
                if(astrovonUp) {                                    // im Falle von Astrovon kann es sein, dass die bis Zeit in den nächsten Tag geht
                    if( upper.getHours()  < EarliestSunUp ) {       // Uewberpruefen ob die BisZeit kleiner als der Schwellwert ist
                        upper.setDate(upper.getDate() + 1);         // 1 Tag (24 Stunden ) addieren da der bis Wert wahrscheinlich am nächsten Tag liegen muss 
                        if (debug) { log("Routine IsTimeInRange - Gruppe"+ Gruppe + " bei Astrovon die zeitbis started Morgen - AstroZeit Sonnenaufgang VON ist "+ lower,"info");}
                    }
                }
        
               if(astrobisDown) {                                   // im Falle von Astrovon kann es sein, dass die bis Zeit in den nächsten Tag geht
                    if( lower.getHours()  > LatestSunDown ) {       // Uewberpruefen ob die vonZeit groesser als der Schwellwert ist
                        upper.setDate(upper.getDate() + 1);         // 1 Tag (24 Stunden ) addieren da der bis Wert wahrscheinlich am nächsten Tag liegen muss 
                        if (debug) { log("Routine IsTimeInRange - Gruppe"+ Gruppe + " bei Astrovon die zeitbis started Morgen - AstroZeit Sonnenuntergang BIS ist "+ upper,"info");}
                    }
                }
                if(astrobisUp) {                                    // im Falle von Astrovon kann es sein, dass die bis Zeit in den nächsten Tag geht
                    if( lower.getHours()  > LatestSunDown ) {       // Uewberpruefen ob die VonZeit groesser als der Schwellwert ist
                        upper.setDate(upper.getDate() + 1);         // 1 Tag (24 Stunden ) addieren da der bis Wert wahrscheinlich am nächsten Tag liegen muss 
                        if (debug) { log("Routine IsTimeInRange - Gruppe"+ Gruppe + " bei Astrovon die zeitbis started Morgen- - AstroZeit Sonnenaufgang BIS  ist "+ upper,"info");}
                    }
                }
        
        

        In Zeile 537 ist diese Variable "LatestSunDown" und in der Zeile 543 steht auch "LatestSunDown".

        Sollte in der Zeile 543 nicht "LatestSunUp" stehen?

        Grüße
        Manfred

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

          @beowolf
          Hi,

          Ist schon ewig her. Habs mir mal angesehen:
          Definitionen:
          astrobisDown = = Astrozeit BIS Sonnenuntergang gesetzt
          astrobisUp = = Astrozeit BIS Sonnenaufgang gesetzt
          Annahme LatestSunDown ist 21:00
          Annahme LatestSunUp ist 08:00

          Ausführung mit Beispielen:
          Vergleich 1:
          bei astrobisDown: Wenn die BIS Zeit auf Sonnenuntergang gesetzt ist und die VONZeit z.B. auf 22:00 gesetzt ist wird 1 Tag addiert, da ja der Sonnenuntergang nicht mehr zu erwarten ist
          Vergleich 2:
          bei astrobisUp: Wenn die BIS Zeit auf Sonnenaufgang gesetzt ist und die VONZeit z.B. auf 09:00 Morgens dann liegt die VON Zeit also nach der BIS Zeit und somit ist der Sonnenaufgang nicht mehr zu erwarten

          Insofern hast du Recht. Ich habs aber nicht getestet.

          vG Looxer

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

            Hat sich erledigt.

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

              Eine Frage noch.

              Wo bekommt das Programm die Astro-Zeit her?

              Es sollte doch eigentlich so funktionieren, das die Simulation dauerhaft eingeschaltet bleibt, aber die entsprechenden Lampen nur in der Zeit von Sonnenuntergang bis Sonnenaufgang geschaltet werden, oder?

              Bei den Zeiten steht dieses hier

              // Bei Eingabe des Keywords bei den Zeiten werden die Astrozeiten verwendet
              // Einstellungen der Aktivzeiten je IDGruppe von bis
              var zeit1von = "SunSet";          //Aktivzeit von IDGruppe1
              var zeit1bis = "SunRise";          //Aktivzeit bis IDGruppe1
              
              var zeit2von = "SunSet";          //Aktivzeit von IDGruppe2
              var zeit2bis = "SunRise";          //Aktivzeit bis IDGruppe2
              
              var zeit3von = "SunSet";          //Aktivzeit von IDGruppe3
              var zeit3bis = "SunRise";          //Aktivzeit bis IDGruppe3
              
              var zeit4von = "SunSet";          //Aktivzeit von IDGruppe4
              var zeit4bis = "SunRise";          //Aktivzeit bis IDGruppe4
              
              var zeit5von = "SunSet";          //Aktivzeit von IDGruppe5
              var zeit5bis = "SunRise";          //Aktivzeit bis IDGruppe5
              
              L 1 Reply Last reply Reply Quote 0
              • L
                looxer01 @Beowolf last edited by looxer01

                @beowolf

                @beowolf sagte in [Vorlage] Anwesenheitssimulation - Script:

                Wo bekommt das Programm die Astro-Zeit her?

                Es ist eine Funktion, die genutzt wird, z.B. getAstroDate(KeyWordSunDown);

                @beowolf sagte in [Vorlage] Anwesenheitssimulation - Script:

                Es sollte doch eigentlich so funktionieren, das die Simulation dauerhaft eingeschaltet bleibt, aber die entsprechenden Lampen nur in der Zeit von Sonnenuntergang bis Sonnenaufgang geschaltet werden, oder?

                Genau. Oder in meinen Worten.
                Bei eingeschalteter Simulation werden Aktionen (z.B. Lampen Schalten)

                • zu zufälligen Zeiten
                • mit zeitlicher Dauer innerhalb der definierten Parameter (maximal und minimal Dauer)
                  ausgeführt,

                wobei die Ausführung nur innerhalb der vorgegebenen von und bis Zeiten geschieht.

                so sollte es zumindest sein.

                vG Looxer

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

                  Ich habe die AWS wiederentdeckt und nutze es jetzt wieder.
                  Mir ist der Adapter zur Aufzeichnung des schaltverhaltens bekannt. Finde ich persönlich aber zu umständlich
                  Der gesamte Code ist nun modernisiert und damit effizienter.
                  Falls also jemand das Programm noch nutzt -

                  vG Looxer

                  T S 2 Replies Last reply Reply Quote 2
                  • T
                    Tontechniker @looxer01 last edited by

                    @looxer01 Wo finde ich die aktuelle Version?

                    L 1 Reply Last reply Reply Quote 1
                    • L
                      looxer01 @Tontechniker last edited by

                      @tontechniker im Ursprungspost ganz unten , innerhalb des spoilers

                      1 Reply Last reply Reply Quote 1
                      • S
                        spike2 @looxer01 last edited by

                        @looxer01 ich nutze das Script ebenfalls schon sein locker einem Jahr und das funktioniert ausgezeichnet. Vielen Dank dafür 🙂

                        Da du es wieder nutzt, dann bitte eine Frage meinerseits.
                        Kann man die Sonnenuntergang und Aufgangszeiten irgendwo anpassen, meist ist es noch hell (ca. 30min später dunkel/ dunkler) und die Lampen leuchten 😉

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

                          @spike2 im Moment nicht. Dafür hatte ich schon immer ein oder 2 Erweiterungen vorgesehen.
                          Mit Schrecken habe ich festgestellt, dass ich das Ursprungsprogramm 2015 erstellt habe: 🤔

                          • Verwendung beliebiger AstroKeywords (z.B. Night)
                          • Verzögerung von x minuten

                          Werde mal schauen, dass ich das demnächst einbaue.

                          vG Looxer

                          S 1 Reply Last reply Reply Quote 0
                          • S
                            spike2 @looxer01 last edited by

                            @looxer01 Mit den AstroKeywords habe ich schon mal vor einer Weile probiert, hat leider nicht ganz so hingehauen.
                            Alternativ könnte man sicherlich die Astrodaten vom Javascript Adapter abfangen, vielleicht so als Idee 🙂

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

                              @spike2 die astrodaten kommen aus dem adapter mit getAstroDate. Nur habe ich nicht alle astro zeiten implementiert. nur sunset und sunrise gehen im Moment. ist eigentlich nur ein check. Mache ich noch

                              S 1 Reply Last reply Reply Quote 0
                              • S
                                spike2 @looxer01 last edited by

                                @looxer01 Ahh okay, dann schonmal Danke dafür 🙂

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

                                  Vielen Dank für die Weiterentwicklung. Es läuft hier seit der ersten Stunde. 😊

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

                                    Hi,
                                    ich habe eine neue Version im ersten post hinterlegt.
                                    In dieser Version kann jedes Astro-Keyword verwendet werden.
                                    wenn debug auf true steht werden alle astrozeiten gelistet. Daran kann man sich ganz gut orientieren.

                                    sieht zur Zeit so aus:
                                    Astrokeyword nadir: Datum: 28:07 ----- Uhrzeit 01:39
                                    Astrokeyword dawn: Datum: 27:07 ----- Uhrzeit 05:09
                                    Astrokeyword nauticalDawn: Datum: 27:07 ----- Uhrzeit 04:13
                                    Astrokeyword nightEnd: Datum: 27:07 ----- Uhrzeit 02:49
                                    Astrokeyword night: Datum: 28:07 ----- Uhrzeit 00:29
                                    Astrokeyword nauticalDusk: Datum: 27:07 ----- Uhrzeit 23:05
                                    Astrokeyword dusk: Datum: 27:07 ----- Uhrzeit 22:08
                                    Astrokeyword sunset: Datum: 27:07 ----- Uhrzeit 21:27
                                    Astrokeyword sunsetStart: Datum: 27:07 ----- Uhrzeit 21:23
                                    Astrokeyword goldenHour: Datum: 27:07 ----- Uhrzeit 20:38
                                    Astrokeyword solarNoon: Datum: 27:07 ----- Uhrzeit 13:39
                                    Astrokeyword goldenHourEnd: Datum: 27:07 ----- Uhrzeit 06:40
                                    Astrokeyword sunriseEnd: Datum: 27:07 ----- Uhrzeit 05:54
                                    Astrokeyword sunrise: Datum: 27:07 ----- Uhrzeit 05:50

                                    vG Looxer

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

                                      Mal ne Frage. Wo kommen diese Astrozeiten her?

                                      z.B. bei der "goldenen Stunde" - Das ist ein Zeitraum von, z.b. heute hier von

                                      05:11 - 06:29 Goldene Stunde am morgen

                                      20:43 - 22:00 Goldene Stunde am abend.

                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword dawn: Datum: 27:07 ----- Uhrzeit 05:02
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword nauticalDawn: Datum: 27:07 ----- Uhrzeit 04:03
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword nightEnd: Datum: 27:07 ----- Uhrzeit 02:25
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword night: Datum: 28:07 ----- Uhrzeit 00:48
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword nauticalDusk: Datum: 27:07 ----- Uhrzeit 23:11
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword dusk: Datum: 27:07 ----- Uhrzeit 22:12
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword sunset: Datum: 27:07 ----- Uhrzeit 21:29
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword sunsetStart: Datum: 27:07 ----- Uhrzeit 21:25
                                       
                                      	2024-07-27 09:20:58.855	info  Astrokeyword goldenHour: Datum: 27:07 ----- Uhrzeit 20:38
                                       
                                      	2024-07-27 09:20:58.854	info  Astrokeyword solarNoon: Datum: 27:07 ----- Uhrzeit 13:37
                                       
                                      	2024-07-27 09:20:58.854	info  Astrokeyword goldenHourEnd: Datum: 27:07 ----- Uhrzeit 06:35
                                       
                                      	2024-07-27 09:20:58.854	info  Astrokeyword sunriseEnd: Datum: 27:07 ----- Uhrzeit 05:49
                                       
                                      	2024-07-27 09:20:58.854	info  Astrokeyword sunrise: Datum: 27:07 ----- Uhrzeit 05:44
                                       
                                      	2024-07-27 09:20:58.854	info  Liste der gegenwärtigen Astrozeiten
                                      

                                      PS
                                      Es gibt auch noch die "Blau Stunde"

                                      Heute ist sie

                                      04:35 - 05:11 Blaue Stunde
                                      22:00 - 22:36 Blaue Stunde

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

                                        @beowolf
                                        Hi,
                                        es gab ja vor einigen Jahren nur ein Script, welches die mathematische Formel zur Astrozeiten-Berechnung enthielt (aufgrund von Längen- und Breitengraden sowie des Datums)
                                        Dieses Script wurde mehr oder weniger innerhalb des Javascript Adapters implementiert und die Funktion getastroDate() bereitgestellt.
                                        2023 wurde dann noch eine Funktion zum update der Astrozeiten einmal täglich bereitgestellt. Die Zeiten sind unter javascript.0.variables.astro zu finden. Da findest du damit auch die Astrokeywords, die ich in die AWS integriert habe.
                                        eine blaue Stunde ist nicht dabei.

                                        vG Looxer

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

                                          Hi,
                                          Version 1.1 ist jetzt hochgeladen mit ein paar weiteren Code Optimierungen aber auch Funktionen

                                          • neben dem debug log kann auch ein minilog aktiviert werden fuer transparenz aber weniger meldungen
                                          • Jetzt werden die schedules nur geplant wenn AWS aktiv ist. Das Programm wird also nicht mehr unnötig durchlaufen, nämlich dann nicht, wenn AWS gar nicht aktiv ist

                                          Habt ihr die neue Version bereits ausprobiert ?

                                          vG Looxer

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

                                            Erster. Ich hab´s probiert und es hat nicht weh getan. 😊

                                            Alles gut. Läuft bis jetzt ohne Probleme. Noch mal vielen Dank für das Skript.

                                            PS.

                                            Doch noch eine Meldung im Log.

                                            javascript.0
                                            	2024-07-29 10:45:00.025	info	script.js.common.Anwesenheitssimulation_NACHTS: AWS-Logging: executeSchedule aufgerufen mit Gruppe3 3 AWSAktiv-Flag = true
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at processTimers (node:internal/timers:512:7)
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at listOnTimeout (node:internal/timers:569:17)
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7)
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15)
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1769:34)
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at Object.<anonymous> (script.js.common.Anwesenheitssimulation_NACHTS:145:29)
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	at executeSchedule (script.js.common.Anwesenheitssimulation_NACHTS:159:42)
                                            javascript.0
                                            	2024-07-29 10:45:00.021	error	Error in callback: TypeError: Cannot read properties of undefined (reading 'von')
                                            

                                            Habe die vorgängerversion wieder aktiviert. Keine Fehlermeldungen mehr.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            990
                                            Online

                                            31.7k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            40
                                            271
                                            51407
                                            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