FP_DATA_MEAN_SUM_INT

Summe und arithmetischen Mittelwert einer Datentabelle mit INT-Zahlen berechnen

Dieser FP-Befehl berechnet die Summe und den arithmetischen Mittelwert von positiven und negativen INT-Zahlen in der Datentabelle von s1_Start bis s2_End. Die Summe aller Elemente der Datentabelle wird am Ausgang d1_Sum und der arithmetische Mittelwert über alle Elemente der Datentabelle am Ausgang d2_Mean zurückgegeben. Wenn der arithmetische Mittelwert keine ganze Zahl ergibt, wird nur der Vorkommawert zurückgegeben.

Parameter

Eingang

s1_Start (INT)

Anfang der Datentabelle

s2_End (INT)

Ende der Datentabelle

Ausgang

d1_Sum (INT)

Summe aller in der Datentabelle spezifizierten Elemente

d2_Mean (INT)

Mittelwert aller in der Datentabelle spezifizierten Elemente

Fehleralarmmerker

sys_bIsOperationErrorHold (wird auf TRUE gesetzt und bleibt TRUE)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich

  • wenn s1_Start>s2_End

  • wenn s1_Start und s2_End zu verschiedenen Datenbereichen gehören

sys_bIsOperationErrorNonHold (wird für einen Zyklus auf TRUE gesetzt)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich

  • wenn s1_Start>s2_End

  • wenn s1_Start und s2_End zu verschiedenen Datenbereichen gehören

Beispiel:

POE-Kopf

Im POE-Kopf werden alle Ein- und Ausgangsvariablen deklariert, die für die Programmierung dieser Funktion verwendet werden.Für alle Programmiersprachen wird der gleiche POE-Kopf verwendet.

	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

POE-Rumpf

Wenn die Variable bStart auf TRUE gesetzt wird, wird die Funktion ausgeführt.

KOP-Rumpf

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

ST-Rumpf

IF bStart then
    FP_DATA_MEAN_SUM_INT(s1_Start := aiDataField[0], 
                         s2_End := aiDataField[4], 
                         d1_Sum => diSum, 
                         d2_Mean => iMean);
END_IF;

Letzte Änderung am: 2022-11-11Feedback zu dieser SeitePanasonic Hotline