F110_WSHR

Décalage à droite d’un mot (16 bits) d’une zone de données de 16 bits

Décale un mot (16 bits) de la zone de données spécifiée par d1 (début) et d2 (fin) vers la droite (décalage en direction du mot de poids faible) lorsque le déclencheur EN est TRUE.

Paramètres

Sortie

d1_Start (WORD, INT, UINT)

Adresse de départ de la zone de 16 bits

d2_End (WORD, INT, UINT)

Adresse de fin de la zone de 16 bits

Remarques

  • Au lieu d’utiliser cette instruction F, nous recommandons d’utiliser l’instruction FP7 correspondante : FP_WSHR_BLOCK

  • Lorsqu’un mot (16 bits) est décalé vers la droite, le mot de départ est décalé et les données dans le dernier mot prennent la valeur 0.

  • d1_Start et d2_End doivent être :

    • Le même type d’opérande

    • d1_Start£d2_End

  • Les variables d1_Start et d2_End doivent être du même type de données.

  1.  (1) Intervalle de données spécifié
  2.  (2) Le mot de départ est décalé
  3.  (3) Les données dans le mot de fin deviennent 0

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
		start: BOOL:=FALSE;
			(*activates the function*)
		source_array: ARRAY [0..3] OF INT:=[2,3,4,5];
			(*result after a 0->1 leading edge
from start: [2,4,5,0]*)
	END_VAR

Corps du POU

La fonction est exécutée lorsque la variable start passe de FALSE à 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_F,F110_WSHR!,Instance,6,1,13,6,,?DEN?AENO?Cd1_Start?Cd2_End);
B(B_VAROUT,,source_array[1],13,3,15,5,);
B(B_VAROUT,,source_array[3],13,4,15,6,);
B(B_CONTACT,,start,2,2,4,4,R);
L(1,3,2,3);
L(4,3,6,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Corps en ST

IF DF(start) then
    F110_WSHR( d1_Start=> source_array[1],
         d2_End=> source_array[3]);
END_IF;

Modifié le : 2023-05-11Commentaires sur cette pageAssistance téléphonique