数字图像处理实验5 图像压缩

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验5 图像压缩

一.实验目的:

1.掌握图像压缩的原理——编码冗余,压缩比C R的计算等。

2.了解并掌握霍夫曼编码的原理、实现步骤。

3.掌握JPEG标准——通用的图像压缩/解压缩编码标准。

二.实验内容:

1.利用已给出的MATLAB自编函数库matlab_function文件夹,实现压缩比的计算。

2.对信号源符进行霍夫曼编码,以消除信源的冗余数据。

3.练习JPEG标准的压缩/解压缩技术。

三.实验原理:

1.图像压缩比C R的计算

函数imratio(f1, f2),计算图像压缩比C R,该函数来自MATLAB自编函数库matlab_function文件夹,语法如下:

imratio(imread(‘filename’), ‘filename.jpg’)

//第二个参数‘filename.jpg’仅是文件名,实际上是一个结构,内含压缩

//后的各种压缩信息,并不代表图像本身

>>f = imread(‘E:\医学图像处理实验讲义\实验五\car_lady.jpg’)

>>imfinfo E:\医学图像处理实验讲义\实验五\car_lady.jpg

//查看图像文件的详细信息

>>imwrite(f, ‘car_lady25.jpg’, ‘quality’, 25)

//将压缩后的图像存到MATLAB默认路径中

>>imfinfo car_lady25.jpg

//可依据图像信息计算出压缩率

>>f25 = imread(‘car_lady25.jpg’)

>>Cr = imratio (f25, ‘car_lady25.jpg’)

2.霍夫曼编码

符号概率

a1 0.1875

a2 0.5

a3 0.125

a4 0.1875

函数huffman(p)进行霍夫曼编码,语法:

huffman(p) //p为向量符号

>>p = [0.1875 0.5 0.125 0.1875]

>>c = huffman(p)

使用函数mat2huff(‘filename’)对图像进行编码,验证霍夫曼编码压缩的性能。对大小为512×512的8比特单色图像Tracy.tif进行压缩,并计算压缩前后的压缩比Cr:

>> f = imread('E:\医学图像处理实验讲义\实验五\Tracy.tif')’)

>> c = mat2huff(f)

>> Cr = imratio(f, c)

3.JPEG标准的压缩/解压缩技术

函数im2jpeg(‘filename’, n)对图像filename进行jpeg标准的压缩,参数n 将下图的标准化数组×参数n,以改变压缩率,默认为1。

函数jpeg2im(‘filename’)将已经jpeg压缩的图像进行解压缩。

>> f = imread(‘E:\医学图像处理实验讲义\实验五\Tracy.tif’)

>>imshow (f)

>> c1 = im2jpeg(f)

>> f1 = jpeg2im(c1)

>>figure, imshow(f1)

>> Cr1 = imratio(f, c1)

>>c4 = im2jpeg(f, 4)

>>f4 = jpeg2im(c4)

>>figure, imshow(f4)

>>Cr4 = imratio(f, c4)

四.实验报告:

1.对图像bubbles.jpg进行参数为25的函数imwrite()保存在默认路径中,计算原图像与压缩保存后的压缩比Cr。

2.对下列符号信源进行霍夫曼编码(排序、从右到左分配码字0和1),与程序得出的编码结果进行验证:

符号概率

a1 0.1875

a2 0.5

a3 0.125

a4 0.1875

对图像Tracy.tif进行霍夫曼编码,求其压缩比。

3.对图像lena.bmp进行JPEG标准压缩、解压缩,对比前后图像的分辨率效果,并求出n=1,n=4时的压缩比Cr1 = ? Cr4 = ?

相关文档
最新文档