Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Homematic Master Programmierung: Use Case lernender Thermostat.

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    346

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.6k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.5k

Homematic Master Programmierung: Use Case lernender Thermostat.

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
19 Beiträge 4 Kommentatoren 1.2k Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • M Offline
    M Offline
    Marty56
    schrieb am zuletzt editiert von
    #2

    Mir ist jetzt klar, wie es geht.

    mit sendTo('hm-rpc.0', 'getParamset', {ID: 'xxxxxx', paramType: 'MASTER'}, res => {

    log(JSON.stringify(res));

    });

    Parameter, die das Device hat, ausgeben und analysieren.

    Dann erschließt sich die Funktion aufgrund der Parameter und der gesetzten Werte.

    und dann nach gewünschten Veränderungen mit

    sendTo('hm-rpc.0', 'putParamset', {ID: 'xxxxxxxx', paramType: 'MASTER', params: {'ENDTIME_FRIDAY_1': 700}}, res => {

    log(JSON.stringify(res));

    });

    In dem Beispiel wird das Ende der ersten Heizungsinterval auf die 700te Minute nach Mittagnacht gesetzt.

    Wenn der Wert 1440 ist, dann ist Mitternacht erreicht, damit kommen keine weiteren Zeitperioden für den Tag.

    Entsprechend dieser Perioden kann man die Soll Temperaturen, mit dem Parameter TEMPERATURE_FRIDAY_1, während dieser Periode ermitteln und gegebenfalls auch ändern.

    sendTo('hm-rpc.0', 'putParamset', {ID: 'xxxxxxxx', paramType: 'MASTER', params: {'TEMPERATURE_FRIDAY_1': 21}}, res => {

    log(JSON.stringify(res));

    });

    HW:NUC (16 GB Ram)
    OS: Debian Bullseye, Promox V7, node v16.x npm 8.19.3

    1 Antwort Letzte Antwort
    0
    • foxriver76F Offline
      foxriver76F Offline
      foxriver76
      Developer
      schrieb am zuletzt editiert von
      #3

      Genau, grundsätzlich erst mal das Paramset des Gerätes anschauen. Dann gibts für jeden Wochentag, ich glaube 13 mögliche Zeiteinstellungen. Da musst du dann in deinem Skript das Paramset analysieren und schauen, welches Programm bearbeitet werden soll und das dann mit putParamset auf die gewünschte Temperatur stellen.

      Videotutorials & mehr

      Hier könnt ihr mich unterstützen.

      1 Antwort Letzte Antwort
      0
      • M Offline
        M Offline
        Marty56
        schrieb am zuletzt editiert von
        #4

        Danke!

        Ich habe das Script jetzt fertig.

        Was mir während des Debuggens aufgefallen ist, dass in "res" immer dasselbe steht und man keinerlei Hinweise bekommt, ob der Schreibvorgang erfolgreich war oder nicht. Das wäre ein Punkt, den man noch verbessern, könnte. In meinem Fall hatte ich versucht auf ein Object geschrieben, das nicht vorhanden war.

        HW:NUC (16 GB Ram)
        OS: Debian Bullseye, Promox V7, node v16.x npm 8.19.3

        1 Antwort Letzte Antwort
        0
        • M Offline
          M Offline
          Marty56
          schrieb am zuletzt editiert von
          #5

          Das Script.

          /---- mit Verstellen der Temperatur an Heizung/Thermostat Soll Temperatur verändern ----
          
          on({id:[Wohnzimmer_setTemp,Kinder_setTemp,Schlafzimmer_setTemp,Bad_setTemp ] , change: 'ne'},function(obj) {
          
              var homematic_instance = 'hm-rpc.0';
              var Master;
              var prefix = "";
              var channel;
              var id;
          
              // unterschiedliche Kanäle Heizungsthermostat und Wandthermostat berücksichtigen
              if (obj.id.includes('.2.SET_TEMPERATURE')) {
                  id = obj.id.replace('.2.SET_TEMPERATURE','');
                  channel = '2';
              } else {
                  id = obj.id.replace('.4.SET_TEMPERATURE','');
                  channel = '4';
              }
              id = id.split('.')[2];
          
              // Master Objekt der Heizung in Object Master einlesen 
              sendTo(homematic_instance, 'getParamset', {ID: id, paramType: 'MASTER'}, res => {
                  Master = res.result;
          
                  // im Manu Mode keine Anpassung durchführen
                  if (getState(homematic_instance + '.' + id + '.' + channel + '.CONTROL_MODE').val === 0 ) {
          
                      // Prefix festlegen abhängig vom Kanal
                      if( channel === '2') {prefix = "P" + (Master.WEEK_PROGRAM_POINTER + 1) + "_";}
          
                      //--- Wochentag auf Englisch bestimmen
                      var wochentag = ["SUNDAY","MONDAY","TUESDAY","WEDNESDAY","THURSDAY","FRIDAY","SATURDAY"];
                      var tag = wochentag[new Date().getDay()];
          
                      //--- Minute im Tag bestimmen ----
                      var minute_of_day = Math.round((new Date().getTime() - getDateObject("00:00").getTime())/60000);
          
                      //--- Periode bestimmen -----------
                      var periode = prefix + "ENDTIME_" + tag + "_";
                      for (var i = 1;i<13;i++) {
                          var periodei = periode + i;
                          if (parseInt(Master[periodei]) > minute_of_day) {break;}
                      }
          
                      //--- prüfen ob geänderte Temperatur ungleich der gesetzten Temp ist ---
                      var temp_auto_key = prefix + 'TEMPERATURE_'+ tag + "_" + i;
                      var temp_set  = getState(homematic_instance + '.' + id + '.' + channel + '.SET_TEMPERATURE').val;
                      //log("Gesetzte Temperatur: " + temp_set);
                      //log("Automatische Temperatur" + Master[temp_auto_key]);
                      if (temp_set !== Master[temp_auto_key]) {
          
                          // Temperatur in Homematic Regelung für alle Tage umprogrammieren ------ 
                          for (var d = 0;d < 7;d++) {
                              temp_auto_key = prefix + 'TEMPERATURE_'+ wochentag[d] + "_" + i;
                              var params_obj = {[temp_auto_key]: temp_set.toString()};
                              //log(JSON.stringify(params_obj));
                              sendTo(homematic_instance, 'putParamset', {ID: id, paramType: 'MASTER', params: params_obj}, res => {});
                          }
                          log("manuell gesetzte Temperatur wurde als automatisch gereglte Temperatur dauerhaft für alle Wochentage übernommen");
                      } 
                  }
              });
          }); 
          

          HW:NUC (16 GB Ram)
          OS: Debian Bullseye, Promox V7, node v16.x npm 8.19.3

          1 Antwort Letzte Antwort
          0
          • foxriver76F Offline
            foxriver76F Offline
            foxriver76
            Developer
            schrieb am zuletzt editiert von
            #6

            @Marty56:

            Danke!

            Ich habe das Script jetzt fertig.

            Was mir während des Debuggens aufgefallen ist, dass in "res" immer dasselbe steht und man keinerlei Hinweise bekommt, ob der Schreibvorgang erfolgreich war oder nicht. Das wäre ein Punkt, den man noch verbessern, könnte. In meinem Fall hatte ich versucht auf ein Object geschrieben, das nicht vorhanden war. `

            Doch wenn ein Fehler aufgetreten ist, ist res.error !== null und enthält ein Objekt.

            sendTo('hm-rpc.0', 'getParamset', {ID: 'OEQ1880303', paramType: 'ASTER'}, res => {
                log(JSON.stringify(res));
                if(res.error) log('Something went wrong: ' + res.error.faultString, 'error');
            });
            
            

            spuckt z. B. bei mir Unknown Paramset aus. Bei dir villeicht Unknown ID. :p

            Videotutorials & mehr

            Hier könnt ihr mich unterstützen.

            1 Antwort Letzte Antwort
            0
            • M Offline
              M Offline
              Marty56
              schrieb am zuletzt editiert von
              #7

              Danke. Muss ich wohl nochmal ausprobieren.

              HW:NUC (16 GB Ram)
              OS: Debian Bullseye, Promox V7, node v16.x npm 8.19.3

              1 Antwort Letzte Antwort
              0
              • cashC Offline
                cashC Offline
                cash
                Most Active
                schrieb am zuletzt editiert von
                #8

                Ich habe damit auch mal ein bißchen probiert.

                sendTo('hm-rpc.0', 'getParamset', {ID: 'OEQ1880303', paramType: 'ASTER'}, res => {
                    log(JSON.stringify(res));
                    if(res.error) log('Something went wrong: ' + res.error.faultString, 'error');
                });
                

                bringt mit einer unbekannten ID:

                javascript.0	2019-01-27 17:15:02.597	error	script.js.Entwicklung.Fehler_finden: Something went wrong: Unknown instance
                javascript.0	2019-01-27 17:15:02.596	info	script.js.Entwicklung.Fehler_finden: {"error":{"code":-2,"faultCode":-2,"faultString":"Unknown instance"}}
                

                mit einer vorhandenen ID:

                javascript.0	2019-01-27 17:17:36.216	error	script.js.Entwicklung.Fehler_finden: Something went wrong: Unknown paramset
                javascript.0	2019-01-27 17:17:36.216	info	script.js.Entwicklung.Fehler_finden: {"error":{"code":-3,"faultCode":-3,"faultString":"Unknown paramset"}}
                

                Soweit also so gut aber die Abfrage auf meine virtuelle Heizgruppe

                sendTo('hm-rpc.1', 'getParamset', {ID: 'INT0000002', paramType: 'ASTER'}, res => {
                    log(JSON.stringify(res));
                    if(res.error) log('Something went wrong: ' + res.error.faultString, 'error');
                });
                

                bringt leider:

                script.js.Entwicklung.Fehler_finden: {"result":"","error":null}
                

                also die gleiche Meldung als wenn ich dort eine Änderung durchführe?

                1 Antwort Letzte Antwort
                0
                • paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von
                  #9

                  @cash:

                  sendTo('hm-rpc.0', 'getParamset', {ID: 'OEQ1880303', paramType: 'ASTER'}, res => {
                  ```` `  
                  

                  'ASTER' –> 'MASTER'

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  1 Antwort Letzte Antwort
                  0
                  • cashC Offline
                    cashC Offline
                    cash
                    Most Active
                    schrieb am zuletzt editiert von
                    #10

                    Ich habe absichtlich mit 'ASTER' abgefragt damit ich Fehler kriege :mrgreen:

                    Mein Problem ist das ich trotz 'ASTER' keinen Fehler bei der virtuellen Heizungsgruppe kriege…

                    1 Antwort Letzte Antwort
                    0
                    • paul53P Offline
                      paul53P Offline
                      paul53
                      schrieb am zuletzt editiert von
                      #11

                      @cash:

                      Mein Problem ist das ich trotz 'ASTER' keinen Fehler bei der virtuellen Heizungsgruppe kriege… `
                      Ein Leerstring in result läßt sich auch als "Fehler" behandeln.

                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                      1 Antwort Letzte Antwort
                      0
                      • foxriver76F Offline
                        foxriver76F Offline
                        foxriver76
                        Developer
                        schrieb am zuletzt editiert von
                        #12

                        Wenn du mal````
                        system.listMethods

                        Videotutorials & mehr

                        Hier könnt ihr mich unterstützen.

                        1 Antwort Letzte Antwort
                        0
                        • cashC Offline
                          cashC Offline
                          cash
                          Most Active
                          schrieb am zuletzt editiert von
                          #13

                          @foxriver Du sprichst in Rätseln. Ich kann zwar mittlerweile einiges aber hier bräuchte ich einen kompletten Scriptbefehl?

                          @paul53 Man kann zwar den Leerstring in result auch als "Fehler" behandeln aber man bekommt das identische Ergebnis wenn man einen Befehl erfolgreich sendet. So kann ich mittels:

                          Heizungsgruppe = 'INT0000004';
                          Heizprogramm = 1;
                                          sendTo('hm-rpc.1', 'putParamset', {ID: Heizungsgruppe, paramType: 'MASTER', params: {'WEEK_PROGRAM_POINTER': Heizprogramm}}, res => {
                                              log(JSON.stringify(res));
                                          }); 
                          

                          das Wochenprogramm der Heizungsgruppe verstellen und das Ergebnis ist dann eben auch

                          {"result":"","error":null}
                          

                          Man erhält also quasi das selbe Ergebnis ob ich dort was sinnvolles mache oder etwas was halt ein Fehler ergibt…

                          1 Antwort Letzte Antwort
                          0
                          • cashC Offline
                            cashC Offline
                            cash
                            Most Active
                            schrieb am zuletzt editiert von
                            #14

                            @foxriver76 ich habe mal

                            sendTo('hm-rpc.1', 'system.listMethods', {}, res => {
                                log(JSON.stringify(res));
                            });
                            

                            versucht. Hoffe Du meintest das?

                            Ergebnis:

                            2019-01-28 20:33:24.633 - info: javascript.0 script.js.Entwicklung.Fehler_finden2: {"result":["init","getParamsetDescription","getLinks","getDeviceDescription","getParamsetId","getParamset","putParamset","system.listMethods","listDevices","getValue","setValue","listReplaceableDevices","deleteDevice"],"error":null}
                            
                            1 Antwort Letzte Antwort
                            0
                            • foxriver76F Offline
                              foxriver76F Offline
                              foxriver76
                              Developer
                              schrieb am zuletzt editiert von
                              #15

                              @cash:

                              @foxriver76 ich habe mal

                              sendTo('hm-rpc.1', 'system.listMethods', {}, res => {
                                  log(JSON.stringify(res));
                              });
                              

                              versucht. Hoffe Du meintest das?

                              Ergebnis:

                              2019-01-28 20:33:24.633 - info: javascript.0 script.js.Entwicklung.Fehler_finden2: {"result":["init","getParamsetDescription","getLinks","getDeviceDescription","getParamsetId","getParamset","putParamset","system.listMethods","listDevices","getValue","setValue","listReplaceableDevices","deleteDevice"],"error":null}
                              ```` `  
                              

                              Jop, wollte nur sehen ob die Virtual Devices API das 'getParamset' Kommando offiziell unterstüzt, anscheinend tut sie das. Interessant wäre ob du den Paramset zurück bekommst, wenn du diesen Aufruf mittels einem tcl SKript direkt auf deiner CCU machst. Finde es komisch, dass nix zurück kommt, nur dann dürfte bei einem Aufruf aus der CCU eigentlich auch nix zurück kommen.

                              Videotutorials & mehr

                              Hier könnt ihr mich unterstützen.

                              1 Antwort Letzte Antwort
                              0
                              • foxriver76F Offline
                                foxriver76F Offline
                                foxriver76
                                Developer
                                schrieb am zuletzt editiert von
                                #16

                                Ah gib mal den Channel mit an, geht bei mir mit hm-ip Geräten nur wenn ich den Channel angebe:

                                sendTo('hm-rpc.1', 'getParamset', {ID: '000393C99B9EDF:1', paramType: 'MASTER'}, res => {
                                    log(JSON.stringify(res));
                                    if(res.error) log('Something went wrong: ' + res.error.faultString, 'error');
                                });
                                
                                

                                000393C99B9EDF****:1**** <–

                                Videotutorials & mehr

                                Hier könnt ihr mich unterstützen.

                                1 Antwort Letzte Antwort
                                0
                                • cashC Offline
                                  cashC Offline
                                  cash
                                  Most Active
                                  schrieb am zuletzt editiert von
                                  #17

                                  Das scheint nicht sinnvoll…

                                  sendTo('hm-rpc.1', 'getParamset', {ID: 'INT0000002:1', paramType: 'MASTER'}, res => {
                                      log(JSON.stringify(res));
                                      if(res.error) log('Something went wrong: ' + res.error.faultString, 'error');
                                  });
                                  

                                  ergibt: {"result":{},"error":null}

                                  {"result":{},"error":null}
                                  

                                  ohne ":1" ergibt dagegen:

                                  {"result":{"P2_ENDTIME_THURSDAY_7":1440,"P1_ENDTIME_MONDAY_12":1440,"P2_ENDTIME_THURSDAY_8…... also ein sehr sehr langes Ergebnis

                                  1 Antwort Letzte Antwort
                                  0
                                  • foxriver76F Offline
                                    foxriver76F Offline
                                    foxriver76
                                    Developer
                                    schrieb am zuletzt editiert von
                                    #18

                                    @cash:

                                    Das scheint nicht sinnvoll…

                                    sendTo('hm-rpc.1', 'getParamset', {ID: 'INT0000002:1', paramType: 'MASTER'}, res => {
                                        log(JSON.stringify(res));
                                        if(res.error) log('Something went wrong: ' + res.error.faultString, 'error');
                                    });
                                    

                                    ergibt: {"result":{},"error":null}

                                    {"result":{},"error":null}
                                    

                                    ohne ":1" ergibt dagegen:

                                    {"result":{"P2_ENDTIME_THURSDAY_7":1440,"P1_ENDTIME_MONDAY_12":1440,"P2_ENDTIME_THURSDAY_8…... also ein sehr sehr langes Ergebnis `
                                    Ich bin davon ausgegangen, dass dein Problem darin besteht, dass du kein getParamset auf deiner virtuellen Heizgruppe ausführen kannst, doch es scheint ja zu funktionieren.

                                    Das Problem ist also, dass kein Fehler gemeldet wird trotz falschem/nich existenten Kommando? Evtl. Ein Fehler in der Virtual Devices API.

                                    Videotutorials & mehr

                                    Hier könnt ihr mich unterstützen.

                                    1 Antwort Letzte Antwort
                                    0
                                    • cashC Offline
                                      cashC Offline
                                      cash
                                      Most Active
                                      schrieb am zuletzt editiert von
                                      #19

                                      Ich vermute mittlerweile auch das dort der Fehler zu suchen ist. Naja vielleicht wird er ja mal von eq3 gefixt

                                      1 Antwort Letzte Antwort
                                      0
                                      Antworten
                                      • In einem neuen Thema antworten
                                      Anmelden zum Antworten
                                      • Älteste zuerst
                                      • Neuste zuerst
                                      • Meiste Stimmen


                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate
                                      FAQ Cloud / IOT
                                      HowTo: Node.js-Update
                                      HowTo: Backup/Restore
                                      Downloads
                                      BLOG

                                      766

                                      Online

                                      32.5k

                                      Benutzer

                                      81.7k

                                      Themen

                                      1.3m

                                      Beiträge
                                      Community
                                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                      ioBroker Community 2014-2025
                                      logo
                                      • Anmelden

                                      • Du hast noch kein Konto? Registrieren

                                      • Anmelden oder registrieren, um zu suchen
                                      • Erster Beitrag
                                        Letzter Beitrag
                                      0
                                      • Home
                                      • Aktuell
                                      • Tags
                                      • Ungelesen 0
                                      • Kategorien
                                      • Unreplied
                                      • Beliebt
                                      • GitHub
                                      • Docu
                                      • Hilfe