16位数据表中的最大值搜索
该功能搜索16位数据表中的最大值及其位置。
输入
数据表的开头
数据表的结尾
输出
最大值
最大值的位置
输入s1_Start可指定数据表的开始区域,s2_End可指定结束区域。最大值返回到输出Max,其位置返回到输出Pos。
位置Pos是相对于数据表开始位置到最大值第一次出现的位置。
如果使用索引寄存器指定的区域超出限制。
如果输入处的变量地址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 INT:=[4,7,-32,13,5];
output_max: INT:=0;
(*the maximum value of
data_array; here: 13*)
output_pos: INT:=0;
(*the position of the
maximum value; here: 3*)
END_VAR
当变量start设置为TRUE时,执行此函数。
在data_field中查找最大值及其位置。result如下:maximum_value = 6,position = 2。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,5,1,7,3,);
B(B_VARIN,,data field[0],5,2,7,4,);
B(B_VARIN,,data field[4],5,3,7,5,);
B(B_VAROUT,,maximum,15,2,17,4,);
B(B_F,F270_MAX,,7,0,15,5,,?DEN?D@'s1'?Ds2?AENO?Cmax?Cpos);
B(B_VAROUT,,position,15,3,17,5,);
L(1,0,1,5);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start then
F270_MAX( s1_Start:= data_field[0],
s2_End:= data_field[4],
Max=> maximum_value,
Pos=> position);
END_IF;