浮点数据 -> 32位整数数据(不超过浮点数据的最大整数)
此函数在范围-2147483000至214783000中将输入s中的浮点数据转换为整数数据(包括+/-符号)。函数结果返回到输出d中。
输入
源REAL数数据(2个字)
输出
用于存储转换数据的目标
输出d中转换的整数值始终小于或等于输入s中的浮点值:
当输入中有正浮点值时,小数点前的正值将返回到输出。
当输入中有负浮点值时,小数点前的下一个最小值将返回到输出。
如果浮点值在小数点后只有零,将返回其小数点前的值。
如果输入s中的值不是REAL数,或转换结果超过d中的32位区域。
如果输入s中的值不是REAL数,或转换结果超过d中的32位区域。
如果计算结果为0。
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
start: BOOL:=FALSE;
(*activates the function*)
input_value: REAL:=-1234567.89;
output_value: DINT:=0;
(*result after a 0->1 leading
edge from start: -1234568*)
END_VAR
在此例中,声明了输入变量input_value。但是,可以直接在函数的输入触点处写入常量。
当变量start设置为TRUE时,执行此函数。
它将浮点值-1234567.89转换为整数值-1234568,并传输到output中的变量output_value。由于整数可能不超过浮点值,此处函数向下舍入。BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 5 ;
NETWORK_BODY
B(B_F,F328_DINT!,Instance,12,1,19,5,,?DEN?D@'s'?AENO?Cd);
B(B_VARIN,,input_value,10,3,12,5,);
B(B_VAROUT,,output_value,19,3,21,5,);
B(B_CONTACT,,start,8,2,10,4,);
L(1,3,8,3);
L(10,3,12,3);
L(1,0,1,5);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start THEN
F328_DINT(input_value, output_value);
END_IF;