FP_MOVE_INVERT

Inverser et déplacer des données

Cette instruction FP inverse logiquement les données ou constantes spécifiées par s et les transfère vers la zone de données indiquée par d, lorsque le déclencheur EN est TRUE.

Paramètres

Entrée

s (WORD, DWORD)

Données sources qui vont être inversées

Sortie

d (WORD, DWORD)

Données de destination

Remarques

Les variables s et d doivent être du même type de données.

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.
Thèmes apparentés

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*)
		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

Corps du POU

La fonction est exécutée lorsque la variable bStart est définie sur 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 := 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

Corps en ST

IF (bStart) then
    FP_MOVE_INVERT(s := wInput_value, d => wOutput_value);
END_IF;

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