INT 수로 구성된 데이터 테이블에서 총 수와 평균 수 계산
이 FP 명령은 s1_Start와 s2_End에서 지정한 데이터 테이블에서 INT의 양수와 음수의 합계와 산술 평균을 계산합니다. 데이터 테이블의 모든 요소 합계는 출력 d1_Sum에서 반환되고 데이터 테이블의 모든 요소 산술 평균은 출력 d2_Mean에서 반환됩니다. 정수가 아니면 산술 평균은 반올림됩니다.
입력
데이터 테이블 시작
데이터 테이블 끝
출력
지정된 데이터 테이블 영역 내 모든 요소의 합계
지정된 데이터 테이블 영역 내 모든 요소의 평균
인덱스 한정자를 사용하여 지정한 영역이 제한을 초과하는 경우.
s1_Start>s2_End인 경우
s1_Start와 s2_End가 서로 다른 데이터 영역에 속하는 경우.
인덱스 한정자를 사용하여 지정한 영역이 제한을 초과하는 경우.
s1_Start>s2_End인 경우
s1_Start와 s2_End가 서로 다른 데이터 영역에 속하는 경우.
이 펑션 프로그램 시 사용한 모든 입력과 출력 변수는 POU 헤더에서 선언되었습니다.모든 프로그래밍 언어에 같은 POU 헤더를 사용합니다.
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
변수 bStart가 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;