FP_INVERT

Inversion de données (complément à un)

Cette instruction FP inverse chaque bit (0 ou 1) de la zone de données spécifiée par d lorsque le déclencheur EN est TRUE. Le résultat est sauvegardé dans la zone de données spécifiée par d. Cette instruction est utile pour contrôler un périphérique utilisant une opération logique négative.

Paramètres

Entrée/sortie

d (WORD, DWORD)

Zone de bits à inverser

Drapeaux d’erreur

sys_bIsOperationErrorHold (passe à TRUE et reste TRUE)
  • Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.

sys_bIsOperationErrorNonHold (passe à TRUE pendant un cycle)
  • Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.

Exemple

En-tête du POU

Toutes les variables d’entrée et de sortie utilisées pour programmer cette fonction ont été déclarées dans l’en-tête du POU. Le même en-tête de POU est utilisé pour tous les langages de programmation.

	VAR
		bStart: BOOL:=FALSE;
			(*activates the function*)
		wInvert_value: WORD:=2#111000111000;
			(*result after a 0->1 leading
edge from start:
2#000111000111*)
	END_VAR

Corps du POU

La fonction est exécutée lorsque la variable bStart passe de FALSE à TRUE.

Corps en LD

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 4 ;
        NETWORK_BODY
B(B_F,FP_INVERT!,,12,0,19,4,,?DEN?Dd?Ad?AENO);
B(B_CONTACT,,bStart,7,1,9,3,R);
B(B_VARIN,,wInvert_value,10,2,12,4,);
L(1,2,7,2);
L(9,2,12,2);
L(1,0,1,4);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Corps en ST

IF DF(bStart) then
    FP_INVERT(d := wInvert_value);
END_IF;

Modifié le : 2019-04-04Commentaires sur cette pageAssistance téléphonique