32비트 데이터 테이블의 데이터 정렬(더 작은 숫자 순이나 더 큰 숫자 순으로)
입력
정렬할 데이터 테이블의 시작 영역
정렬할 데이터 테이블의 끝 영역
정렬 순서 지정:
0 = 오름차순
1 = 내림차순
F 명령을 사용하는 대신 해당 FP7 명령을 사용하는 것이 좋습니다.FP_DATA_SORT
데이터는 입력 s3_Descending에서 입력한 값에 따라 지정한 순서의 버블 정렬을 통해 정렬됩니다. 워드 비교 수는 워드 수 제곱에 비례하여 증가하므로, 워드 수가 크면 정렬 프로세스에 시간이 걸릴 수 있습니다. 입력에서의 값이 s1_Start=s2_End인 경우, 정렬이 수행되지 않습니다.
이것은 32비트 명령이지만 그 단계의 개수는 16비트 명령과 동일합니다.
인덱스 한정자를 사용하여 지정한 영역이 제한을 초과하는 경우.
입력 s1_Start의 변수 어드레스가 s2_End보다 큰 경우
s1_Start와 s2_End가 서로 다른 데이터 영역에 속하는 경우.
인덱스 한정자를 사용하여 지정한 영역이 제한을 초과하는 경우.
입력 s1_Start의 변수 어드레스가 s2_End보다 큰 경우
s1_Start와 s2_End가 서로 다른 데이터 영역에 속하는 경우.
이 펑션 프로그램 시 사용한 모든 입력과 출력 변수는 POU 헤더에서 선언되었습니다. 모든 프로그래밍 언어에 같은 POU 헤더를 사용합니다.
VAR
start: BOOL:=FALSE;
(*activates the function*)
data_array: ARRAY [0..4] OF DINT:=[4,7,-32,13,5];
(*result after a 0->1 leading
edge from start: [-32,4,5,7,13]*)
asc_order: INT:=0;
(*which way to sort:
0 means ascending order
1 means descending order*)
END_VAR
이 예에서는 입력 변수 sort_order가 선언됩니다. 하지만 함수의 입력 접점에 직접 정수를 쓸 수 있습니다.
변수 start가 TRUE로 설정되면 펑션이 실행됩니다.
변수 sort_order가 1로 설정되므로, 지정된 데이터 필드는 내림차순으로 정렬됩니다.BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 9 ;
NETWORK_BODY
B(B_VARIN,,output,7,1,9,3,);
B(B_VARIN,,data field[0],7,2,9,4,);
B(B_VARIN,,data field[4],7,3,9,5,);
B(B_F,F278_DSORT,,9,0,18,6,,?DEN?D@'s1'?Ds2?Ds3?AENO);
B(B_VARIN,,sort_order,7,4,9,6,);
B(B_COMMENT,,sorting order:ø^s3 = 0:ascending~ 1:descending,10,6,25,8,);
L(1,0,1,9);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start then
F278_DSORT( s1_Start:= data_field[0],
s2_End:= data_field[4],
s3_Descending:= sort_order);
END_IF;