Bloque que ejecuta una operación de desplazamiento lógico binario a la derecha en un valor pasado por Value, almacenando el resultado en Result.
Representación Ladder

Estructura del Bloque
Tipo de Variable |
Nombre |
Tipo de Dato |
Descripción |
VAR_INPUT |
EN |
BOOL |
Habilitación del bloque |
Value |
BYTE USINT SINT WORD UINT INT DWORD UDINT DINT |
Variable a sufrir desplazamiento |
|
Shift |
BYTE USINT |
Indice de desplazamiento |
|
VAR_OUTPUT |
ENO |
BOOL |
Fin de operación |
Result |
BYTE USINT SINT WORD UINT INT DWORD UDINT DINT |
Variable que almacena el resultado de la operación |
Operación
Este bloque, cuando tiene un valor TRUE en EN, envía a la salida Result el valor de la variable Value luego de realizar un determinado número de desplazamientos lógicos a la derecha, de acuerdo con el valor de Shift.
Cuando EN tiene valor FALSE, Result permanece inalterado.
El valor de ENO pasa al próximo bloque Ladder el valor de EN luego de finalizada la operación.
Diagrama de Flujo del Bloque

Ejemplo en Ladder

El ejemplo de arriba realiza un desplazamiento lógico a la derecha de dos posiciones en la variable VALUE, cuyo valor inicial es 124 (0111 1100 en binario). Los bits a la derecha van siendo descartados, y a la izquierda son insertados nuevos ceros. El resultado final (0001 1111 en binario) es almacenado en RESULT.

El ejemplo de arriba realiza un desplazamiento lógico a la derecha de tres posiciones en la variable VALUE, cuyo valor inicial es -98 (1001 1110 en binario). Los bits a la derecha van siendo descartados, y a la izquierda son insertados nuevos ceros. El resultado final (0001_0011 en binario) es almacenado en RESULT.
Ejemplo en ST
El siguiente ejemplo muestra las instrucciones para aplicar el ejemplo anterior en el lenguaje ST.
VAR VALUE : SINT := -98; SHIFT : BYTE := 3; RESULT : INT; END_VAR
RESULT := FB_SHR( EN:=DI1, Value:=VALUE, Shift:=SHIFT, ENO=>DO1);
|
|---|