版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 課 程 設(shè) 計</b></p><p> 課程名稱 光電圖像處理綜合課程設(shè)計</p><p> 題目名稱 圖像二維整數(shù)離散余弦變換</p><p> ?。―CT) 變換算法和DSP實現(xiàn)</p><p> 2013年11月26日</p><p><b>
2、 目錄</b></p><p> 一、離散余弦變換……………………………………………2</p><p><b> 1、概念</b></p><p> 2、離散余弦變換用于圖像處理</p><p><b> 3、量化</b></p><p> 二、流程圖
3、……………………………………………………5</p><p> 三、程序中實現(xiàn)………………………………………………6</p><p> 四、輸出結(jié)果…………………………………………………11</p><p><b> 一、離散余弦變換</b></p><p><b> 1、概念</b><
4、/p><p> 離散余弦變換(DCT for Discrete Cosine Transform)是與傅里葉變換相關(guān)的一種變換,它類似于離散傅里葉變換(DFT for Discrete Fourier Transform),但是只使用實數(shù)。離散余弦變換相當(dāng)于一個長度大概是它兩倍的離散傅里葉變換,這個離散傅里葉變換是對一個實偶函數(shù)進(jìn)行的(因為一個實偶函數(shù)的傅里葉變換仍然是一個實偶函數(shù)),在有些變形里面需要將輸入或者輸
5、出的位置移動半個單位(DCT有8種標(biāo)準(zhǔn)類型,其中4種是常見的)。</p><p> 最常用的一種離散余弦變換的類型是下面給出的第二種類型,通常我們所說的離散余弦變換指的就是這種。它的逆,也就是下面給出的第三種類型,通常相應(yīng)的被稱為"反離散余弦變換","逆離散余弦變換"或者"IDCT"。</p><p> 有兩個相關(guān)的變換,一個
6、是離散正弦變換(DST for Discrete Sine Transform),它相當(dāng)于一個長度大概是它兩倍的實奇函數(shù)的離散傅里葉變換;另一個是改進(jìn)的離散余弦變換(MDCT for Modified Discrete Cosine Transform),它相當(dāng)于對交疊的數(shù)據(jù)進(jìn)行離散余弦變換。</p><p> 離散余弦變換,尤其是它的第二種類型,經(jīng)常被信號處理和圖像處理使用,用于對信號和圖像(包括靜止圖像和運
7、動圖像)進(jìn)行有損數(shù)據(jù)壓縮。這是由于離散余弦變換具有很強的"能量集中"特性:大多數(shù)的自然信號(包括聲音和圖像)的能量都集中在離散余弦變換后的低頻部分,而且當(dāng)信號具有接近馬爾科夫過程(Markov processes)的統(tǒng)計特性時,離散余弦變換的去相關(guān)性接近于K-L變換(Karhunen-Loève 變換--它具有最優(yōu)的去相關(guān)性)的性能。</p><p> 2、離散余弦變換用于圖像處理
8、:</p><p> 圖像數(shù)據(jù)一般有較強的相關(guān)性,若所選用的正交矢量空間的基矢量與圖像本身的主要特征相近,在該正交矢量空間中描述圖像數(shù)據(jù)則會變得更簡單。 </p><p> 經(jīng)過正交變換,會把原來分散在原空間的圖像數(shù)據(jù)在新的坐標(biāo)空間中得到集中。對于大多數(shù)圖像,大量變換系數(shù)很小,只要刪除接近于零的系數(shù),并且對較小的系數(shù)進(jìn)行粗量化,而保留包含圖像主要信息的系數(shù),以此進(jìn)行壓縮編碼。 <
9、/p><p> 在重建圖像進(jìn)行解碼時,所損失的將是一些不重要的信息,幾乎不會引起圖像的失真。</p><p> 在變換編碼中,首先要將圖像數(shù)據(jù)分割成子圖像,然后對子圖像數(shù)據(jù)塊實施某種變換,如DCT變換,那么子圖像尺寸取多少好呢?根據(jù)實踐證明子圖像尺寸取4×4、8×8、16×16適合作圖像的壓縮,這是因為:</p><p> <1
10、> 如果子圖像尺寸取得太小,雖然計算速度快,實現(xiàn)簡單,但壓縮能力有一定的限制。</p><p> <2> 如果子圖像尺寸取得太大,雖然去相關(guān)效果變好,因為象DFT、DCT等正弦型變換均具有漸近最佳性,但也漸趨飽和。若尺寸太大,由于圖像本身的相關(guān)性很小,反而使其壓縮效果不顯示,而且增加了計算的復(fù)雜性。</p><p> 8*8FDCT和IDCT的普通算法如下:</
11、p><p><b> 其中:</b></p><p> 離散余弦變換(Discrete Cosine Tranform,簡稱DCT)是一種與傅立葉變換緊密相關(guān)的數(shù)學(xué)運算。在傅立葉級數(shù)展開式中,如果被展開的函數(shù)式是偶函數(shù),那么其傅立葉級數(shù)中只包含余弦項,再將其離散化可導(dǎo)出余弦變換,因此稱之為離散余弦變換。時間域中信號需要許多數(shù)據(jù)點表示;在x軸表示時間,在y軸表示幅度。信
12、號一旦用傅立葉變換轉(zhuǎn)換到頻率域,就只需要幾點就可以表示這個相同的信號。如我們已經(jīng)看到的那樣,原因就是信號只含有少量的頻率成分。這允許在頻率域中只用幾個數(shù)據(jù)點就可以表示信號,而在時間域中表示則需要大量數(shù)據(jù)點。</p><p> 這一技術(shù)可以應(yīng)用到彩色圖像上。彩色圖像有像素組成,這些像素具有RGB彩色值。每個像素都帶有x,y坐標(biāo),對每種原色使用8x8或者16x16矩陣。在灰度圖像中像素具有灰度值,它的x,y坐標(biāo)由灰
13、色的幅度組成。為了在JPEG中壓縮灰度圖像,每個像素被翻譯為亮度或灰度值。為了壓縮RGB彩色圖像,這項工作必須進(jìn)行三遍,因為JPEG分別得處理每個顏色成分,R成分第一個被壓縮,然后是G成分,最后是B成分。而一個8x8矩陣的64個值,每個值都帶有各自的x,y坐標(biāo),這樣我們就有了一個像素的三維表示法,稱作控件表達(dá)式或空間域。通過DCT變換,空間表達(dá)式就轉(zhuǎn)化為頻譜表達(dá)式或頻率域。從而到達(dá)了數(shù)據(jù)壓縮的目的。</p><p&g
14、t; DCT式目前最佳的圖像變換,它有很多優(yōu)點。DCT是正交變換,它可以將8x8圖像空間表達(dá)式轉(zhuǎn)換為頻率域,只需要用少量的數(shù)據(jù)點表示圖像;DCT產(chǎn)生的系數(shù)很容易被量化,因此能獲得好的塊壓縮;DCT算法的性能很好,它有快速算法,如采用快速傅立葉變換可以進(jìn)行高效的運算,因此它在硬件和軟件中都容易實現(xiàn);而且DCT算法是對稱的,所以利用逆DCT算法可以用來解壓縮圖像。</p><p> 為什么采用8x8的圖像塊,其原
15、因是由于計算量和像素之間關(guān)系的數(shù)量,許多研究表明,在15或20個像素之后,像素間的相關(guān)性開始下降。就是說,一列相似的像素通常會持續(xù)15到20個像素那么長,在此之后,像素就會改變幅度水平(或反向)。</p><p> 模擬圖像經(jīng)采樣后成為離散化的亮度值然后分成一個個宏塊,而一個宏塊有分成8x8大小的塊,可以用一個矩陣來表示這個塊。</p><p> 在這里,N=8,矩陣中元素f(i,j)
16、表示塊中第i行、第j列像素的亮度值。把該矩陣看作一個空間域,顯然,塊中這些亮度值的大小有一定的隨機性,無序性,或者說亮度值的分布沒有什么特征;DCT變換就是來解決這個問題的,把這些隨機的數(shù)據(jù)變的有序,便于對數(shù)據(jù)進(jìn)行編碼壓縮。</p><p><b> 3、量化</b></p><p> 量化過程實際上就是對 DCT 系數(shù)的一個優(yōu)化過程。它是利用了人眼對高頻部分不敏
17、感的特性來實現(xiàn)數(shù)據(jù)的大幅簡化。</p><p> 量化過程實際上是簡單地把頻率領(lǐng)域上每個成份,除以一個對于該成份的常數(shù),且接著四舍五入取最接近的整數(shù)。</p><p> 這是整個過程中的主要有損運算。</p><p> 以這個結(jié)果來說,經(jīng)常會把很多高頻率的成份四舍五入而接近0,且剩下很多會變成小的正或負(fù)數(shù)。</p><p> 整個量化
18、的目的是減小非“0”系數(shù)的幅度以及增加“0”值系數(shù)的數(shù)目。</p><p> 量化是圖像質(zhì)量下降的最主要原因。</p><p> 因為人眼對亮度信號比對色差信號更敏感,因此使用了兩種量化表:亮度量化值和色差量化值。</p><p> 總體上來說,DCT 變換實際是空間域的低通濾波器。對 Y 分量采用細(xì)量化,對 UV 采用粗量化。</p><
19、p> 量化表是控制 JPEG 壓縮比的關(guān)鍵,這個步驟除掉了一些高頻量;另一個重要原因是所有圖片的點與點之間會有一個色彩過渡的過程,大量的圖像信息被包含在低頻率中,經(jīng)過量化處理后,在高頻率段,將出現(xiàn)大量連續(xù)的零。</p><p><b> 二、流程圖</b></p><p> 基于DCT的圖像壓縮編碼的程序?qū)崿F(xiàn)的流程圖如圖3-1所示。</p>
20、<p> 圖3-1 程序流程圖</p><p><b> 三、程序中實現(xiàn)</b></p><p> /************************************************************************/</p><p><b> /* 學(xué)號:</b></
21、p><p> 姓名: */</p><p> /************************************************************************/</p><p> #include <stdio.h>
22、</p><p> #include <math.h></p><p> #define N 8</p><p> #define PI 3.1415926</p><p> int f1[N][N]=</p><p><b> {</b></p><p&
23、gt; {139,144,149,153,155,155,155,155},</p><p> {144,151,153,156,159,156,156,156},</p><p> {150,155,160,163,158,156,156,156},</p><p> {159,161,162,160,160,159,159,159},</p>
24、<p> {159,160,161,162,162,155,155,155},</p><p> {161,161,161,161,160,157,157,157},</p><p> {162,162,161,163,162,157,157,157},</p><p> {162,162,161,161,163,158,158,158},&l
25、t;/p><p><b> };</b></p><p> int q1[N][N]=//定義色度量化系數(shù)</p><p><b> {</b></p><p> {17,18,24,47,99,99,99,99}, </p><p> {18,21
26、,26,66,99,99,99,99}, </p><p> {24,26,56,99,99,99,99,99}, </p><p> {47,66,99,99,99,99,99,99}, </p><p> {99,99,99,99,99,99,99,99}, </p><p> {99,99,99,99,99,99,99,9
27、9}, </p><p> {99,99,99,99,99,99,99,99}, </p><p> {99,99,99,99,99,99,99,99},</p><p><b> };</b></p><p> int q2[N][N]=//定義亮度量化系數(shù)</p>&
28、lt;p><b> {</b></p><p> {16,11,10,16,24,40,51,61},</p><p> {12,12,14,19,26,58,60,55},</p><p> {14,13,16,24,40,57,69,56},</p><p> {14,17,22,29,51,87,8
29、0,62},</p><p> {18,22,37,56,68,109,103,77},</p><p> {24,35,55,64,81,104,113,92},</p><p> {49,64,78,87,103,121,120,101},</p><p> {72,92,95,98,112,100,103,99}</p&
30、gt;<p><b> };</b></p><p> void showMat_d(double **matShow);</p><p> void showMat_i(int **matShow);//顯示函數(shù),輸出為整形數(shù)據(jù)</p><p> void DCT(int **f,double **F);
31、//經(jīng)過FDCT變換,f為輸入數(shù)據(jù),F(xiàn)為輸出數(shù)據(jù)</p><p> void IDCT(int **f,int **F);//經(jīng)過逆變換,f為輸入數(shù)據(jù),F(xiàn)為輸出數(shù)據(jù)</p><p> void quant(double **f,int **F);//量化過程,f為傳進(jìn)的DCT數(shù)據(jù),F(xiàn)為量化后的數(shù)據(jù)</p><p> void iQuant(
32、int **f,int **F);//逆量化過程,f為量化后的數(shù)據(jù),F(xiàn)為消除了量化的數(shù)據(jù)</p><p> void main()</p><p><b> {</b></p><p> double F[N][N]={0};//初始化輸出數(shù)組</p><p> int f_1[N][N]={
33、0};//初始化逆變換的輸出數(shù)組</p><p> int f2[N][N]={0};//自定義輸入數(shù)組的數(shù)據(jù)</p><p> int fq[N][N]={0};//定義量化后的數(shù)組。</p><p> int fq_1[N][N]={0};//定義經(jīng)過逆變化后的數(shù)組</p><p>
34、 int i=0,j=0;</p><p> //////////////////////////////////////////////////////////////////////////</p><p> printf("輸入數(shù)據(jù)f(x,y)為:\n");</p><p> showMat_i((int **)f1);//輸
35、出原始數(shù)據(jù)</p><p> for(i=0;i<N;i++)</p><p> for(j=0;j<N;j++)</p><p> f1[i][j]-=128;//減128</p><p> printf("\nDCT之后,數(shù)據(jù)F(u,v)為:\n");</p><p&g
36、t; DCT((int **)f1,(double **)F);//DCT變換</p><p> showMat_d((double **)F);//輸出DCT數(shù)據(jù)</p><p> quant((double **)F,(int **)fq);//量化</p><p> printf("\n量化后的DCT為:\n");&l
37、t;/p><p> showMat_i((int **)fq);//輸出量化后的DCT數(shù)據(jù)</p><p> iQuant((int **)fq,(int **)fq_1);//經(jīng)過逆量化處理</p><p> printf("\n逆量化后的數(shù)為:\n");</p><p> showMat_i((int *
38、*)fq_1);</p><p> printf("\nIDCT之后,數(shù)據(jù)f'(x,y)為:\n");</p><p> IDCT((int **)fq_1,(int **)f_1);//IDCT變換</p><p> for(i=0;i<N;i++)</p><p> for(j=0;j<
39、N;j++)</p><p> f_1[i][j]+=128;//加128</p><p> showMat_i((int **)f_1);//輸出數(shù)據(jù)</p><p> //////////////////////////////////////////////////////////////////////////</p>&
40、lt;p><b> }</b></p><p> void showMat_d(double **matShow)</p><p><b> {</b></p><p><b> int i=0;</b></p><p><b> int j=0;&l
41、t;/b></p><p> for(i=0;i<N;i++)</p><p><b> {</b></p><p> for(j=0;j<N;j++)</p><p><b> {</b></p><p> printf("%5.1f
42、",((*((double*)matShow+i*N+j))));</p><p><b> }</b></p><p> printf("\n");</p><p><b> }</b></p><p><b> }</b></p&
43、gt;<p> void showMat_i(int **matShow)</p><p><b> {</b></p><p><b> int i=0;</b></p><p><b> int j=0;</b></p><p> for(i=0;i
44、<N;i++)</p><p><b> {</b></p><p> for(j=0;j<N;j++)</p><p><b> {</b></p><p> printf("%3d ",((*((int*)matShow+i*N+j))));</p&
45、gt;<p><b> }</b></p><p> printf("\n");</p><p><b> }</b></p><p><b> }</b></p><p> void quant(double **f,int **F
46、)</p><p><b> {</b></p><p><b> int i=0;</b></p><p><b> int j=0;</b></p><p> double temp[N][N]={0.0};</p><p> for (i
47、=0;i<N;i++)</p><p> for(j=0;j<N;j++)</p><p><b> {</b></p><p> *((double*)temp+i*N+j)=(*((double*)f+i*N+j)/((*((int*)q2+i*N+j))));</p><p> if (((*(
48、(double*)temp+i*N+j))<0))</p><p><b> {</b></p><p> *((int*)F+i*N+j)=(int)((*((double*)temp+i*N+j))-0.5);//-0.5為四舍五入取整</p><p><b> }</b></p><
49、;p><b> else</b></p><p> *((int*)F+i*N+j)=(int)((*((double*)temp+i*N+j))+0.5);//+0.5為四舍五入取整</p><p><b> }</b></p><p><b> }</b></p>
50、<p> void iQuant(int **f,int **F)</p><p><b> {</b></p><p><b> int i=0;</b></p><p><b> int j=0;</b></p><p> double temp[N][
51、N]={0.0};</p><p> for (i=0;i<N;i++)</p><p> for(j=0;j<N;j++)</p><p><b> {</b></p><p> *((double*)temp+i*N+j)=(double)*((int*)f+i*N+j)*(*((int*)q2+
52、i*N+j));</p><p> if (((*((double*)temp+i*N+j))<0))</p><p><b> {</b></p><p> *((int*)F+i*N+j)=(int)((*((double*)temp+i*N+j))-0.5);//-0.5為四舍五入取整</p><p&g
53、t;<b> }</b></p><p><b> else</b></p><p> *((int*)F+i*N+j)=(int)((*((double*)temp+i*N+j))+0.5);//+0.5為四舍五入取整</p><p><b> }</b></p><
54、p><b> }</b></p><p> void DCT(int **f,double **F)//DCT轉(zhuǎn)換</p><p><b> {</b></p><p> int x,m,n;</p><p> double dTemp[N][N] = {0.0};//
55、中間矩陣</p><p> double temp[N][N]={0.0};</p><p> double coff[N] = {0.0};//變換系數(shù)</p><p> coff[0] = 1/sqrt(N);</p><p> for (m=1;m<N;m++)</p><p><b&
56、gt; {</b></p><p> coff[m]=sqrt(2)/sqrt(N);</p><p><b> }</b></p><p> //一維變換,,,,對列進(jìn)行一維DCT變換。</p><p> for(n=0;n<N;n++)//每一列遍歷</p><
57、;p> for(m=0;m<N;m++)//每一行遍歷</p><p> for(x=0;x<N;x++)//每個cos系數(shù)遍歷</p><p> (*((double*)temp+m*N+n))+=(double)(*((int*)f+x*N+n))*coff[m]*cos((2*x+1)*PI*m/(2*N));</p><p&
58、gt; //二維變換,,對行進(jìn)行以為DCT變換</p><p> for (m=0;m<N;m++)//每一行遍歷</p><p> for(n=0;n<N;n++)//每一列遍歷</p><p> for(x=0;x<N;x++)//每個cos系數(shù)遍歷(*((double*)F+m*N+n))+=(*((dou
59、ble*)temp+m*N+x))*coff[n]*cos((2*x+1)*PI*n/(2*N));</p><p><b> }</b></p><p> void IDCT(int **f,int **F)//逆變換</p><p><b> {</b></p><p> i
60、nt y,m,x;</p><p> double dTemp[N][N] = {0.0};//中間矩陣</p><p> double temp[N][N] ={0.0};</p><p> double coff[N] = {0.0};//變換系數(shù)</p><p> coff[0] = 1.0/sqrt(N);<
61、;/p><p> for (m=1;m<N;m++)</p><p><b> {</b></p><p> coff[m]=sqrt(2)/sqrt(N);</p><p><b> }</b></p><p><b> //一維變換</b>
62、;</p><p> for(x=0;x<N;x++)</p><p> for(y=0;y<N;y++)</p><p> for(m=0;m<N;m++)</p><p> (*((double*)temp+x*N+y))+=(*((int*)f+x*N+m))*coff[m]*cos((2*y+1
63、)*PI*m/(2*N));</p><p><b> //二維變換</b></p><p> for (y=0;y<N;y++)</p><p> for(x=0;x<N;x++)</p><p><b> {</b></p><p>
64、 for(m=0;m<N;m++)</p><p> (*((double*)dTemp+x*N+y))+=(*((double*)temp+m*N+y))*coff[m]*cos((2*x+1)*PI*m/(2*N));</p><p> if ((*((double*)dTemp+x*N+y))<0)</p><p><b> {
65、</b></p><p> (*((int*)F+x*N+y))=(int)((*((double*)dTemp+x*N+y))-0.5);//-0.5為四舍五入取整</p><p><b> }</b></p><p><b> else</b></p><p> (*((in
66、t*)F+x*N+y))=(int)((*((double*)dTemp+x*N+y))+0.5);//+0.5為四舍五入取整</p><p><b> }</b></p><p><b> 四、輸出結(jié)果</b></p><p><b> 亮度量化輸出結(jié)果:</b></p><
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 圖像的離散余弦變換dct
- 基于二維離散余弦變換和進(jìn)化策略的多聚焦圖像融合.pdf
- 二維離散余弦變換的VLSI實現(xiàn)及IP軟核設(shè)計.pdf
- 基于離散余弦變換的圖像水印算法.pdf
- 多標(biāo)準(zhǔn)離散余弦變換算法及VLSI體系研究與實現(xiàn).pdf
- 數(shù)字圖像處理dct變換課程設(shè)計
- 基于DCT的二維實值離散Gabor變換并行算法及應(yīng)用.pdf
- 離散余弦變換的設(shè)計與實現(xiàn).pdf
- 畢業(yè)設(shè)計---用vc++實現(xiàn)圖像的離散余弦變換
- 二維離散小波變換的FPGA實現(xiàn).pdf
- 基于2D DCT的二維實值離散Gabor變換.pdf
- 二維混合信號與系統(tǒng)的變換算法研究.pdf
- 離散余弦變換VLSI設(shè)計.pdf
- 1,其他。正向離散余弦變換4.4.2jpeg有損壓縮算法計算兩維的dct
- 基于離散余弦變換和小波域的圖像水印算法研究.pdf
- 方向離散余弦變換和方向離散小波變換及其在超聲圖像中的應(yīng)用.pdf
- 外文翻譯--利用離散余弦變換進(jìn)行圖像壓縮
- 改進(jìn)的離散余弦反變換迭代算法研究與音頻DSP核設(shè)計.pdf
- 離散余弦逆變換的硬件實現(xiàn).pdf
- 基于離散余弦變換和離散小波變換的雙重數(shù)字水印算法的研究.pdf
評論
0/150
提交評論