[matlab] ZigZag-Scanning (2-D Array)
Attachment '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 와 같다.
![no_03.png](https://www.hooni.net/xe/files/attach/images/207/918/074/47f1d06633650eb51fa99ffb891579ca.png)
3. 위의 2번의 결과 배열의 좌/우를 뒤집는다. (fliplr() 함수 사용)
결과는 다음 afterFliplr2 와 같다.
![no_04.png](https://www.hooni.net/xe/files/attach/images/207/918/074/0c8b8dab1f5d1e2aa099ef3bb2779e09.png)
4. 위의 3번의 결과 배열의 홀수번째 컬럼의 위/아래를 뒤집는다. (flipud()함수 사용)
결과는 다음 afterFlipud 과 같다.
![no_05.png](https://www.hooni.net/xe/files/attach/images/207/918/074/3291fd8e38c8483778363ffe377043cd.png)
5. 위의 5번의 결과 배열에서 0을 제거하고 1차원 배열로 출력한다.
결과는 다음 orderNonZero 와 같다.
![no_06.png](https://www.hooni.net/xe/files/attach/images/207/918/074/76edaeb5681221587d59c9e581519a2f.png)
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
# 관련 함수 설명
![fliplr.png](https://www.hooni.net/xe/files/attach/images/207/918/074/dcfce0e15380f613f3098eb03d5993c1.png)
![spdiags.png](https://www.hooni.net/xe/files/attach/images/207/918/074/07274bbfbd84cdfed8ba1c0957b845ac.png)
![flipud.png](https://www.hooni.net/xe/files/attach/images/207/918/074/e734ebb44f234cbdbda8cebc83f93dd2.png)
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
157 | Develop |
[ios] Xcode를 사용해서 Static Library 만들기 (시뮬레이터 + 디바이스)
![]() |
hooni | 2015.01.03 | 3398 |
156 | Develop |
[ios] iOS앱의 Xcode 빌드 과정
![]() |
hooni | 2015.01.03 | 2390 |
155 | Develop |
[ios] APNS에 사용할 인증서 만들기 (KeyChain에 있는 인증서 Export)
![]() |
hooni | 2015.01.03 | 981 |
154 | Develop |
[ios] binary를 C코드로 변환
![]() |
hooni | 2015.01.03 | 1643 |
153 | Develop |
[ios] Xcode의 디버그 모드에서 콜스택
![]() |
hooni | 2015.01.03 | 1106 |
152 | Develop |
[ios] iOS 앱 아이콘을 만드는 유틸
![]() |
hooni | 2015.01.03 | 941 |
151 | Develop |
[maven] Mac OS에 메이븐(maven) 설치하기
![]() |
hooni | 2015.01.21 | 1218 |
150 | Develop |
[php] XE에서 도메인 별로 광고 다르게 적용하기
![]() |
hooni | 2015.01.28 | 700 |
149 | Develop |
[php] XE 스킨에서 특정 도메인 리다이렉션
![]() |
hooni | 2015.01.28 | 673 |
148 | Develop |
[js] 2048 예쁘게 만들고 있는거.. ㅋㄷ
![]() |
hooni | 2015.01.30 | 0 |
147 | Develop | [ios] URL 랜딩 속도(OpenURL 10초 정지되는) 이슈 | hooni | 2015.02.09 | 920 |
146 | Develop | [ios] 문자열로 함수 실행하기 (eval 함수처럼) | hooni | 2015.02.10 | 925 |