Sumatorio y media de datos de 16 bits
Esta función calcula la suma y la media aritmética de los números (positivos y negativos) de la tabla de datos de 16 bits especificada.
Entrada
área inicial de la tabla de datos
área final de la tabla de datos
Salida
suma de todos los elementos de la tabla especificada
media de todos los elementos de la tabla especificada
La entrada s1_Start especifica el área inicial de la tabla de datos, y s2_End el final. La suma de todos los elementos de la tabla se devuelve enSum y la media aritmética en Mean. La media aritmética se redondea a un número entero.
si el área especificada utilizando el modificador índice supera el límite.
si la dirección de la variable de entrada s1_Start > s2_End.
Si s1_Start y s2_End pertenecen a diferentes áreas de datos
si el área especificada utilizando el modificador índice supera el límite.
si la dirección de la variable de entrada s1_Start > s2_End.
Si s1_Start y s2_End pertenecen a diferentes áreas de datos
si el sumatorio produce un desbordamiento del rango de datos de 16 bits.
Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU. Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.
VAR
start: BOOL:=FALSE;
(*activates the function*)
data_array: ARRAY [0..4] OF INT:=[4,7,-32,13,5];
sum: DINT:=0;
(*the sum of all elements of
data_array; here: -3*)
mean: INT:=0;
(*the arithmetic mean of all
elements of data_array;
here: 0*)
END_VAR
Cuando la variable start está ajustada a TRUE, se ejecuta la función. La función calcula la suma de todos los elementos de la tabla de datos (sum = 4 + 3 + 8 + (-2) + 1 + (-6) = 8
) y lleva el resultado (8 en este caso) a la variable sum. Además, la función calcula la media aritmética de todos los elementos de la tabla de datos (media = sum/6 = (4 + 3 + 8 + (-2) + 1 + (-6)) / 6 = 1,333)
y escribe el resultado con redondeo (1 en este caso) en la variable mean.
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_F,F275_MEAN,,10,0,19,5,,?DEN?D@'s1'?Ds2?AENO?Csum?Cmean);
B(B_VAROUT,,sum,19,2,21,4,);
B(B_VAROUT,,mean,19,3,21,5,);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start then
F275_MEAN( s1_Start:= data_field[0],
s2_End:= data_field[4],
Sum=> sum,
Mean=> mean);
END_IF;