Calculer sommes et moyennes de nombres INT dans un tableau de données
Cette instruction FP calcule la somme et la moyenne arithmétique de nombres INT positifs et négatifs dans le tableau de données, spécifié par s1_Start et s2_End. La somme de tous les éléments du tableau de données est renvoyée en sortie d1_Sum et la moyenne arithmétique de tous les éléments du tableau de données est renvoyée en sortie d2_Mean. La moyenne arithmétique est arrondie lorsque la valeur n’est pas un nombre entier.
Entrée
Zone de départ du tableau de données
Zone finale du tableau de données
Sortie
Somme de tous les éléments du tableau de données indiqué
Moyenne de tous les éléments du tableau de données indiqué
Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.
Si s1_Start>s2_End
Si s1_Start et s2_End appartiennent à différentes zones de données.
Si la zone spécifiée à l’aide du modificateur d’adresse est en dehors des limites autorisées.
Si s1_Start>s2_End
Si s1_Start et s2_End appartiennent à différentes zones de données.
Instructions F correspondantes : F275_MEAN, F276_DMEAN, F352_FMEAN
Toutes les variables d’entrée et de sortie utilisées pour programmer cette fonction ont été déclarées dans l’en-tête du POU.Le même en-tête de POU est utilisé pour tous les langages de programmation.
VAR
bStart: BOOL:=FALSE;
(*activates the function*)
aiDataField: ARRAY [0..4] OF INT:=[2,3,6,-3,1];
diSum: DINT:=0;
(*the sum of all elements of
data_array; here: 9*)
iMean: INT:=0;
(*the arithmetic mean of all
elements of data_array;
here: 1*)
END_VAR
La fonction est exécutée lorsque la variable bStart est définie sur TRUE.
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_CONTACT,,bStart,6,2,8,4,);
B(B_VARIN,,aiDataField[0],10,3,12,5,);
B(B_VARIN,,aiDataField[4],10,4,12,6,);
B(B_VAROUT,,diSum,25,3,27,5,);
B(B_VAROUT,,iMean,25,4,27,6,);
B(B_F,FP_DATA_MEAN_SUM_INT!,,12,1,25,6,,?DEN?Ds1_Start?Ds2_End?AENO?Cd1_Sum?Cd2_Mean);
L(8,3,12,3);
L(1,3,6,3);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF bStart then
FP_DATA_MEAN_SUM_INT(s1_Start := aiDataField[0],
s2_End := aiDataField[4],
d1_Sum => diSum,
d2_Mean => iMean);
END_IF;