浮点数据 -> 16位整数数据(不超过浮点数据的最大整数)
此函数在范围-32767.99至32767.99中将输入s中的浮点数据转换为整数数据(包括+/-符号)。函数结果返回到输出d中。
输入
源REAL数数据(2个字)
输出
用于存储转换数据的目标
输出d中转换的整数值始终小于或等于输入s中的浮点值:
当输入中有正浮点值时,小数点前的正值将返回到输出。
当输入中有负浮点值时,小数点前的下一个最小值将返回到输出。
如果浮点值在小数点后只有零,将返回其小数点前的值。
如果输入s中的值不是REAL数,或转换结果超过d中的16位区域。
如果输入s中的值不是REAL数,或转换结果超过d中的16位区域。
如果计算结果为0。
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
start: BOOL:=FALSE;
(*activates the function*)
input_value: REAL:=-1.234;
output_value: INT:=0;
(*result after a 0->1 leading
edge from start: 32*)
END_VAR
在此例中,声明了输入变量input_value。但是,可以直接在函数的输入触点处写入常量。
当变量start设置为TRUE时,执行此函数。它将浮点值-1.234转换为整数值-2,并传输到变量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_VARIN,,output,7,1,9,3,);
B(B_VARIN,,input_value,7,2,9,4,);
B(B_VAROUT,,output_value,17,2,19,4,);
B(B_F,F327_INT,,9,0,17,4,,?DEN?D@'s'?AENO?Cd);
L(1,0,1,5);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start THEN
F327_INT(input_value, output_value);
END_IF;