Calculer sommes et moyennes de nombres DINT dans un tableau de données
Cette instruction FP calcule la somme et la moyenne arithmétique de nombres DINT 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
diMean: DINT:=0;
(*the arithmetic mean of all elements of data_array; here: 2*)
adiSum: ARRAY [0..1] OF DINT:=[2(0)];
(*the sum of all elements of data_array; here: 6*)
adiDataField: ARRAY [0..2] OF DINT:=[3,-1,4];
bStart: BOOL:=FALSE;
(*activates the function*)
END_VAR
La fonction est exécutée lorsque la variable bStart est définie sur TRUE.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 5 ;
NETWORK_BODY
B(B_CONTACT,,bStart,4,1,6,3,);
B(B_F,FP_DATA_MEAN_SUM_DINT0!,,14,0,28,5,,?DEN?Ds1_Start?Ds2_End?AENO?Cd1_Sum?Cd2_Mean);
B(B_VARIN,,adiDataField[0],12,2,14,4,);
B(B_VAROUT,,adiSum,28,2,30,4,);
B(B_VARIN,,adiDataField[2],12,3,14,5,);
B(B_VAROUT,,diMean,28,3,30,5,);
L(1,0,1,5);
L(1,2,4,2);
L(6,2,14,2);
END_NETWORK_BODY
END_NET_WORK
END_BODY
if (bStart) then
FP_DATA_MEAN_SUM_DINT0(s1_Start := adiDataField[0],
s2_End := adiDataField[2],
d1_Sum => diSum,
d2_Mean => diMean);
End_if;