Décalage à droite de plusieurs bits d’une zone de données de 16 bits
La fonction décale vers la droite les bits d’une zone de données de 16 bits spécifiée, dont le début et la fin sont spécifiés par les sorties d1 et d2. n indique le nombre de bits de la zone de données, qui doit être décalé vers la droite. La valeur peut être entre 0 et 16. Les bits effacés à cause du décalage sont mis à 0. Lorsque l’entrée n = 0, aucun décalage n’est exécuté. Lorsque l’entrée n = 16, un mot est décalé, c.-à-d. que le processus est le même que si la fonction F110_WHSL avait été utilisée.
Entrée
Nombre de bits à décaler
Sortie
Adresse de départ de la zone de 16 bits
Adresse de fin de la zone de 16 bits
Au lieu d’utiliser cette instruction F, nous recommandons d’utiliser l’instruction FP7 correspondante :
Les adresses des variables en entrées d1_Start et d2_End doivent être du même type.
si l’adresse des variables en sortie d1_Start > d2_End ou la valeur en entrée n est ³ 16.
si l’adresse des variables en sortie d1_Start > d2_End ou la valeur en entrée n est ³ 16.
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
start: BOOL:=FALSE;
(*activates the function*)
data_array: ARRAY [0..2] OF WORD:=[16#1234,16#5678,16#9012];
(*result after a 0->1 leading edge
from start:
[16#8123,16#0567,16#9012]*)
END_VAR
Dans cet exemple, la variable d’entrée number_bits est déclarée. Vous pouvez aussi entrer directement une constante au contact d’entrée de la fonction.
La fonction est exécutée lorsque la variable start passe de FALSE à TRUE.
4 bits sont décalés vers la droite (correspondant à une position dans une représentation hexadécimale) Les 4 bits dans data_field[2], résultant du décalage, sont complétés par des zéros.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_VARIN,,number_bits,5,2,7,4,);
B(B_VAROUT,,data field[0],16,2,18,4,);
B(B_VAROUT,,data field[2],16,3,18,5,);
B(B_F,F108_BITR,,7,0,16,5,,?DEN?Dn?AENO?Cd1?Cd2);
B(B_CONTACT,,output,3,1,5,3,R);
L(1,0,1,5);
L(1,2,3,2);
L(5,2,7,2);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF DF(start) then
F108_BITR( n:=number_bits,
d1_Start=> data_field[0],
d2_End=> data_field[2]);
END_IF;