Blinken - Impulsgenerator mit variablem Tastgrad: Unterschied zwischen den Versionen
Krueuw (Diskussion | Beiträge) K (→Inbetriebnahme) |
Krueuw (Diskussion | Beiträge) |
||
Zeile 80: | Zeile 80: | ||
== Funktionsbeschreibung == | == Funktionsbeschreibung == | ||
[[Datei:Kausakkette1.png|Trigger]]<br> | [[Datei:Kausakkette1.png|Trigger]]<br> | ||
1. Auslösung des MSwitch-Gerätes 'Pulse' | 1. Auslösung des MSwitch-Gerätes 'Pulse' durch Aus- und Wiedereinschalten,<br> | ||
2. Aktivieren des 1. Befehlszweiges 'cmd1' des MSwitch-Gerätes 'Pulse', | 2. Aktivieren des 1. Befehlszweiges 'cmd1' des MSwitch-Gerätes 'Pulse', | ||
Zeile 93: | Zeile 93: | ||
[[Datei:Kausalkette5.png|Pausenzeit]]<br> | [[Datei:Kausalkette5.png|Pausenzeit]]<br> | ||
6. um die Länge von ' | 6. um die Länge von 'onpulse' verzögertes Ausführen von 'Set exec_cmd_1', Verweis auf ID1, damit um 'offpulse' verzögertes erneutes Abarbeiten des Zweiges 'cmd1'. | ||
[[Datei:Kausalkette6.png|x]]<br> | [[Datei:Kausalkette6.png|x]]<br> | ||
5. | 5. Die Rahmen eins bis drei werden zeitgleich sofort abgearbeitet, der vierte Rahmen wird erst nach 'onpuls' des dritten gestartet. | ||
== Anpassung an eigene Anforderungen == | == Anpassung an eigene Anforderungen == |
Version vom 9. November 2019, 16:28 Uhr
Blinken - Impulsgenerator mit variablem Tastgrad
Import
Die folgende Definition kann als Testraum in die eigene FHEM-Installation ohne Seiteneffekte importiert werden, indem man auf das Pluszeichen oben links im Webinterface klickt. Falls dieses unsichtbar sein sollte, kann es z.B über den Style f18 sichtbar gemacht werden.
defmod Pulse MSwitch # MSwitch_Self pulsedevice<br> attr Pulse MSwitch_Debug 0<br> attr Pulse MSwitch_Delete_Delays 1<br> attr Pulse MSwitch_Eventhistory 0<br> attr Pulse MSwitch_Expert 1<br> attr Pulse MSwitch_Extensions 1<br> attr Pulse MSwitch_Help 1<br> attr Pulse MSwitch_Ignore_Types "TYPE=MSwitch"<br> attr Pulse MSwitch_Include_Devicecmds 1<br> attr Pulse MSwitch_Include_MSwitchcmds 0<br> attr Pulse MSwitch_Include_Webcmds 0<br> attr Pulse MSwitch_Inforoom MSwitch<br> attr Pulse MSwitch_Lock_Quickedit 1<br> attr Pulse MSwitch_Mode Full<br> attr Pulse MSwitch_Safemode 1<br> attr Pulse readingList onpulse offpulse<br> attr Pulse room 07_Pulse<br> attr Pulse setList onpulse:00:00:01,00:00:02,00:00:03,00:00:04,00:00:05 offpulse:00:00:01,00:00:02,00:00:03,00:00:04,00:00:05<br> attr Pulse webCmd on:off:onpulse:offpulse<br> attr Pulse webCmdLabel ::ontime:offtime<br>
defmod pulsedevice MSwitch # no_device<br> attr pulsedevice MSwitch_Debug 0<br> attr pulsedevice MSwitch_Eventhistory 0<br> attr pulsedevice MSwitch_Help 0<br> attr pulsedevice MSwitch_Ignore_Types notify allowed at watchdog doif fhem2fhem telnet FileLog readingsGroup FHEMWEB autocreate eventtypes readingsproxy svg cul<br> attr pulsedevice MSwitch_Inforoom MSwitch<br> attr pulsedevice MSwitch_Mode Dummy<br> attr pulsedevice room 07_Pulse<br> attr pulsedevice setList on off<br>
setstate Pulse off<br> setstate Pulse 2019-11-03 14:17:18 .Device_Affected MSwitch_Self-AbsCmd1,MSwitch_Self-AbsCmd2,pulsedevice-AbsCmd1,pulsedevice-AbsCmd2<br> setstate Pulse 2019-11-03 14:21:52 .Device_Affected_Details MSwitch_Self-AbsCmd1#[NF]exec_cmd_1#[NF]no_action#[NF]ID#[sp]1#[NF]#[NF]delay1#[NF]delay1#[NF][Pulse#[dp]onpulse]#[NF]00#[dp]00#[dp]00#[NF]#[NF]#[NF]0#[NF]0#[NF]1#[NF]0#[NF]#[NF]0#[NF]0#[NF]3#[ND]MSwitch_Self-AbsCmd2#[NF]exec_cmd_1#[NF]no_action#[NF]#[NF]#[NF]delay1#[NF]delay1#[NF][Pulse#[dp]offpulse]#[NF]00#[dp]00#[dp]00#[NF]#[NF]#[NF]0#[NF]0#[NF]1#[NF]1#[NF]#[NF]0#[NF]0#[NF]4#[ND]pulsedevice-AbsCmd1#[NF]on#[NF]off#[NF]#[NF]#[NF]delay1#[NF]delay1#[NF]00#[dp]00#[dp]00#[NF]00#[dp]00#[dp]00#[NF]#[NF]#[NF]0#[NF]0#[NF]1#[NF]0#[NF]#[NF]0#[NF]0#[NF]1#[ND]pulsedevice-AbsCmd2#[NF]off#[NF]no_action#[NF]#[NF]#[NF]delay2#[NF]delay1#[NF][Pulse#[dp]onpulse]#[NF]00#[dp]00#[dp]00#[NF]#[NF]#[NF]0#[NF]0#[NF]1#[NF]0#[NF]#[NF]0#[NF]0#[NF]2<br> setstate Pulse 2019-11-03 12:31:25 .Device_Events no_trigger<br> setstate Pulse 2019-11-03 12:31:25 .First_init done<br> setstate Pulse 2019-11-03 12:31:25 .Trigger_cmd_off no_trigger<br> setstate Pulse 2019-11-03 12:31:25 .Trigger_cmd_on no_trigger<br> setstate Pulse 2019-11-03 12:31:25 .Trigger_off no_trigger<br> setstate Pulse 2019-11-03 12:31:25 .Trigger_on no_trigger<br> setstate Pulse 2019-11-03 12:31:25 .V_Check V2.00<br> setstate Pulse 2019-11-03 14:18:43 .sortby show<br> setstate Pulse 2019-11-03 12:31:25 Trigger_log off<br> setstate Pulse 2019-11-03 14:21:24 last_activation_by manual<br> setstate Pulse 2019-11-03 14:21:23 last_cmd 1<br> setstate Pulse 2019-11-03 14:21:23 last_exec_cmd set Pulse exec_cmd_1 <br> setstate Pulse 2019-11-03 14:21:05 offpulse 00:00:05<br> setstate Pulse 2019-11-03 14:19:18 onpulse 00:00:02<br> setstate Pulse 2019-11-03 14:21:24 state off<br>
setstate pulsedevice on<br> setstate pulsedevice 2019-11-03 12:32:30 .Device_Affected no_device<br> setstate pulsedevice 2019-11-03 12:32:30 .Device_Events no_trigger<br> setstate pulsedevice 2019-11-03 12:32:30 .First_init done<br> setstate pulsedevice 2019-11-03 12:32:30 .Trigger_cmd_off no_trigger<br> setstate pulsedevice 2019-11-03 12:32:30 .Trigger_cmd_on no_trigger<br> setstate pulsedevice 2019-11-03 12:32:30 .Trigger_off no_trigger<br> setstate pulsedevice 2019-11-03 12:32:30 .Trigger_on no_trigger<br> setstate pulsedevice 2019-11-03 12:32:30 .V_Check V2.00<br> setstate pulsedevice 2019-11-03 12:32:30 Trigger_log off<br>
Inbetriebnahme
Der Testraum 07_Puls enthält zwei konfigurierte MSwitch-Geräte, die die beabsichtigte Funktion zusammen bewirken. Pulse enthält die Logik, Pulsedevice dient der Statusausgabe des Generators. Um die Impulsfolge durch Selbsttriggerung zu starten, genügt es Pulse per Webinterface zu deaktivieren und zu aktivieren.
Nach der Auslösung liefert das Pulsdevice eine endlose konfigurierbare Folge von Rechtecksignalen. Pulsdevice im Testraum in Aktion:
Funktionsbeschreibung
1. Auslösung des MSwitch-Gerätes 'Pulse' durch Aus- und Wiedereinschalten,
2. Aktivieren des 1. Befehlszweiges 'cmd1' des MSwitch-Gerätes 'Pulse',
3. Auswahl betroffener Geräte: 'MSwitch_Self -> pulse' und 'pulsedevice', Erzeugung je eines 'device action'-Rahmens
4. unverzögertes Setzen des Status von 'pulsedevice' auf 'on', positive Flanke des Rechtecksignals
5. um die Länge von 'onpulse' verzögertes Rücksetzen des Status von 'pulsdevice', negative Flanke des Rechtecksignals
6. um die Länge von 'onpulse' verzögertes Ausführen von 'Set exec_cmd_1', Verweis auf ID1, damit um 'offpulse' verzögertes erneutes Abarbeiten des Zweiges 'cmd1'.
5. Die Rahmen eins bis drei werden zeitgleich sofort abgearbeitet, der vierte Rahmen wird erst nach 'onpuls' des dritten gestartet.
Anpassung an eigene Anforderungen
Um eigene Geräte für die Ausgabe benutzen zu können, muss:
Attribut Switch_Ignore_Types = TYPE=MSwitch
auf
Attribut Switch_Ignore_Types = notify allowed at watchdog doif fhem2fhem telnet FileLog readingsGroup FHEMWEB autocreate eventtypes readingsproxy svg cul
geändert werden.
Um den Verlust von Konfigurationsdaten zu vermeiden, lässt man das quickedit verriegelt und fügt eigene Zielgeräte per 'edit list' hinzu.
Die Bestätigung mit 'modify Devices' erzeugt pro neuem Gerät einen 'device action'-Rahmen, in den die Konfiguration von 'pulsedevice' übernommen werden kann. 'Modify action' übernimmt.
Der zweite notwendige Action-Rahmen für das eigene Device wird per 'add action ..' erzeugt.
Das Attribut 'setlist' erlaubt die leichte Anpassung der auswählbaren Impuls- bzw. Pausenzeiten. Hier können auch Dezimalbrüche wie 0,5 angegeben werden.