浮点数据表中的总数和平均数计算
此函数计算指定的32位数据表中浮点值(带+/-号)的总和与算术均数。
输入
数据表的开始区域
数据表的结束区域
输出
指定的数据表区域中所有元素的总和
指定的数据表区域中所有元素的平均数
输入s1_Start可指定数据表的开始区域,s2_End可指定结束区域。数据表中所有元素的总和返回到输出Sum,数据表中所有元素的算术均数返回到输出Mean。
建议使用相应的FP7指令,来代替使用此F型指令:
如果输入处的变量地址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];
(*result after a 0->1 leading
edge from start:
[-32.0,4.0,5.0,7.0,13.0]*)
asc_order: INT:=0;
(*which way to sort:
0 means ascending order
1 means descending order*)
END_VAR
当变量start设置为TRUE时,执行此函数。
计算 sum = 2.0 + 3.45 + (-6.91) + 5.44 + 1.3 = 5.28
并且 mean = Sum/5 = 5.28/5 = 1.056
(data_field中的元素)。
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,,sum,19,2,21,4,);
B(B_F,F352_FMEAN,,10,0,19,5,,?DEN?D@'s1'?Ds2?AENO?Csum?Cmean);
B(B_VAROUT,,mean,19,3,21,5,);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start then
F352_FMEAN( s1_Start:= data_field[0] ,
s2_End:= data_field[4] ,
Sum=> sum ,
Mean=> mean );
END_IF;