Truncar (cortar) los dígitos decimales de una variable de entrada tipo REAL o LREAL, convertir en DOUBLE INTEGER
TRUNC_TO_DINT trunca los dígitos decimales del número REAL, LREAL y devuelve un valor del tipo de datos DOUBLE INTEGER.
Si se truncan los dígitos decimales, se reducen los números positivos hacia cero y se incrementan los números negativos hacia cero.
Puesto que los números de tipo REAL tienen una resolución de 7 dígitos, se perderá información para los números largos.
Entrada
Tipo de datos de entrada
Salida
Resultado de la conversión
si la variable de entrada no es de tipo REAL
la variable de salida es mayor que un doble entero de 32 bits
si la salida es cero
Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU. Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.
VAR
REAL_value: TRUNC;
DINT_value: DINT:=0;
END_VAR
En este ejemplo se utilizan variables. También puede utilizarse una constante para la variable de entrada.
Se truncan los dígitos decimales de REAL_value. El resultado se almacena como un DOUBLE INTEGER de 32 bits en DINT_value.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 2 ;
NETWORK_BODY
B(B_F,TRUNC_TO_DINT!,Instance,10,0,19,2,,?D?C);
B(B_VARIN,,REAL_value,8,0,10,2,);
B(B_VAROUT,,DINT_value,19,0,21,2,);
L(1,0,1,2);
END_NETWORK_BODY
END_NET_WORK
END_BODY
DINT_value:=TRUNC_TO_DINT(REAL_value);
LD |
REAL_value |
TRUNC_TO_DINT |
|
ST |
DINT_value |