Copier des données vers un bloc mémoire
Cette instruction FP copie les données ou constantes équivalentes spécifiées par s vers le bloc mémoire indiqué par d1_Start et d2_End, lorsque le déclencheur EN est TRUE.
Entrée
Valeur source qui doit être copiée
Sortie
Adresse de départ de la zone de données de destination
Adresse de fin de la zone de données de destination
Les variables d’entrée et de sortie doivent être du même type de données.
Les opérandes d1_Start et d2_End doivent être ainsi :
Dans la même zone mémoire, par ex. DT, WR, FL, LD,...
d1_Start £ d2_End
Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.
Si d1_Start > d2_End
Instructions F correspondantes : F11_COPY
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*)
aiDataField: ARRAY [0..6] OF INT:=[1,3,5,7,9,11,13];
(*result after a 0->1 leading
edge from start:
[1,3,5,11,11,11,13]*)
END_VAR
La fonction est exécutée lorsque la variable bStart est définie sur TRUE.
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_COPY!,,11,1,18,6,,?DEN?D@'s'?AENO?Cd1_Start?Cd2_End);
B(B_CONTACT,,bStart,3,2,5,4,);
B(B_VARIN,,11,9,3,11,5,);
B(B_VAROUT,,aiDataField[3],18,3,20,5,);
B(B_VAROUT,,aiDataField[5],18,4,20,6,);
L(1,3,3,3);
L(5,3,11,3);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF bStart then
(* Copy the value 11 to aiDataField[3], *)
(* aiDataField[4] and aiDataField[5] *)
FP_COPY(s := 11, d1_Start => aiDataField[3], d2_End => aiDataField[5]);
END_IF;