TRUNC_TO_UDINT

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.

NOTA
  • 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.

Parámetros

Entrada

Unnamed input (REAL, LREAL)

Tipo de datos de entrada

Salida

Unnamed output (UDINT)

Resultado de la conversión

Banderas de error

sys_bIsOperationErrorHold (pasa a TRUE y permanece TRUE)

si la variable de entrada no es de tipo REAL

sys_bIsOperationErrorNonHold (pasa a TRUE para un ciclo de scan)

la variable de salida es mayor que un doble entero de 32 bits

sys_bIsCarry (pasa a TRUE para un ciclo de scan)

si la salida es cero

Ejemplo

Cabecera de la POU

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

Cuerpo 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,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

Cuerpo en ST

UDINT_value := TRUNC_TO_UDINT(REAL_value);

Modificado el: 2022-11-15Comentarios sobre esta páginaLínea directa de Panasonic