Navigation

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

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] Heizungsthermostatsteuerung 2.1 - Script

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

      @looxer01:

      @Kugelkopf:

      ap! Stimmt! Wenn externes Logging ausgeschaltet ist gibt es keine Fehler mehr! Sorry für meinen vorschnellen Post! Ich dachte nur, ich warne euch bevor es möglicherweise bei dem ein oder anderen zu Problemen führt! `
      Hi,

      nun habe ich eine Lösung für das Problem womit das externe Logging auch wieder funktioniert - wie vorher.

      Folgender Code muss ausgetauscht werden:

      //        if (!fs.existsSync(LogPath)) {
      //            log("Routine writelog: Logfile nicht gefunden - wird angelegt", "info");
      //            var headerLine= "Datum;Uhrzeit;Raum;Geraete-ID;SollTemp gesetzt;Profil;Global-Parameter;Event;Manuelle Temp;Schedule-Point;Bemerkung";
      //            fs.appendFileSync(LogPath, headerLine + "\n");       // Fuege Satz in Datei ein
      //        }
      
      

      neuer Code:

      fs.readFile(LogPath, 'utf8', function(err,data){
          if (!err){
              // File existiert
              fs.appendFileSync(LogPath, logdate + ";" + logtime + ";" + room + ";" + id + ";" + Form_CurrentSollTemp + ";" + Source_Profil + ";" + Source_GlobalParameter + ";" + Source_ICALEvent + ";" + Form_Source_ManualAdjustment + ";" + Source_SchedulePoint + ";" + Text + "\n");  // Fuege Satz in Datei ein
          }else{
              log("Routine writelog: Logfile nicht gefunden - wird angelegt", "info");
              var headerLine= "Datum;Uhrzeit;Raum;Geraete-ID;SollTemp gesetzt;Profil;Global-Parameter;Event;Manuelle Temp;Schedule-Point;Bemerkung";
              fs.appendFileSync(LogPath, headerLine + "\n");       // Fuege Satz in Datei ein
          }
      });
      
      

      Kommt in die nächste Version

      vG Looxer `

      Vielen Dank! 😃

      1 Reply Last reply Reply Quote 0
      • W
        Wildbill last edited by

        @Beliar_666:

        @looxer01:

        @Beliar_666:

        Wie bekomme ich denn zusätzliche Datenpunkte für ein weiteres Zimmer ins Java? Ich will jetzt quasi einen weiteren Raum hinzufügen, aber die Datenpunkte werden nicht erstellt. `
        Hi,

        gerade gesehen, dass das auch noch offen ist (gibt ja noch einiges)

        Hast du dein Problem lösen können ? Wenn nicht, dann brauche ich am Besten deine Einstellungen.

        vG looxer `

        Nein ist noch nicht gelöst. Welche Einstellungen möchtest Du haben?

        Grüssle `
        Hi,

        neue Räume erschienen bei mir bislang immer erst, wenn ich den Script-Adapter einmal komplett neu gestartet habe. Das neustarten des Skripts hat da nie ausgereicht. Kommt mir irgendwie so vor, als ob der Script-Adapter (und damit auch die Skripte) die neuen Datenpunkte eines neuen Raums/Geräts erst bei einem Adapterneustart mitbekommen.

        Gruss, Jürgen

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

          @Beliar_666:

          Kann jetzt natürlich sein das ich das System irgendwie nicht verstehe, aber für ein Raum hat es so bisher funktioniert. `
          Hi,

          das von dir gesendete Script enthält nicht alle Einstellungen und dafür ist die "RoomList" Tabelle doppelt.

          Ich denke, dass das nur ein Kopierfehler ist ?

          Ich nehme mal an, dass du ausschliesslich HM Geräte hast.

          Da du die UseRoomList Variable auf true hast, nimmt das Script nur die dort gelisteten Räume.

          Du hast jetzt 2 Möglichkeiten,

          1. du setzt die Variable UseRoomList auf false. Damit werden alle Geräte aller Räume eingelesen (für HM Geräte)

          2. du erweiterst die Tabelle UseRoomList mit den Räumen, die du haben willst (Gross-und Kleinschreibung beachten)

          Das sollte es gewesen sein.

          vG Looxer

          1 Reply Last reply Reply Quote 0
          • Beliar_666
            Beliar_666 last edited by

            hier stand Blödsinn

            1 Reply Last reply Reply Quote 0
            • Beliar_666
              Beliar_666 last edited by

              @looxer01:

              Hi,

              das von dir gesendete Script enthält nicht alle Einstellungen und dafür ist die "RoomList" Tabelle doppelt.

              Ich denke, dass das nur ein Kopierfehler ist ?

              Ich nehme mal an, dass du ausschliesslich HM Geräte hast.

              Da du die UseRoomList Variable auf true hast, nimmt das Script nur die dort gelisteten Räume.

              Du hast jetzt 2 Möglichkeiten,

              1. du setzt die Variable UseRoomList auf false. Damit werden alle Geräte aller Räume eingelesen (für HM Geräte)

              2. du erweiterst die Tabelle UseRoomList mit den Räumen, die du haben willst (Gross-und Kleinschreibung beachten)

              Das sollte es gewesen sein.

              vG Looxer `

              Anbei jetzt das komplette Script. In dieser Roomlist sind 2 Räume eingetragen. Kinderzimmer_2 habe ich nachträglich hinzugefügt. Aber Datenpunkte werden hierfür keine erstellt. Und das sollte das Script doch machen, oder hab ich da noch irgendwas vergessen?
              9141_heizungsscript.txt

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

                @Beliar_666:

                n dieser Roomlist sind 2 Räume eingetragen. Kinderzimmer_2 habe ich nachträglich hinzugefügt. Aber Datenpunkte werden hierfür keine erstellt. Und das sollte das Script doch machen, oder hab ich da noch irgendwas vergessen? `
                das script zeigt eine Liste von gefundenen Sensoren - dann wenn es aufgerufen wird.

                Wenn das Kinderzimmer_2 nicht dabei ist, dann wurde nichts gefunden.

                Überprüfe mal die Gewerke und Raumzuordnungen in der CCU bzw in inBroker.

                in ioBroker kannst du das an zwei Stellen tun:

                1. Aufzaehlungen

                2. bei den Objekten für die entsprechenden Thermostate.

                Gibt es irgendwelche Fehlermeldungen ?

                Auch könntest du debug = true setzen. Dann gibt es mehr Meldungen.

                vG Looxer

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

                  @dav71701:

                  Hallo Max,

                  hast Du eine Lösung für das Delay Problem gefunden? Bei mir ist es genauso, habe auch die HM-CC-RT-DN in Verbindung mit den Xiaomi Aqara Sensoren im Einsatz, was auch bis auf das "Delay nach Verschluss" alles super funktioniert (auch von mir ein großes Dankeschön in die Entwickler!).

                  Wäre so wie Du auch sehr an eine Lösung interessiert. `

                  Hi,

                  ich habe jetzt die Delay Funktion komplett überarbeitet und auch für Nicht-HM Thermostate implementiert.

                  Hast du oder sonst jemand Zeit zum Testen ?

                  vG Looxer

                  1 Reply Last reply Reply Quote 0
                  • AxelF1977
                    AxelF1977 last edited by

                    looxer, ich habe da auch noch was, was nicht funktioniert, 1. ist sicherlich recht speziell.

                    1. Ich habe im Badezimmer eine Dachlöucke, welche über den Rolladenaktor HM-LC-Bl1PBU-FM gesteuert wird. Da dieser Werte von 0% - 100% zurück gibt, und kein State, lasse ich in den Ordner per Blockly ein State erzeuge, was true und false hat, um die Heizkörper bisher zu steuer. Also Fenster auf und zu.

                    Ich habe probiert diesen Datenpunkt wie die anderen einzubinden, die enum Werte sind entsprechend. So habe ich probiert den Taster in das Script einzubinden.

                    SensorTypeTab[9] = ['hm-rpc.2.',  'HM-LC-Bl1PBU-FM',        'Dachlucke' ,                  'HM',    '1.STATE' ,        false,         false,                 true    ]; //Dachlucke Taster
                    

                    Leider läuft es nicht [EDIT, läuft jetzt]

                    2. Ich nutze Direktverknüpfungen über die CCU für Wand thermostate und Heizungsthermostate, sowie zwiswchen den Verschlüssen und den Thermostate. Gerade bin ich im Script über folgenden Hinweis gestolpert "Wenn mit Direktverbindungen gearbeitet wird dann MUSS zentrale Steuerung auf true stehen"

                    Wo stelle ich das ein? Im Script, CCU?

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

                      @AxelF1977:

                      1. Ich habe im Badezimmer eine Dachlöucke, welche über den Rolladenaktor HM-LC-Bl1PBU-FM gesteuert wird. Da dieser Werte von 0% - 100% zurück gibt, und kein State, lasse ich in den Ordner per Blockly ein State erzeuge, was true und false hat, um die Heizkörper bisher zu steuer. Also Fenster auf und zu.

                      Ich habe probiert diesen Datenpunkt wie die anderen einzubinden, die enum Werte sind entsprechend. So habe ich probiert den Taster in das Script einzubinden. `
                      Hi,

                      In der Sensor Tabelle kannst du auch einen Wert bei geschlossen eintragen . also null oder 100 je nachdem wie die Definition des Aktors ist.

                      Damit sollte also der "Geschlossen-Zustand" funktionieren.

                      @AxelF1977:

                      looxer, ich habe da auch noch was, was nicht funktioniert, 1. ist sicherlich recht speziell.

                      1. Ich habe im Badezimmer eine Dachlöucke, welche über den Rolladenaktor HM-LC-Bl1PBU-FM gesteuert wird. Da dieser Werte von 0% - 100% zurück gibt, und kein State, lasse ich in den Ordner per Blockly ein State erzeuge, was true und false hat, um die Heizkörper bisher zu steuer. Also Fenster auf und zu.

                      Ich habe probiert diesen Datenpunkt wie die anderen einzubinden, die enum Werte sind entsprechend. So habe ich probiert den Taster in das Script einzubinden.

                      SensorTypeTab[9] = ['hm-rpc.2.',  'HM-LC-Bl1PBU-FM',        'Dachlucke' ,                  'HM',    '1.STATE' ,        false,         false,                 true    ]; //Dachlucke Taster
                      

                      Leider läuft es nicht [EDIT, läuft jetzt]

                      2. Ich nutze Direktverknüpfungen über die CCU für Wand thermostate und Heizungsthermostate, sowie zwiswchen den Verschlüssen und den Thermostate. Gerade bin ich im Script über folgenden Hinweis gestolpert "Wenn mit Direktverbindungen gearbeitet wird dann MUSS zentrale Steuerung auf true stehen"

                      Wo stelle ich das ein? Im Script, CCU? `

                      Das ist im Script in der ThermostabTypeTab die Nummer 7

                      vG Looxer

                      1 Reply Last reply Reply Quote 0
                      • Beliar_666
                        Beliar_666 last edited by

                        Zu meinem Problem: Es war mal wieder was ganz banales. Es fehlte tatsächlich das Gewerk. Jetzt sind die Datenpunkte vorhanden. Muss ich jetzt für jeden Raum einen eigenen View anlegen?

                        @looxer01:

                        Das ist im Script in der ThermostabTypeTab die Nummer 7 `
                        Gilt das jetzt nur für Wandthermostate die mit Heizungsthermostaten Verknüpft sind, oder muss das true auch gesetzt werden, wenn nur Fenstersensoren direkt in der CCU mit den Thermostaten verknüpft sind?

                        Und noch eine Frage, vielleicht eine dumme, aber woher weiss ich ob mein Thermostat die verschiedenen Punkte der Thermostattabelle unterstützt oder nicht? Z.B. : 6. und 9. ?

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

                          @Beliar_666:

                          s fehlte tatsächlich das Gewerk. Jetzt sind die Datenpunkte vorhanden. Muss ich jetzt für jeden Raum einen eigenen View anlegen? `
                          Hi,

                          ja, sonst laesst sich das Ganze nicht steuern.
                          @Beliar_666:

                          looxer01 hat geschrieben: ↑

                          04.12.2018, 19:26

                          Das ist im Script in der ThermostabTypeTab die Nummer 7

                          Gilt das jetzt nur für Wandthermostate die mit Heizungsthermostaten Verknüpft sind, oder muss das true auch gesetzt werden, wenn nur Fenstersensoren direkt in der CCU mit den Thermostaten verknüpft sind? `
                          das gilt für diesen Fall für die Wandthermostate mit den Heizungsthermostaten.

                          für die Sensortabelle gibt es das aber auch. Das sind dann die Verknüpfungen zu den Thermostaten

                          @Beliar_666:

                          woher weiss ich ob mein Thermostat die verschiedenen Punkte der Thermostattabelle unterstützt oder nicht? Z.B. : 6. und 9. ? `
                          Die Voreinstellungen sind ja schon passend.

                          zu 6: wenn die entsprechenden datenpunkte da sind, da wird das ja auch unterstützt

                          zu 7. HM Geräte (Wandthermostate und Heizungsthermostate) lassen sich i.d.R. ja verknüpfen.

                          vG Looxer

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

                            Hi,

                            Eric hat mich gerade informiert, dass der ICAL Adapter erweitert wurde.

                            Damit hat sich auch der Datenpunkt geändert. Ihr müsst also in den Einstellungen den Pfad ändern.

                            alt:

                            var ICALPath                = "ical.0.events";             // Pfad zu den ICAL events zur Profilauswahl
                            
                            

                            neu:

                            var ICALPath                = "ical.0.events.0.now"; // Pfad zu den ICAL events zur Profilauswahl
                            
                            

                            Ich habe es beu mir schon für die neue Version eingestellt.

                            Für alle die also ICAL nutzen: bitte den Pfad in den Einstellungen korrigieren.

                            vG Looxer

                            1 Reply Last reply Reply Quote 0
                            • eric2905
                              eric2905 last edited by

                              Hi,

                              @looxer01:

                              Hi,

                              Eric hat mich gerade informiert, dass der ICAL Adapter erweitert wurde.

                              Damit hat sich auch der Datenpunkt geändert. Ihr müsst also in den Einstellungen den Pfad ändern.

                              ….

                              Ich habe es beu mir schon für die neue Version eingestellt.

                              Für alle die also ICAL nutzen: bitte den Pfad in den Einstellungen korrigieren. `
                              Achtung - gilt erst ab der iCal-Version 1.7.0, die momentan noch im Latest-Repository liegt.

                              Also nur wer den iCal v1.7 nutzt sollte (muss) das ändern!

                              Gruß,

                              Eric

                              Von unterwegs getippert

                              1 Reply Last reply Reply Quote 0
                              • D
                                dav71701 last edited by

                                @looxer01:

                                @dav71701:

                                Hallo Max,

                                hast Du eine Lösung für das Delay Problem gefunden? Bei mir ist es genauso, habe auch die HM-CC-RT-DN in Verbindung mit den Xiaomi Aqara Sensoren im Einsatz, was auch bis auf das "Delay nach Verschluss" alles super funktioniert (auch von mir ein großes Dankeschön in die Entwickler!).

                                Wäre so wie Du auch sehr an eine Lösung interessiert. `

                                Hi,

                                ich habe jetzt die Delay Funktion komplett überarbeitet und auch für Nicht-HM Thermostate implementiert.

                                Hast du oder sonst jemand Zeit zum Testen ?

                                vG Looxer `

                                Mach ich gerne wenn du mir das Skript zur Verfügung stellst, kann aber den Teil in Verbindung mit Xiaomi Aqara Sensoren testen.

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

                                  @dav71701:

                                  Mach ich gerne wenn du mir das Skript zur Verfügung stellst, kann aber den Teil in Verbindung mit Xiaomi Aqara Sensoren testen. `
                                  Hi,

                                  super, dann mal anbei das Script als temporäre Version.

                                  Zur Erklärung was die Delay Funktion macht.

                                  Wenn eine FensterGeschlossen Situation erkannt wird, und das Thermostat einen delay von 1.5 hat (oder was auch immer) dann werden alle Aenderungen wie z.B. manuelle Aenderungen, Plan-Aenderungen etc ignoriert. Nach Ablauf der 90 Sekunden findet dann ein erneuter Programmstart für den entsprechenden Raum statt. Somit wartet das Thermostag 90 Sekunden bis weitere Aenderungen akzeptiert werden.

                                  Das habe ich mal eingebaut weil die alten Thermostate HM-CC-TC sehr langsam auf eine FensterGeschlossen Situation reagiert haben. Somit wurde eine falsche Temperatur vom Thermostat eingestellt, die dann vom Script als manuelle Aenderung interpretiert wurde.

                                  Das ist eine Besonderheit bei diesen Thermostaten.

                                  Deinen Fall kenne ich nicht so genau. Ich hoffe, dass du dein Problem jedenfalls damit lösen kannst.

                                  vG Looxer

                                  305_heizungsscript_201_temp.txt

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

                                    @frostnatt:

                                    Die Logik müsste überschaubar sein, auch wenn die Lesbarkeit des Codes nicht die beste ist (ich bin kein ITler).

                                    Es passiert leider nichts, die Profile werden nicht aktiviert. Ich habe versucht zu debuggen (wie ich halt kann :oops: )und muste feststellen dass AktivesEventProfil-Datenpunkt nicht beschrieben wird.

                                    Könntest du bei Gelegenheit den Code überfliegen? Vielleich fällt dir irgendwas ein… `
                                    Hi Max,

                                    kurze Frage und auch um die Funktionalität möglichst einfach zu halten.

                                    Wenn von hinten nach vorne gelesen wird und das erste aktive profil selektiert wird, dann sollte deine Anforderung doch erfüllt sein ?

                                    Mit anderen Worten:

                                    • Profil_1 aktiv und ausschliesslich - dann wird Profil_1 selektiert

                                    • Profil_2 aktiv und ausschliesslich - dann wird Profil_2 selektiert

                                    • Profil_1 und Profil-2 aktiv - dann wird Profil_2 selektiert

                                    Das dürfte vom coding relativ einfach sein und braucht keine weiteren Einstellungen (ich weiss - war meine Idee :oops: )

                                    vG Looxer

                                    EDIT

                                    würde dann so aussehen - habs aber noch nicht getestet

                                        // Globales Profil ist prio2
                                        if (UseEventsGlobalProfilSelect === true) {
                                          for (i = MaxProfile; i > 0; i--) {
                                            ProfilName = UseEventG_Profil;
                                            ProfilName = UseEventG_Profil.replace("<profilnummer>", i);
                                            if (getState(ICALPath + "." + ProfilName).val) {
                                                setOwnState(pathprofile+".AktivesEventProfil", i);
                                                Source_Profil = i;
                                                Source_ICALEvent = ProfilName;
                                                return i;
                                            }
                                          } // ende for i
                                        } // ende if globalProfilSelect</profilnummer> 
                                    
                                    1 Reply Last reply Reply Quote 0
                                    • D
                                      dav71701 last edited by

                                      @looxer01:

                                      @dav71701:

                                      Mach ich gerne wenn du mir das Skript zur Verfügung stellst, kann aber den Teil in Verbindung mit Xiaomi Aqara Sensoren testen. `
                                      Hi,

                                      super, dann mal anbei das Script als temporäre Version.

                                      Zur Erklärung was die Delay Funktion macht.

                                      Wenn eine FensterGeschlossen Situation erkannt wird, und das Thermostat einen delay von 1.5 hat (oder was auch immer) dann werden alle Aenderungen wie z.B. manuelle Aenderungen, Plan-Aenderungen etc ignoriert. Nach Ablauf der 90 Sekunden findet dann ein erneuter Programmstart für den entsprechenden Raum statt. Somit wartet das Thermostag 90 Sekunden bis weitere Aenderungen akzeptiert werden.

                                      Das habe ich mal eingebaut weil die alten Thermostate HM-CC-TC sehr langsam auf eine FensterGeschlossen Situation reagiert haben. Somit wurde eine falsche Temperatur vom Thermostat eingestellt, die dann vom Script als manuelle Aenderung interpretiert wurde.

                                      Das ist eine Besonderheit bei diesen Thermostaten.

                                      Deinen Fall kenne ich nicht so genau. Ich hoffe, dass du dein Problem jedenfalls damit lösen kannst.

                                      vG Looxer

                                      heizungsscript_201_TEMP.txt `

                                      Hi,

                                      hier kurz mein IST-Zustand vor dem Test:

                                       var ThermostatTypeTab = [];
                                      //                      0.RPC-Pfad       1.GeraeteType      2\. Beschreibung,           3\. Type   4.DP-SollTemp        5.nicht verwendet  ID 6.DP MANU/AUTO Schaltung    7.Steuerung DV       8\. IstTemp                  9-Check-MANU-Mode       10-Ventilstellung wenn nicht Heizperiode    11\. Delay nach Verschluss zu
                                      ThermostatTypeTab[2]  = ['hm-rpc.0.',  'HM-CC-RT-DN'     , 'Heizkoerperthermostat(neu)' ,'HT',   '4.SET_TEMPERATURE'      ,   false,        '4.MANU_MODE',              false,                 '4.ACTUAL_TEMPERATURE',      '4.CONTROL_MODE',           12,                                            0];
                                      
                                      und 
                                      
                                      // Typen-Tabelle der Verschlusssensoren fuer Homematic Geräte
                                      // 6 = Verschlussstatus = false ist gechlossen
                                      var SensorTypeTab = [];
                                      //                   0.RPC-Pfad    1.GeraeteType        2\. Beschreibung,              3.Type     4.DP Status   5.nicht verwendet  6\. Verschlussstatus    7\. direktverknuepft
                                      SensorTypeTab[1] = ['hm-rpc.0.',  'HM-Sec-SC'  ,        'Fenstersensor (alt)' ,         'HM',    '1.STATE' ,        false,         false,                 false   ];
                                      SensorTypeTab[2] = ['hm-rpc.0.',  'HM-Sec-RHS' ,        'Fenster-Drehgriffkontakt',     'HM',    '1.STATE' ,        false,         0,                     true    ];
                                      SensorTypeTab[3] = ['hm-rpc.0.',  'HM-Sec-SC-2',        'Fenstersensor-2 (alt)' ,       'HM',    '1.STATE' ,        false,         false,                 true    ];
                                      
                                      Xioami Sensoren werden per CUX eingebunden und als HM-Sec-SC Sensor simuliert
                                      
                                      2018-12-05 16:46:28.141 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorStatCalc: Sensorstatus ist true fuer devtype = HM-Sec-SC und id hm-rpc.1.CUX9001002.1.STATE
                                      2018-12-05 16:46:28.141 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Fenster hm-rpc.1.CUX9001002.1.STATE status geaendert fuer hm-rpc.1.CUX9001002.1.STATE Büro true
                                      2018-12-05 16:46:28.141 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Raum Büro
                                      2018-12-05 16:46:28.141 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Sensor ist direktverknuepft ? false
                                      2018-12-05 16:46:28.141 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Sensor status ist ? true
                                      2018-12-05 16:46:28.141 - info: javascript.0 script.js.common.Heizungssteuerung: Routine LoopDevices: Sensorstatus fuer raum Büro ist true
                                      2018-12-05 16:46:28.142 - info: javascript.0 script.js.common.Heizungssteuerung: Setze Büro.Source_Global_Parameter zu Absenkung - Verschluss geoeffnet
                                      2018-12-05 16:46:28.142 - info: javascript.0 script.js.common.Heizungssteuerung: Routine LoopDevices:Absenkung - Verschluss geoeffnet
                                      
                                      Es funktionierte - bis auf das Delay nach Fensteröffnung - alles.
                                      
                                      

                                      Test mit "heizungsscript_201_TEMP":

                                      Identische Einstellung OHNE Delay! 
                                      
                                      //                      0.RPC-Pfad       1.GeraeteType      2\. Beschreibung,           3\. Type   4.DP-SollTemp        5.nicht verwendet  ID 6.DP MANU/AUTO Schaltung    7.Steuerung DV       8\. IstTemp                  9-Check-MANU-Mode       10-Ventilstellung wenn nicht Heizperiode    11\. Delay nach Verschluss zu
                                      ThermostatTypeTab[2]  = ['hm-rpc.0.',  'HM-CC-RT-DN'     , 'Heizkoerperthermostat(neu)' ,'HT',   '4.SET_TEMPERATURE'      ,   false,        '4.MANU_MODE',              false,                 '4.ACTUAL_TEMPERATURE',      '4.CONTROL_MODE',           12,                                            0];
                                      
                                      // Typen-Tabelle der Verschlusssensoren fuer Homematic Geräte
                                      // 6 = Verschlussstatus = false ist gechlossen
                                      var SensorTypeTab = [];
                                      //                   0.RPC-Pfad    1.GeraeteType        2\. Beschreibung,              3.Type     4.DP Status   5.nicht verwendet  6\. Verschlussstatus    7\. direktverknuepft
                                      SensorTypeTab[0] = ['hm-rpc.0.',  'HM-Sec-SCo' ,        'Fenstersensor (neu)' ,         'HM',    '1.STATE' ,        false,         false,                 true    ];
                                      SensorTypeTab[1] = ['hm-rpc.0.',  'HM-Sec-SC'  ,        'Fenstersensor (alt)' ,         'HM',    '1.STATE' ,        false,         false,                 false   ];
                                      
                                      führt dazu, dass ein offenes Fenster wohl erkannt wird, aber eine Absenkung der Temperatur nicht erfolgt
                                      
                                      018-12-05 17:03:04.080 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorFind ID = hm-rpc.1.CUX9001002.1.STATE Raum = Büro
                                      2018-12-05 17:03:04.080 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorStatCalc: Sensorstatus ist false fuer devtype = HM-Sec-SC und id hm-rpc.1.CUX9001002.1.STATE
                                      2018-12-05 17:03:04.080 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Fenster hm-rpc.1.CUX9001002.1.STATE status geaendert fuer hm-rpc.1.CUX9001002.1.STATE Büro false
                                      2018-12-05 17:03:04.080 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Raum Büro
                                      2018-12-05 17:03:04.080 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Sensor ist direktverknuepft ? false
                                      2018-12-05 17:03:04.080 - info: javascript.0 script.js.common.Heizungssteuerung: Routine SensorChange: Sensor status ist ? false
                                      2018-12-05 17:03:04.081 - info: javascript.0 script.js.common.Heizungssteuerung: loop Devices gestarted fuer Raum Büro
                                      2018-12-05 17:03:04.081 - info: javascript.0 script.js.common.Heizungssteuerung: Routine LoopDevices: Sensorstatus fuer raum Büro ist false
                                      2018-12-05 17:03:04.082 - info: javascript.0 script.js.common.Heizungssteuerung: Routine LoopDevices:
                                      2018-12-05 17:03:04.082 - info: javascript.0 script.js.common.Heizungssteuerung: Setze Büro.Source_Global_Parameter zu
                                      2018-12-05 17:03:04.082 - info: javascript.0 script.js.common.Heizungssteuerung: Routine DetermineSchedule: zu planender Tag ist = Mi Tag fuer den Schedule ist = Sa
                                      2018 
                                      

                                      Bevor ich jetzt diverse Einstellungen ausprobiere kurz die Frage, wie hattest du dir die Einstellung gedacht, wenn man Xioami Sensoren verwendet?

                                      Als Anlage mal mein "altes Skript" und dein "neues Skript" was auf meine Wohnung angepasst ist.
                                      4191_heizungsscript_alt.txt
                                      4191_heizungsscript_201_test.txt

                                      1 Reply Last reply Reply Quote 0
                                      • J
                                        Jango86sn last edited by

                                        Moin moin.

                                        Erstmal vielen Dank für das Skript und der View. Richtig stark gemacht.

                                        Aber leider habe ich folgendes Problem:

                                        immer wenn das Skript nach Schedule durchläuft wird eine manuelle Temperaturanpassung angezeigt obwohl ich keine durchgeführt habe.

                                        Ich verwende Max! Thermostate in Verbindung mit einem CUL-Stick über Fhem.

                                        Das Thermostat habe ich im Skript unter nicht HM-Thermostate hinzugefügt.

                                        Im Log erhalte folgende Meldungen:

                                        javascript.0 2018-12-05 18:22:35.864 info script.js.common.Heizung: Heizungsscript verarbeitung Trigger für Raum all durchgelaufen

                                        javascript.0 2018-12-05 18:22:14.710 info script.js.common.Heizung: Routine ThermostatChange: fhem.0.BZ_Antrieb.desiredTemperature Raum badezimmer Manuelle Solltemperatur-Aenderung erkannt auf 19.0

                                        fhem.0 2018-12-05 18:22:13.511 info event ioBroker "fhem.0.BZ_Antrieb.desiredTemperature 19" > set BZ_Antrieb desiredTemperature 19

                                        javascript.0 2018-12-05 18:22:13.472 info script.js.common.Heizung: Heizungsscript verarbeitung Trigger für Raum badezimmer durchgelaufen

                                        javascript.0 2018-12-05 18:20:24.415 info script.js.common.Heizung: Heizungsscript verarbeitung Trigger für Raum all durchgelaufen

                                        Ich habe das Thermostat dem Gewerk und dem Raum zugeordnet

                                        Vielleicht könnt ihr mir helfen.

                                        Schöne Grüße
                                        11531_2018-12-05_18_37_43-enums_-_iobroker.png
                                        11531_2018-12-05_18_38_15-enums_-_iobroker.png
                                        11531_2018-12-05_18_38_50-javascript_-_iobroker.png
                                        11531_2018-12-05_18_39_14-javascript_-_iobroker.png

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

                                          @Jango86sn:

                                          mmer wenn das Skript nach Schedule durchläuft wird eine manuelle Temperaturanpassung angezeigt obwohl ich keine durchgeführt habe. `
                                          ist es nur die Anzeige oder wird die manuelle Temp auch im View mit Gültigkeit angezeigt ?

                                          vielleicht kannst du mal ein komplettes log zur Verfügung stellen. Dazu debug = true stellen.

                                          vG Looxer

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

                                            @dav71701:

                                            Bevor ich jetzt diverse Einstellungen ausprobiere kurz die Frage, wie hattest du dir die Einstellung gedacht, wenn man Xioami Sensoren verwendet? `
                                            Hi,

                                            also also CUXD Geräte werden die Sensoren wie HM Sensoren erkannt. Damit ist deine Einstellung ok

                                            Kannst du mal beschreiben wofür du den Delay brauchst ?

                                            vG Looxer

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            795
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            climate heating javascript template
                                            115
                                            1127
                                            353623
                                            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