[matlab] ZigZag-Scanning (2-D Array)
첨부 '12' |
|
---|
[MatLab] ZigZag-Scanning (2-D Array)
# ZigZag-Scanning 과제 내용
주어진 2차원 배열을 다음 그림과 같이 지그재그 형태로 탐색하여 1차원 배열의 결과물을 만드는 MatLab 코드를 만들어야 함.
[이미지] https://en.wikipedia.org/wiki/JPEG
[참고] https://en.wikipedia.org/wiki/File:JPEG_ZigZag.svg
# MatLab 실행 영상
# 구현 방법
다음과 같은 2차원(3x3) 배열 Q가 있다고 할 때,
1. 원본 Q 배열의 좌/우를 뒤집는다. (fliplr() 함수 사용)
결과는 다음 afterFliplr1 과 같다.
2. 위의 1번의 결과 배열에서 대각 배열을 만든다. (spdiags() 함수 사용)
결과는 다음 afterSpdiags 와 같다.
3. 위의 2번의 결과 배열의 좌/우를 뒤집는다. (fliplr() 함수 사용)
결과는 다음 afterFliplr2 와 같다.
4. 위의 3번의 결과 배열의 홀수번째 컬럼의 위/아래를 뒤집는다. (flipud()함수 사용)
결과는 다음 afterFlipud 과 같다.
5. 위의 5번의 결과 배열에서 0을 제거하고 1차원 배열로 출력한다.
결과는 다음 orderNonZero 와 같다.
6. 위의 5번의 결과는 Q 배열을 탐색하는 인덱스의 순서이다.
MatLab에서 배열 인덱스는 1부터 시작하므로,
원본 Q 배열을 orderNonZero 인덱스의 순서대로 탐색하여 Zig-Zag 1차원 배열을 만들 수 있다.
결과는 다음 ZigZag 와 같다.
# MatLab 소스코드 (Ver.1)
clear all; clc; %% Test elements #1 Q = [1 2 3; 4 5 6; 7 8 9]; %% Test elements #2 Q = [01 02 06 07; 03 05 08 13; 04 09 12 14; 10 11 15 16]; %% Init tmp = reshape(1:numel(Q), size(Q)); %% Flip left/right -> Diagonal matrix -> Flip left/right again afterFliplr1 = fliplr( tmp ); afterSpdiags = spdiags( afterFliplr1 ); afterFliplr2 = fliplr( afterSpdiags ); %% Flip up/down(odd columns) afterFlipudOdd = afterFliplr2; afterFlipudOdd(:,1:2:end) = flipud( afterFliplr2(:,1:2:end) ); %% Remove zero orderNonZero = afterFlipudOdd; orderNonZero( orderNonZero==0 ) = []; %% Get elements (by zigzag-order) ZigZag = Q(orderNonZero) %keyboard
# MatLab 소스코드 (Ver.2)
clear all; clc; %% ZigZag %% %% Test array1 Q = [1 2 3; 4 5 6; 7 8 9]; %% Test array2 Q = [01 02 06 07; 03 05 08 13; 04 09 12 14; 10 11 15 16]; %% Init tmp = reshape(1:numel(Q), size(Q)); %% Flip left/right -> Diagonal matrix -> Flip left/right again order = fliplr( spdiags( fliplr(tmp) ) ); %% Flip up/down(odd columns) order(:,1:2:end) = flipud( order(:,1:2:end) ); %% Remove zero order(order==0) = []; %% Get elements (by zigzag-order) ZigZag = Q(order) keyboard
# 관련 함수 설명
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
1077 | Develop | [Xcode] 디버깅 옵션 | hooni | 2013.04.23 | 57194 |
1076 | Develop | [winmobile] 윈도우 모바일 간단한 테스트 코드 ㅋㅋ | hooni | 2013.04.23 | 17081 |
1075 | System/OS | [windows] 패스워드를 잊어먹었을때.. | hooni | 2003.04.23 | 17294 |
1074 | System/OS | [windows] 최근 열어본 문서목록 안나오게 하는 방법 | hooni | 2013.04.23 | 25471 |
1073 | System/OS | [windows] 종료, 재시작, 로그아웃 아이콘 만들기 | hooni | 2013.04.23 | 18102 |
1072 | System/OS | [windows] 인터넷 익스플로러(IE) 도구모음 표시줄에 아이콘 추가 | hooni | 2013.04.23 | 18217 |
1071 | System/OS | [windows] 윈도우즈 콘솔에서 정품인증 하는 방법 | hooni | 2017.05.24 | 5258 |
1070 | System/OS | [windows] 윈도우 사용자 계정 로그인 암호 분실, 암호 변경하는 방법 | hooni | 2015.07.09 | 20846 |
1069 | System/OS | [windows] 원격 데스크탑(터미널 서비스) 포트 변경 | hooni | 2013.04.23 | 16300 |
1068 | System/OS | [windows] 여러가지 활용 팁 | hooni | 2003.04.23 | 19963 |
1067 | System/OS | [windows] 배치(bat)파일 제작 방법 | hooni | 2003.04.23 | 16996 |
1066 | System/OS | [windows] 도스 사용 팁 | hooni | 2003.04.23 | 17800 |