UPGRADE IP 9 verfügbar!
Timberwolf VISU jetzt mit NEUEM Layout Editor
Freie Anordnung, Reihenfolge und Größe der Widgets - viele weitere Verbesserungen
Infos im Wiki: https://elabnet.atlassian.net/l/cp/06SeuHRJ

NEU! Insider & Leistungsmerkmale FÜR ALLE freigeschaltet
Damit kann nun jeder das Upgrade vornehmen und VISU & IFTTT testen. Alle Info hier: viewtopic.php?f=8&t=5074

[NEUHEIT] Universeller Binär -> String Baustein (bin2txt V2.0)

Hier stellen Foristen und Kunden Ihre EIGENEN Logikbausteine vor. Diese Logikbausteine stehen jedem im Rahmen der vom Autor eingeräumten / genannten Lizenz zur Verfügung.
Forumsregeln
  • Denke bitte an aussagekräftige Titel und gebe dort auch die [Firmware] an. Wenn ETS oder CometVisu beteiligt sind, dann auch deren Version
  • Bitte mache vollständige Angaben zu Deinem Server, dessen ID und dem Online-Status in Deiner Signatur. Hilfreich ist oft auch die Beschreibung der angeschlossener Hardware sowie die verwendeten Protokolle
  • Beschreibe Dein Projekt und Dein Problem bitte vollständig. Achte bitte darauf, dass auf Screenshots die Statusleiste sichtbar ist
  • Bitte sei stets freundlich und wohlwollend, bleibe beim Thema und unterschreibe mit deinem Vornamen. Bitte lese alle Regeln, die Du hier findest: https://wiki.timberwolf.io/Forenregeln

Ersteller
Dragonos2000
Reactions:
Beiträge: 2181
Registriert: So Aug 12, 2018 1:38 pm
Wohnort: Karlsruher Raum
Hat sich bedankt: 481 Mal
Danksagung erhalten: 889 Mal

Universeller Binär -> String Baustein (bin2txt V2.0)

#1

Beitrag von Dragonos2000 »

Mal wieder Zeit für neue Bausteine :) Anbei möchte ich einen konfigurierbaren Baustein mit Euch teilen, mit dem Ihr über einen Binäreingang eine Textmeldung senden könnt.
bin2txt.JPG
Betriebsmodi:
  1. Senden nur bei "False" (Mode 0), dabei wird der für "True" konfigurierte String ignoriert
  2. Senden nur bei "True" (Mode 1), dabei wird der für "False" konfigurierte String ignoriert
  3. Senden sowohl bei "True" als auch bei "False" von unterschiedlichen Texten (Mode 2)
Zusätzlich ist ein Holddown-Timer implementiert, um zu schnelles / kurzes triggern hintereinander zu verhindern.

Eingänge:
  • Trigger Input = Binäreingang, der das Senden auslöst
  • Str2Send for True = String, der bei Empfang von "True" am Trigger Input gesendet werden soll (Betriebsmodi 1 und 2)
  • Str2Send for False = String, der bei Empfang von "False" am Trigger Input gesendet werden soll (Betriebsmodi 0 und 2)
  • Holddown = Zeit in Sekunden, während der ein erneutes Triggern unterdrückt wird
  • Mode = Betriebsmodus (siehe oben)
Einsatzgebiete(bei mir derzeit):
  • Textmeldungen auf Display eines KNX-Bedienelements
  • Abspielen eines bestimmtes Wave-Files auf dem Synohr
  • Sollte sich auch für MQTT gut gebrauchen lassen...

Code: Alles auswählen

{
  "Level": [
	["$ConstFalse","bool",false],
	["$ConstTrue","bool",true],
	["$Send","bool",false],
	["$HoldDown","bool",false],
	["$P_OpMode","integer",0],
	["$P_HoldDownTime","float",1.0],
	["$I_Trigger","bool",false],
	["$P_TextTrue","string","Init-Value"],
	["$P_TextFalse","string","Init-Value"],
	["$O_Text","string","Init-Value"],
	["$VAR<Inhibit?>","bool",false]
  ],
  "_Meta": {
    "Icon": " ",
    "Version": "2.0",
    "_description": "Sending text when triggered"
  },
  "Output": [
	["Text Output","Text output","$O_Text","x"]
  ],
  "Module": [
	["Break",["$VAR<Inhibit?>"]],
	["Multiplexer",["$P_TextFalse","$P_TextTrue"],"$O_Text","$I_Trigger"],
	["Multiplexer",["-$I_Trigger","$I_Trigger","$ConstTrue"],"$I_Trigger","$P_OpMode"],	//Inversion, if "false" shall be the trigger to send the output
	["And",["-$HoldDown", "$I_Trigger"], "$Send"],
	["SendExplicit","$Send","$O_Text",0],
	["Monoflop","$I_Trigger","$ConstFalse","$HoldDown","$P_HoldDownTime",0]
  ],
  "Input": [
	["Trigger Input","Send when trigger receives configured logic level", "$I_Trigger","a"],
	["Str2Send for TRUE","String to be sent, when TRUE is received", "$P_TextTrue","u"],
	["Str2Send for FALSE","String to be sent, when FALSE is received", "$P_TextFalse","u"],
	["HoldDown","Holddown timer in seconds until next output can be sent", "$P_HoldDownTime","u"],
	["Mode","Operation Mode: 0=Send on FALSE, 1=Send on TRUE, 2=Send both", "$P_OpMode","u"],
	["Inhibit","INHIBIT","$VAR<Inhibit?>","u"]
  ]
}
Viel Spaß damit.

Der Schöpfer dieser Custom Logik überträgt die Nutzungsrechte gemäß der TOLL ("Timberwolf Open Logikblock License") die unter https://wrgt.news/TOLL zum Download zur Verfügung steht.
Du hast keine ausreichende Berechtigung, um die Dateianhänge dieses Beitrags anzusehen.
Zuletzt geändert von Dragonos2000 am Mo Jun 07, 2021 5:19 pm, insgesamt 4-mal geändert.
Lg
Jochen
____________________________________________________________
TW 2600 #188
VPN offen, Zugriff jederzeit, Experimente jederzeit, Reboot jederzeit

gbglace
Reactions:
Beiträge: 3585
Registriert: So Aug 12, 2018 10:20 am
Hat sich bedankt: 1253 Mal
Danksagung erhalten: 1649 Mal

#2

Beitrag von gbglace »

Hmm, denkbar wäre damit auch Text to Speech via Alexa und Co. um die passende Logik Textauswahl nach Events im TWS zu erledigen und nicht im NR wo dann wieder alles erstmal an Triggern ins NR gelangen muss (KNX und neu MQTT).

Sehr schön.
Grüße
Göran

#1 Timberwolf 2600 Velvet Red TWS #225 / VPN aktiv / Reboot OK
#2 Timberwolf 2600 Organic Silver TWS #438 / VPN aktiv / Reboot OK
#3 PBM 3 Kanäle, #4 Modbus-Extension

Ersteller
Dragonos2000
Reactions:
Beiträge: 2181
Registriert: So Aug 12, 2018 1:38 pm
Wohnort: Karlsruher Raum
Hat sich bedankt: 481 Mal
Danksagung erhalten: 889 Mal

#3

Beitrag von Dragonos2000 »

Noch ein Nachtrag, falls jemand den Baustein implementiert und im Doktormodus ansieht:
Aufgrund der Tatsache, dass ich "SendExplicit" verwende, sieht das Verhalten im Dokmode etwas seltsam/falsch aus. Wenn man allerdings auf den KNX Bus schaut seht man dann, dass die Ergebnisse erwartungsgemäß sind.
Während ich das hier schreibe fällt mir da der Umstand ein, wie sich "SendExplicit" mit anderen Technologien verhält: Ob das nur bei KNX funktioniert, oder hoffentlich auch bspw. beim Schreiben Richtung MQTT. Das habe ich noch nicht untersucht/überprüft.
Zuletzt geändert von Dragonos2000 am Mo Jun 07, 2021 10:23 am, insgesamt 2-mal geändert.
Lg
Jochen
____________________________________________________________
TW 2600 #188
VPN offen, Zugriff jederzeit, Experimente jederzeit, Reboot jederzeit

Robert_Mini
Reactions:
Beiträge: 3741
Registriert: So Aug 12, 2018 8:44 am
Hat sich bedankt: 1164 Mal
Danksagung erhalten: 2058 Mal

#4

Beitrag von Robert_Mini »

Mein Verständnis ist, dass das sendexplicit verhindert, dass ein Wert an den Dispatcher gesendet wird und damit sollte es für alle Technologien funktionieren.

Lg
Robert
Zuletzt geändert von Robert_Mini am Mo Jun 07, 2021 10:42 am, insgesamt 1-mal geändert.
Timberwolf Server 2500 / #117 (VPN offen + reboot nach Rückfrage) / zusätzlich: 3500M/#935, 3500L/#1297

ROI111
Reactions:
Beiträge: 93
Registriert: Do Dez 27, 2018 6:14 pm
Hat sich bedankt: 65 Mal
Danksagung erhalten: 59 Mal

#5

Beitrag von ROI111 »

Hallo,

ich möchte dieLogik nutzen um den String "Waschmaschine fertig" mittels MQTT zum IO_Broker zu senden. Von dort geht es dann weiter an mein Telegram :-)

Leider ist String scheinbar auf 14 Zeichen begrenzt. Ich bekomme, auch im Doktormodus, immer nur Waschmaschine f gesendet.

Habt ihr eine Idee wie man mehr Zeichen senden kann?

Schöne Grüße

Matthias
TWS 950Q ID:348, VPN offen, Reboot erlaubt

ms20de
Elaborated Networks
Reactions:
Beiträge: 974
Registriert: Sa Aug 11, 2018 9:14 pm
Hat sich bedankt: 280 Mal
Danksagung erhalten: 499 Mal

#6

Beitrag von ms20de »

ROI111 hat geschrieben: Fr Aug 13, 2021 7:41 pm ich möchte die Logik nutzen um den String "Waschmaschine fertig" mittels MQTT zum IO_Broker zu senden. Von dort geht es dann weiter an mein Telegram :-)

Leider ist String scheinbar auf 14 Zeichen begrenzt. Ich bekomme, auch im Doktormodus, immer nur Waschmaschine f gesendet.
Hallo Matthias,

kommen auch nicht alle Zeichen bei MQTT an? Aktuell gibt es ein Darstellungsproblem, dass die Anzahl der Zeichen in der Timberwolf-Objekt-Darstellung beschränkt ist. Allerdings sollte immer der volle String an das Ziel weitergesendet werden.

Viele Grüße,
Matthias
[ Timberwolf Entwicklung ]

TWS 2400 ID:102 VPN offen, Reboot auf Nachfrage

ROI111
Reactions:
Beiträge: 93
Registriert: Do Dez 27, 2018 6:14 pm
Hat sich bedankt: 65 Mal
Danksagung erhalten: 59 Mal

#7

Beitrag von ROI111 »

ms20de hat geschrieben: Fr Aug 13, 2021 8:37 pm
ROI111 hat geschrieben: Fr Aug 13, 2021 7:41 pm
Hallo Matthias,

kommen auch nicht alle Zeichen bei MQTT an? Aktuell gibt es ein Darstellungsproblem, dass die Anzahl der Zeichen in der Timberwolf-Objekt-Darstellung beschränkt ist. Allerdings sollte immer der volle String an das Ziel weitergesendet werden.

Viele Grüße,
Matthias
Hallo Matthias,

Auch bei MQTT kommt nur der verkürzte String an und wird zum IOBroker weitergeleitet.

Schöne Grüße

Matthias
Zuletzt geändert von ROI111 am Fr Aug 13, 2021 11:41 pm, insgesamt 2-mal geändert.
TWS 950Q ID:348, VPN offen, Reboot erlaubt

gbglace
Reactions:
Beiträge: 3585
Registriert: So Aug 12, 2018 10:20 am
Hat sich bedankt: 1253 Mal
Danksagung erhalten: 1649 Mal

#8

Beitrag von gbglace »

ROI111 hat geschrieben: Fr Aug 13, 2021 7:41 pm ich möchte dieLogik nutzen um den String "Waschmaschine fertig" mittels MQTT zum IO_Broker zu senden. Von dort geht es dann weiter an mein Telegram :-)
Es ist zwar etwas OT, aber bis zur Fertigstellung einer Nachrichtenzentrale im TWS nutze ich einen Telegramm Adapter in NR und einen vorgelagerten Funktions-block der als Input eine Zahl 0-255 erwartet. Je Wert werden unterschiedliche Texte gesendet, die sind halt in dem Baustein gecoded.

Bei der Bimmel am Haus sendet der Binäreingang einfach einen Zahlenwert auf den KNX, das geht in via KNX-Ultimate ins NR und auf den Baustein, gleiches geht mit verschiedensten Logiken aus dem TWS. Das was davon nicht auf KNX benötigt wird kann auch per MQTT ans NR und in den Funktionsblock.

Fand ich erstmal eine schlanke Lösung, ein recht einfacher Trigger und dazu ein Mapping auf fixe Texte. Das Mapping aber eben derzeit noch in NR.
Grüße
Göran

#1 Timberwolf 2600 Velvet Red TWS #225 / VPN aktiv / Reboot OK
#2 Timberwolf 2600 Organic Silver TWS #438 / VPN aktiv / Reboot OK
#3 PBM 3 Kanäle, #4 Modbus-Extension

Ersteller
Dragonos2000
Reactions:
Beiträge: 2181
Registriert: So Aug 12, 2018 1:38 pm
Wohnort: Karlsruher Raum
Hat sich bedankt: 481 Mal
Danksagung erhalten: 889 Mal

#9

Beitrag von Dragonos2000 »

@ms20de Hat sich da die 14 Byte Beschränkung vom KNX DPT 16.00x auch für die anderen Technologien eingeschlichen?
Lg
Jochen
____________________________________________________________
TW 2600 #188
VPN offen, Zugriff jederzeit, Experimente jederzeit, Reboot jederzeit

ms20de
Elaborated Networks
Reactions:
Beiträge: 974
Registriert: Sa Aug 11, 2018 9:14 pm
Hat sich bedankt: 280 Mal
Danksagung erhalten: 499 Mal

#10

Beitrag von ms20de »

Dragonos2000 hat geschrieben: Fr Aug 20, 2021 10:40 am @ms20de Hat sich da die 14 Byte Beschränkung vom KNX DPT 16.00x auch für die anderen Technologien eingeschlichen?
Wir haben uns aus Performance Gründen entschieden längere Strings im Objektsystem nicht zwischenzuspeichern. Ich weiß nicht ob es ein anderes SmartHome System auf dem Markt gibt, welches so viele Objekt Änderungen pro Sekunde verarbeiten kann wie der Timberwolf Server. Lange Zeichenketten (Theoretisch bis zu mehreren GB) werden aber immer an das Ziel-Objekt weitergegeben, zusätzlich wird jetzt im aktuellen Developmemt-Test auch der Anfang der Zeichenkette zwischengespeichert damit eine einfachere Diagnose möglich ist.

In der Logik gibt es aktuell eine Beschränkung auf 31 Zeichen welche wir noch untersuchen. Bei MQTT, Modbus und HTTP API letztere kommend in der nächsten Insider Version sind lange Zeichenketten möglich die im Normalbetrieb an keine Grenzen stoßen sollten.

Viele Grüße,
Matthias
Zuletzt geändert von ms20de am Fr Aug 20, 2021 4:31 pm, insgesamt 3-mal geändert.
[ Timberwolf Entwicklung ]

TWS 2400 ID:102 VPN offen, Reboot auf Nachfrage
Antworten

Zurück zu „Zusätzliche Logikbausteine“