FP_INVERT_BIT

Bit invertieren

Dieser FP-Befehl invertiert [1 (TRUE) ®0 (FALSE) oder 0 (FALSE) ®1 (TRUE)] das Bit an der Position n_Pos im Datenbereich d, wenn der Trigger EN auf TRUE gesetzt ist. Andere Bits als das angegebene ändern sich nicht.

Parameter

Eingang

n_Pos (INT, DINT, UINT, UDINT)

Zu invertierende Bitposition (zulässiger Bereich: 0–15)

Ein-/Ausgang

d (WORD)

Ergebnis

Fehleralarmmerker

sys_bIsOperationErrorHold (wird auf TRUE gesetzt und bleibt TRUE)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich
sys_bIsOperationErrorNonHold (wird für einen Zyklus auf TRUE gesetzt)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich

Beispiel

POE-Kopf

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*)
		wOutput_value: WORD:=2#111;
			(*result after a 0->1 leading
edge from start: 2#101*)
	END_VAR

POE-Rumpf

Wenn die Variable bStart auf TRUE gesetzt wird, wird die Funktion ausgeführt.

KOP-Rumpf

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 6 ;
        NETWORK_BODY
B(B_F,FP_INVERT_BIT!,,11,1,20,6,,?DEN?Dn_Pos?Dd?Ad?AENO);
B(B_CONTACT,,bStart,5,2,7,4,R);
B(B_VARIN,,1,9,3,11,5,);
B(B_VARIN,,wOutput_value,9,4,11,6,);
L(1,3,5,3);
L(7,3,11,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST-Rumpf

IF DF(start) then
    FP_INVERT_BIT(n_Pos := 1, d := wOutput_value);
END_IF;

Letzte Änderung am: 2019-10-10Feedback zu dieser SeitePanasonic Hotline