Datentransfer invertiert
Dieser FP-Befehl invertiert den Datenbereich oder die äquivalente Konstante s logisch und überträgt ihn/sie in den Datenbereich d, wenn der Trigger EN auf TRUE gesetzt ist.
Eingang
Zu invertierende Quelldaten
Ausgang
Zieldaten
Die Variablen s und d müssen vom gleichen Datentyp sein.
Im POE-Kopf werden alle Ein- und Ausgangsvariablen deklariert, die für die Programmierung dieser Funktion verwendet werden. Für alle Programmiersprachen wird der gleiche POE-Kopf verwendet.
VAR
bStart: BOOL:=FALSE;
(*activates the function*)
wInput_value: DWORD:=16#00001234;
(*this value will be
inverted*)
wOutput_value: DWORD:=0;
(*result after a 0->1 leading
edge from start:
16#FFFFEDCB*)
END_VAR
Wenn die Variable bStart auf TRUE gesetzt wird, wird die Funktion ausgeführt.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 5 ;
NETWORK_BODY
B(B_F,FP_MOVE_INVERT!,,17,0,27,4,,?DEN?D@'s'?AENO?Cd);
B(B_CONTACT,,bStart,6,1,8,3,);
B(B_VARIN,,wInput_value,15,2,17,4,);
B(B_VAROUT,,wOutput_value,27,2,29,4,);
L(8,2,17,2);
L(1,2,6,2);
L(1,0,1,5);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF (bStart) then
FP_MOVE_INVERT(s := wInput_value, d => wOutput_value);
END_IF;