FB_DALIV2LightControl

FB_DALIV2LightControl 1:

Funktionsbaustein zur tageslichtabhängigen Lichtsteuerung mit bis zu 30 Stützpunkten.

Kernstück dieses Funktionsbausteines ist eine Eingangs-/Stellgrößen-Tabelle von 30 Elementen mit einer Schwellwertumschaltung. Erreicht der Istwert der Helligkeit den Bereich eines Stützpunktes (arrControlTable[n].nActualValue-arrControlTable[n].nSwitchRange/2 ... arrControlTable[n].nActualValue+arrControlTable[n].nSwitchRange/2) so springt die Stellgröße auf den entsprechenden WertarrControlTable[n].nControlValue (siehe Diagramm). Daran angekoppelt ist ein Rampenbaustein, der die Stellgröße in der Zeit tRampTime anfährt. Beim Einschalten mit einer positiven Flanke an bOn wird das Licht jedoch zunächst auf die nächstgelegene Stellgröße direkt geschaltet. Erst dann wird die Steuerung aktiviert. Während die Steuerung aktiv ist, kann jederzeit mit einer positiven Flanke an bOn "nachgestartet" und damit das Licht auf die nächstgelegene Stellgröße direkt gesteuert werden. Eine positive Flanke an bOff schaltet alle angesteuerten Lampen direkt ab.

FB_DALIV2LightControl 2:

Es muss nicht der ganze Bereich der Tabelle genutzt werden. Das erste Tabellenelement, welches als Tabellenende nSwitchRange eine 0 hat, wird als Beginn des unbenutzten Bereiches angesehen.

Anmerkung zum Parameter nMasterDevAddr

Das DALI-System bietet die Möglichkeit, Lampen nicht nur einzeln zu steuern, sondern diese auch gruppenweise oder mit Sammelbefehlen anzusprechen. Da die einzelnen Geräte Teilnehmer von verschiedenen Gruppen sein können, kann es sein, dass die einzelnen Lampen vor einer Gruppen- bzw. Sammelansteuerung verschiedene Helligkeitszustände haben. Um dennoch eine Aussage darüber treffen zu können, ob die Lampen nun ein- oder ausgeschaltet werden sollen, wird jeder Gruppe ein Führungsgerät (Master-Device) zugeordnet, nach dessen Zustand sich die restlichen Geräte richten. Soll mit dem Baustein eine einzelne Lampe angesteuert werden, eAddrType = eAddrTypeShort, so braucht kein Master-Device angegeben werden. Der Parameter nMasterDevAddr ist in diesem Fall ohne Bedeutung.

VAR_INPUT

bEnable                    : BOOL := TRUE;
bOn                        : BOOL;
bOff                       : BOOL;
nActualValue               : UINT;
tRampTime                  : TIME := t#30s;
arrControlTable            : ARRAY[1..30] OF ST_DALIV2ControlTable;
nOptions                   : DWORD := 0;
nAddr                      : BYTE := 0;
eAddrType                  : E_DALIV2AddrType := eDALIV2AddrTypeShort;
nMasterDevAddr             : BYTE := 0;
tCycleActualLevelMasterDev : TIME := t#0s;

bEnable: Solange dieser Eingang auf TRUE steht, sind die Eingänge bOn und bOff aktiv. Ein negativer Zustand deaktiviert die Eingänge und setzt den Baustein nach Abarbeitung der letzten notwendigen DALI-Befehle zurück. Es werden dann keine DALI-Befehle außer die zyklische Abfrage der Helligkeit des Mastergerätes mehr ausgegeben.

bOn: Eine steigende Flanke schaltet die angesteuerten Lampen direkt auf die nächst gelegene Stellgröße.

bOff: Eine steigende Flanke schaltet die angesteuerten Lampen unmittelbar aus.

nActualValue: Istwert der Helligkeit.

tRampTime: Zeitdauer, in der die Stellgröße auf den nächsten Wert gesteuert wird (voreingestellter Wert: 30s).

arrControlTable: Eingangs-/Stellgrößen-Tabelle. arrControlTable[1] bis arrControlTable[30] des Typen ST_DALIV2ControlTable (siehe ST_DALIV2ControlTable).

nOptions: Reserviert für zukünftige Entwicklungen.

nAddr: Adresse des Einzelgerätes bei Einzelansteuerung oder der Gruppe bei Gruppenansteuerung.

nMasterDevAddr: Adresse des Master-Gerätes bei Gruppen- und Sammelschaltungen.

eAddrType: Kurzadresse, Gruppenadresse oder Sammelruf (Broadcast) (siehe E_DALIV2AddrType).

tCycleActualLevelMasterDev: Zykluszeit, mit der im Hintergrund die aktuelle Stellgröße ausgelesen wird (siehe ACTUAL DIM LEVEL). Damit das Dimmen der Lampen nicht gestört wird, wird das Auslesen immer in der niedrigsten Priorität durchgeführt. Wird der Wert auf 0 gesetzt, so wird das Auslesen gesperrt.

VAR_OUTPUT

nActualLevelMasterDev : BYTE;
bBusy                 : BOOL;
bError                : BOOL;
nErrorId              : UDINT;

nActualLevelMasterDev: Aktueller Ausgabewert des Master-Gerätes (bei eAddrType = eAddrTypeShort immer des jeweilig angesprochenen Gerätes).

bBusy: Bei der Aktivierung des Bausteins wird der Ausgang gesetzt und bleibt so lange aktiv, bis der Befehl abgearbeitet wurde.

bError: Dieser Ausgang wird auf TRUE geschaltet, wenn bei der Ausführung eines Befehls ein Fehler aufgetreten ist. Der befehlsspezifische Fehlercode ist in nErrorId enthalten. Wird durch das Ausführen eines Befehls an den Eingängen auf FALSE zurückgesetzt.

nErrorId: Enthält den befehlsspezifischen Fehlercode des zuletzt ausgeführten Befehls. Wird durch das Ausführen eines Befehls an den Eingängen auf 0 zurückgesetzt. (Siehe Fehlercodes)

VAR_IN_OUT

stCommandBuffer : ST_DALIV2CommandBuffer;

stCommandBuffer: Verweis auf die interne Struktur zur Kommunikation mit den Bausteinen FB_KL6811Communication() (KL6811) oder FB_KL6821Communication() (KL6821).

Voraussetzungen

Entwicklungsumgebung

erforderliche SPS-Bibliothek

TwinCAT ab v3.1.4020.14

Tc2_DALI ab v3.4.3.0