NEWS
HM-RPC Level Kanal 3&4 nicht synchron
-
@negalein sagte in HM-RPC Level Kanal 3&4 nicht synchron:
"native": { "MIN": 0, "UNIT": "100%", "OPERATIONS": 7, "MAX": 1.01, "FLAGS": 1, "ID": "LEVEL", "TYPE": "FLOAT", "DEFAULT": 0, "CONTROL": "SHUTTER_VIRTUAL_RECEIVER.LEVEL" },
ist denn der max mit 1.01 in Ordnung?
-
@foxriver76 sagte in HM-RPC Level Kanal 3&4 nicht synchron:
was spricht gegen einen alias mit unterschiedlichen read/write oder bzw. was ist dein Ziel?
Ich hätte nichts dagegen. Er muss schaltbar sein (wegen Shuttercontrol). Kenne mich mit Alias nicht aus.
Derzeit ist es eben so, dass Shuttercontrol das Rollo bei zB Sonnenuntergang nicht schliesst, da
.4.LEVEL
schon auf 0% steht, obwohl es real zB 90% sind. -
@negalein
Bei mir, seit Triggerumstellung ist es okay. Und das CCU Script macht das ja anscheinend auch bei Aktualisierung (zwar Kanal4 /Level als Trigger, aber die DP aktualisieren sich ja alle.Das CCU Script hat halt noch 5 Sekunden Verzögerung drinn.)
Bisher läuft es auch mit dem Blockly von @paul53 , eben nur auf Aktualisierung. -
@dslraser sagte in HM-RPC Level Kanal 3&4 nicht synchron:
Bei mir, seit Triggerumstellung ist es okay. Und das CCU Script macht das ja anscheinend auch bei Aktualisierung (zwar Kanal4 /Level als Trigger, aber die DP aktualisieren sich ja alle.Das CCU Script hat halt noch 5 Sekunden Verzögerung drinn.)
Bisher läuft es auch mit dem Blockly von @paul53 , eben nur auf Aktualisierung.Danke für die Info.
Dann werd ich mal umstellen und beobachten.
Zum CCU-Script bin ich eh noch nicht gekommen. -
@negalein sagte in HM-RPC Level Kanal 3&4 nicht synchron:
Danke für die Info.
passt immernoch
Hier sieht mach auch die Aktualisierungen (zwei Beispiele)
-
-
It's not a bug, it's a feature. Der Kanal 3 liefert immer den IST-Wert des jeweiligen Rolladens, spätestens, wenn dieser angehalten hat. Die Kanäle 4, 5 und 6 dienen dagegen zur Setzung von SOLL-Werten. Setzt man in einen dieser Kanäle einen Wert (z.B. per Skript oder Shuttercontrol) dann fährt der Rolladen genau diese Position an und die Werte in Kanal 3 und dem verwendeten Stellkanal stimmen überein. Wird dagegen manuell eine Fahrt ausgelöst, dann weiß der Controller (BROLL oder FROLL ist hier egal) ja nicht, wie weit der Rolladen fahren soll. Er kennt nur die Richtung und fährt, bis er entweder per Taster gestoppt wird oder eine Endposition erreicht hat. Damit er fährt, wird bei Drücken des Tasters "Hoch" der Wert 100% und bei Drücken des Tasters "Runter" der Wert 0% in den jeweils mit dem Taster verknüpften Stellkanal 4,5 oder 6 geschrieben. Wird die Fahrt dann z.B. bei 50% per Taster gestoppt, so wird der Wert im Stellkanal nicht geändert, nur in Kanal 3. Und genau das führt zu den bekannten Problemen. Wenn man es also 100% richtig machen wollte, dann müsste Shuttercontrol entsprechend geändert werden und zwei Kanäle (3 zur Ermittlung des IST-Werts und 4,5 oder 6 für as Setzen des Soll-Werts) verwenden. Leider habe ich von eq3 direkt dazu keine Aussage gefunden. Lediglich in diesem Post wurde das schon mal ausführlich dargelegt. Ist zwar nicht schön, aber wohl von eq3 genauso beabsichtigt.
-
@it-veteran Deshalb könnte man einen alias als Workaround nutzen. Genau solche Situationen waren der Hintergrund der separaten read und write States. Das Szenario mit unterschiedlichen Kanälen (bzw. letztendlich States) zum setzen und auslesen findet sich in HM und auch bei anderen Geräten oft wieder.
https://github.com/ioBroker/ioBroker.js-controller#object-and-state-aliases
-
@foxriver76 sagte in HM-RPC Level Kanal 3&4 nicht synchron:
@it-veteran Deshalb könnte man einen alias als Workaround nutzen. Genau solche Situationen waren der Hintergrund der separaten read und write States. Das Szenario mit unterschiedlichen Kanälen (bzw. letztendlich States) zum setzen und auslesen findet sich in HM und auch bei anderen Geräten oft wieder.
https://github.com/ioBroker/ioBroker.js-controller#object-and-state-aliases
Kannst Du oder auch @paul53 mal ein Beispiel zeigen wie man so etwas als alias erstellt ? bzw. wie so ein alias fertig aussieht ? (Dein Link zur Beschreibung ist leider auch nur in englisch)
-
@dslraser sagte: wie so ein alias fertig aussieht ?
{ "from": "system.adapter.javascript.1", "user": "system.user.admin", "ts": 1617735406586, "common": { "name": "Rollo Wintergarten", "role": "level", "type": "number", "desc": "per Script erstellt", "unit": "%", "min": 0, "max": 100, "def": 0, "read": true, "write": true, "alias": { "id": { "read": "hm-rpc.0.00115A49A5B2BE.3.LEVEL", "write": "hm-rpc.0.00115A49A5B2BE.4.LEVEL" } } }, "native": {}, "acl": { "object": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator", "state": 1636 }, "_id": "alias.0.Wintergarten.Rollo.Level", "type": "state" }
-
@paul53
Vielen Dank. -
@dslraser sagte in HM-RPC Level Kanal 3&4 nicht synchron:
Vielen Dank
wie erstellt man einen Alias auf einfache Art?
Adapter gibts mMn keinen. -
@negalein
Entweder per Script oder vielleicht mit dem Adapter hierEdit: Falscher Link
Den hier meine ich
https://github.com/sbormann/ioBroker.alias-manager -
@dslraser sagte in HM-RPC Level Kanal 3&4 nicht synchron:
oder vielleicht mit dem Adapter hier
Cool, gibt einen Adapter.
Link hat schon gepasst. Ist im Beitrag eh zu Git verlinkt!
Danke -
@paul53 sagte in HM-RPC Level Kanal 3&4 nicht synchron:
@dslraser sagte: wie so ein alias fertig aussieht ?
{ "from": "system.adapter.javascript.1", "user": "system.user.admin", "ts": 1617735406586, "common": { "name": "Rollo Wintergarten", "role": "level", "type": "number", "desc": "per Script erstellt", "unit": "%", "min": 0, "max": 100, "def": 0, "read": true, "write": true, "alias": { "id": { "read": "hm-rpc.0.00115A49A5B2BE.3.LEVEL", "write": "hm-rpc.0.00115A49A5B2BE.4.LEVEL" } } }, "native": {}, "acl": { "object": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator", "state": 1636 }, "_id": "alias.0.Wintergarten.Rollo.Level", "type": "state" }
@Negalein
Funktioniert übrigens wie gewünscht (auch in iQontrol)Hier mal das Script von @paul53
// Original-Datenpunkt const idOrigin = 'hm-rpc.0.00111BE99FD0D1.4.LEVEL'/*Rollo Wohnzimmer Panoramafenster:4 LEVEL*/ // Optional: Status-Datenpunkt, wenn Kommando und Status getrennt. // Bei Nicht-Verwendung Leerstring '' zuweisen const idRead = 'hm-rpc.0.00111BE99FD0D1.3.LEVEL'/*Rollo Wohnzimmer Panoramafenster:4 LEVEL*/ // Alias-Datenpunkt const idAlias = 'Rollos.Rollo_Wohnzimmer_Panoramafenster'; var typeAlias, read, write, nameAlias, role, desc, min, max, unit, states, custom, raum, gewerk; // Folgende kommentieren, wenn keine Änderung der Eigenschaft erforderlich nameAlias = 'Rollo Wohnzimmer Panoramafenster'; desc = 'per Script erstellt'; // typeAlias = 'boolean'; // oder 'number' // read = "val < 0 ? -val : 0"; // Erkennung "Aus" --> false erfolgt automatisch // write = "val ? String(1) : String(0)"; // role = 'value'; // min = 0; // nur Zahlen // max = 100; // nur Zahlen // unit = '%'; // nur für Zahlen // states = {0: 'Aus', 1: 'Auto', 2: 'Ein'}; // Zahlen (Multistate) oder Logikwert (z.B. Aus/Ein) custom = {}; // verhindert doppelte Ausführung von history, ... // raum = 'EG_Flur'; // Groß-/Kleinschreibung in der ID beachten ! // gewerk = 'Licht'; // Groß-/Kleinschreibung in der ID beachten ! // Ab hier nichts ändern !! function createAlias(idDst, idSrc, idRd) { if(existsState(idDst)) log(idDst + ' schon vorhanden !', 'warn'); else { var obj = {}; obj.type = 'state'; obj.common = getObject(idSrc).common; obj.common.alias = {}; if(idRd) { obj.common.alias.id = {}; obj.common.alias.id.read = idRd; obj.common.alias.id.write = idSrc; obj.common.read = true; } else obj.common.alias.id = idSrc; if(typeAlias) obj.common.type = typeAlias; if(obj.common.read !== false && read) obj.common.alias.read = read; if(obj.common.write !== false && write) obj.common.alias.write = write; if(nameAlias) obj.common.name = nameAlias; if(role) obj.common.role = role; if(desc) obj.common.desc = desc; if(obj.common.type == 'number') { if(min !== undefined) obj.common.min = min; if(max !== undefined) obj.common.max = max; if(unit) obj.common.unit = unit; } else { if(obj.common.min !== undefined) delete obj.common.min; if(obj.common.max !== undefined) delete obj.common.max; if(obj.common.unit) delete obj.common.unit; } if(states) obj.common.states = states; if(custom && obj.common.custom) obj.common.custom = custom; obj.native = {}; setObject(idDst, obj, function() { if(idRd) setState(idRd, getState(idRd).val, true); else setState(idSrc, getState(idSrc).val, true); }); if(raum && existsObject('enum.rooms.' + raum)) { let obj = getObject('enum.rooms.' + raum) obj.common.members.push(idDst); setObject('enum.rooms.' + raum, obj); } if(gewerk && existsObject('enum.functions.' + gewerk)) { let obj = getObject('enum.functions.' + gewerk) obj.common.members.push(idDst); setObject('enum.functions.' + gewerk, obj); } } } createAlias('alias.0.' + idAlias, idOrigin, idRead);
Und hier der alias
{ "type": "state", "common": { "name": "Rollo Wohnzimmer Panoramafenster", "def": 0, "type": "number", "read": true, "write": true, "min": 0, "max": 100, "unit": "%", "role": "level", "smartName": { "de": "Rollo Panoramafenster" }, "alias": { "id": { "read": "hm-rpc.0.00111BE99FD0D1.3.LEVEL", "write": "hm-rpc.0.00111BE99FD0D1.4.LEVEL" } }, "desc": "per Script erstellt" }, "native": {}, "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1617809166789, "_id": "alias.0.Rollos.Rollo_Wohnzimmer_Panoramafenster", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" } }
-
@dslraser sagte in HM-RPC Level Kanal 3&4 nicht synchron:
Funktioniert übrigens wie gewünscht
Danke, werd ich gleich mal übernehmen. Und an mich anpassen!
-
@negalein sagte in HM-RPC Level Kanal 3&4 nicht synchron:
Danke, werd ich gleich mal übernehmen. Und an mich anpassen!
zu früh gefreut, ein Blockly/Script braucht es trotzdem...
-
@dslraser sagte: ein Blockly/Script braucht es trotzdem...
Weshalb?
-
@paul53 sagte in HM-RPC Level Kanal 3&4 nicht synchron:
Weshalb?
Weil im alias trotzdem nicht immer der reale Wert (von Kanal 3) angezeigt wird.
-
@dslraser sagte: Weil im alias trotzdem nicht immer der reale Wert (von Kanal 3) angezeigt wird.
Kann das jemand bestätigen (habe keine Rollo-Aktoren)?
Nach meiner Erfahrung spiegelt der Alias exakt jeden Zustand des Read-Datenpunktes.