Truncar (cortar) los dígitos decimales de una variable de entrada tipo REAL o LREAL, convertir a DOUBLE INTEGER sin signo
TRUNC_TO_UDINT trunca los dígitos decimales del número REAL, LREAL y devuelve un valor del tipo de datos DOUBLE INTEGER sin signo.
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
UDINT_value: UDINT:=0;
REAL_value: REAL:=78497.79;
END_VAR
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,TRUNC_TO_UDINT!,Instance,13,2,23,4,,?D?C);
B(B_VARIN,,REAL_value,11,2,13,4,);
B(B_VAROUT,,UDINT_value,23,2,25,4,);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
UDINT_value := TRUNC_TO_UDINT(REAL_value);