DCT 코드 일부분이 이해가 안됩니다.
연분홍
질문 제목 : dct 코드 관련dct 코드를 분석중입니다. dct가 어떤 역할을 하는 모듈인지는 대략적으로 알고있는데,
분석 도중 이해가 되지 않는 부분이 있어서요 ㅜㅜ 막히네요.. 아침부터.. 이 함수만 붙잡고 있었어요 ㅜㅜ...
동영상 압축 프로세실 과정 중 dct 함수에 대하여 잘 아시는분 계시면 답변 부탁드려요.,질문 내용 :
int dct(short* inblock, short* outblock)
{
const short f0=32767;
const short f1=32138;
const short f2=30273;
const short f3=27245;
const short f4=23170;
const short f5=18204;
const short f6=12539;
const short f7=6392;
int j1, i, j;
short b[8];
short b1[8];
short d[8][8];
short *inblock_addr = inblock;
short *outblock_addr = outblock;
short *d_addr;
d_addr = &(d[0][0]);
for (i = 0; i 8; i++, d_addr+=8) {
for (j = 0; j 8; j++) {
b[j] = (*inblock_addr++);
}
b1[0] = b[0] + b[7];
b1[7] = b[0] - b[7];
b1[1] = b[1] + b[6];
b1[6] = b[1] - b[6];
b1[2] = b[2] + b[5];
b1[5] = b[2] - b[5];
b1[3] = b[3] + b[4];
b1[4] = b[3] - b[4];
b[0] = b1[0] + b1[3];
b[1] = b1[1] + b1[2];
b[2] = b1[1] - b1[2];
b[3] = b1[0] - b1[3];
b[4] = b1[4];
b[5] = ((b1[6] - b1[5]) * f0)16;
b[6] = ((b1[6] + b1[5]) * f0)16;
b[7] = b1[7];
*(d_addr) = ((b[0] + b[1]) * f4)18;
*(d_addr+4) = ((b[0] - b[1]) * f4)18;
*(d_addr+2) = (b[2] * f6 + b[3] * f2)18;
*(d_addr+6) = (b[3] * f6 - b[2] * f2)18;
b1[4] = b[4] + b[5];
b1[7] = b[7] + b[6];
b1[5] = b[4] - b[5];
b1[6] = b[7] - b[6];
*(d_addr+1) = (b1[4] * f7 + b1[7] * f1)18;
*(d_addr+5) = (b1[5] * f3 + b1[6] * f5)18;
*(d_addr+7) = (b1[7] * f7 - b1[4] * f1)18;
*(d_addr+3) = (b1[6] * f3 - b1[5] * f5)18;
}
진한 글자 부분의 코드가 왜 저렇게 작성되었는지 알려주시면 감사하겠습니다.
f0~f7이 들어오는 inblock을 계수행렬로 바꾸기 위한 변환계수의 역할을 하는것인지,
그리고 b[0]에서 b[7]까지 위에 작업 처럼 inblock 행렬이 좌우대칭이라 행렬을 또 줄이는 작업을 하는것인지...
shift 16과 shift 18은 왜 하는것이고, 최종적으로 배열b마다 f상수를 다 곱하는데, 정말 계수의 역할이라 저런 작업을 하는것인지..
dct 역할과 알고리즘 흐름정도만 알았지 ㅠㅠ 코드로 보니 왜 저렇게 짠건지 모르겠어요 ㅠㅜ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |