FP_MOVE3

Déplacer trois valeurs vers une zone de destination

Cette instruction FP copie trois valeurs d’entrée vers une zone de destination définie par d_Start.

Paramètres

Entrée

s1, s2, s3 (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

Zone source

Sortie

d_Start (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

Zone de destination

Remarques

Les variables d’entrée et de sortie doivent être du même type de données.

Drapeaux d’erreur

sys_bIsOperationErrorHold (passe à TRUE et reste TRUE)
  • Si les valeurs spécifiées à l’aide du modificateur d’adresse sont en dehors des limites autorisées.

  • Si la plage de transfert est en dehors des limites accessibles.

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

  • Si la plage de transfert est en dehors des limites accessibles.

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
		rArray: ARRAY[0..2] OF REAL:=[3(0.0)];
		bEnable: BOOL:=FALSE;
		rValue3: REAL:=5.6;
		rValue2: REAL:=3.4;
		rValue1: REAL:=1.2;
	END_VAR

Corps du POU

La fonction est exécutée lorsque la variable bEnable 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 := 6 ;
        NETWORK_BODY
B(B_VARIN,,rValue1,18,2,20,4,);
B(B_VARIN,,rValue2,18,3,20,5,);
B(B_VAROUT,,rArray[0],28,2,30,4,);
B(B_CONTACT,,bEnable,5,1,7,3,);
B(B_VARIN,,rValue3,18,4,20,6,);
B(B_F,FP_MOVE3!,,20,0,27,6,,?DEN?D@'s1'?Ds2?Ds3?AENO?Cd_Start);
L(1,2,5,2);
L(7,2,20,2);
L(27,3,28,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Corps en ST

If (bEnable) then
    FP_MOVE3(s1 := rValue1,
             s2 := rValue2,
             s2 := rValue3,
             d_Start => rArray[0]);
End_if;

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