16비트 데이터 테이블의 데이터 정렬
입력
정렬할 데이터 테이블의 시작 영역
정렬할 데이터 테이블의 끝 영역
정렬 순서 지정:
0 = 오름차순
1 = 내림차순
F 명령을 사용하는 대신 해당 FP7 명령을 사용하는 것이 좋습니다.FP_DATA_SORT
데이터는 입력 s3_Descending에서 입력한 값에 따라 지정한 순서의 버블 정렬을 통해 정렬됩니다. 워드 비교 수는 워드 수 제곱에 비례하여 증가하므로, 워드 수가 크면 정렬 프로세스에 시간이 걸릴 수 있습니다. 입력에서의 값이 s1_Start=s2_End인 경우, 정렬이 수행되지 않습니다.
인덱스 한정자를 사용하여 지정한 영역이 제한을 초과하는 경우.
입력 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 INT:=[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
변수 start가 TRUE로 설정되면 펑션이 실행됩니다.
입력 s3에서 정수 0이 지정됩니다. 즉, 정렬이 오름차순으로 실행됩니다. 하지만 POU 헤더에서 변수를 선언하고 입력 s3에서 본문의 함수에 쓸 수 있습니다.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,8,1,10,3,);
B(B_VARIN,,data field[0],8,2,10,4,);
B(B_VARIN,,data field[4],8,3,10,5,);
B(B_F,F277_SORT,,10,0,19,6,,?DEN?D@'s1'?Ds2?Ds3?AENO);
B(B_VARIN,,0,8,4,10,6,);
B(B_COMMENT,,sorting order:ø^s3 = 0:ascending~ 1:descending,11,6,26,8,);
L(1,0,1,9);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF start then
F277_SORT( s1_Start:= data_field[0],
s2_End:= data_field[4],
s3_Descending:= 0);
END_IF;