实数数据表(浮点数据)中的最大值查找
该函数可搜索浮点数据数据表中的最大值及其位置。
输入
数据表的开头
数据表的结尾
输出
最大值
最大值的位置
输入s1_Start可指定数据表的开始区域,s2_End可指定结束区域。最大值返回到输出Max,其位置返回到输出Pos。
位置Pos相对于数据表开头到最大值第一次出现的位置。
如果找到多个最大值,则从s1_Start指定的起始地址开始找到的第一个最大值将存储在Max中。
如果输入处的变量地址s1_Start > s2_End。
如果输入s1_Start和s2_End处的值的地址区域不同。
如果浮点值超出处理范围。
如果输入处的变量地址s1_Start > s2_End。
如果输入s1_Start和s2_End处的值的地址区域不同。
如果浮点值超出处理范围。
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
start: BOOL:=FALSE;
(*activates the function*)
data_array: ARRAY [0..4] OF REAL:=[4.0,7.0,-32.0,13.0,5.0];
output_max: REAL:=0.0;
(*the maximum value of
data_array; here: -32.0*)
output_pos: INT:=0;
(*the position of the
maximum value; here: 2*)
END_VAR
当变量start设置为TRUE时,执行此函数。
然后在data_field中查找最大值及其位置。result如下:max_value = 5.44,position = 3。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_VARIN,,output,8,1,10,3,);
B(B_VARIN,,data field[0],8,2,10,4,);
B(B_VARIN,,data field[4],8,3,10,5,);
B(B_VAROUT,,max_value,19,2,21,4,);
B(B_F,F350_FMAX,,10,0,19,5,,?DEN?D@'s1'?Ds2?AENO?Cmax?Cpos);
B(B_VAROUT,,position,19,3,21,5,);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start then
F350_FMAX( s1_Start:= data_field[0],
s2_End:= data_field[4],
Max=> max_value,
Pos=> position);
END_IF;