FP_MOVE_BLOCK

Déplacer des blocs de données

Cette instruction FP déplace des blocs de données de la zone de données spécifiée par s1_Start et s2_End vers le bloc de données à partir de d_Start, lorsque le déclencheur EN est TRUE.

Paramètres

Entrée

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

Adresse de départ de la zone de données source

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

Adresse de fin de la zone de données source

Sortie

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

Adresse de départ de la zone de données de destination

Remarques

  • Les conditions suivantes s’appliquent :

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

    • Les opérandes s1_Start et s2_End doivent être dans la même zone mémoire, par ex. DT, WR, FL, LD,...

    • s1_Start£s2_End

  • Lorsque s1_Start, s2_End et d_Start sont dans la même zone de données :

    • s1_Start=d_Start : l’instruction ne sera pas exécutée.

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.
  • Si s1_Start > s2_End

  • Si la zone de destination 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.
  • Si s1_Start > s2_End

  • Si la zone de destination 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*)
		aiSource_Array: ARRAY [0..4] OF INT:=[1,2,3,4,5];
		aiTarget_Array: ARRAY [0..2] OF INT:=[3(0)];
			(*result after a 0->1 leading edge
from start: [2,3,4]*)
	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 := 6 ;
        NETWORK_BODY
B(B_CONTACT,,bStart,6,2,8,4,);
B(B_VARIN,,aiSource_Array[1],11,3,13,5,);
B(B_VARIN,,aiSource_Array[3],11,4,13,6,);
B(B_VAROUT,,aiTarget_Array[0],23,3,25,5,);
B(B_F,FP_MOVE_BLOCK!,,13,1,23,6,,?DEN?Ds1_Start?Ds2_End?AENO?Cd_Start);
L(1,3,6,3);
L(8,3,13,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Corps en ST

If (bStart) then
    FP_MOVE_BLOCK(s1_Start := aiSource_Array[0], s2_End := aiSource_Array[3], d_Start => aiTarget_Array[0]);
End_if;

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