矢量量化程序调试结果

来源:互联网 发布:unity3d入门教程 pdf 编辑:程序博客网 时间:2024/06/07 13:45

1 调试前准备

1)利用matlab生成 .img 图像文件

[plain] view plain copy
  1. clear variables;  
  2. filename='**';  
  3. im=imread(filename);  
  4. im=rgb2gray(im);  
  5. f=fopen([filename(1:end-4) '.img'],'wb');  
  6. for i=1:size(im,2)  
  7.     for j=1:size(im,1)  
  8.         fwrite(f,im(j,i),'uint8');  
  9.     end  
  10. end  
  11. fclose(f);  

2) 利用matlab查看 .img 图像文件
[plain] view plain copy
  1. clear variables;  
  2. f=fopen('**.img','rb');  
  3. %haha=fread(f,Inf,'uint8');  
  4. haha=fread(f);  
  5. haha1=reshape(haha,800,1280);  
  6. haha2=zeros(800,1280);  
  7. for i=1:800  
  8.     for j=1:1280  
  9.         haha2(i,j)=haha((j-1)*800+i);  
  10.     end  
  11. end  
  12. fclose(f);  


2 输入参数格式

1)trvqsp_img:获得图像矢量量化的码书

     调用参数格式:

trvqsp_img ts_img codefile [-b cb_size] [ -t block_height] [-w block_width] [-x row_size][-y col_size] [-h]

ts_img:是训练图像,也即待量化压缩的图像,假定为8位灰度级,使用光栅扫描顺序存储。

Codefile:以二进制格式存放码书的文件,有一个包含12个字节的文件头记录:向量的维度,以及码书的大小。

-b cb_size:码书的大小

-t block_height:块的高度(以像素为单位)

-w block_width:块的宽度(以像素为单位)

实际上由block_width 、block_height决定着码书向量的大小,也即每个输出块的大小。因此向量的维数是block_height *block_width

-x row_size:输入图像的宽

-y col_size:输入图像的高

-h 帮助

此处参数输入可采用.bat文件:



2)vqimg_enc:根据码书对图像进行矢量量化

    调用格式:

vqimg_enc [-i imagein] [-o cmpfile] [-c codebook] [-x row_size] [-y col_size] [-h]

-i imagein:输入的待编码的图像文件名
-o cmpfile:输出的量化压缩后的文件名
-c cmpfile:码书文件
-x row_size:输入图像的宽
-y col_size:输入图像的高
-h 帮助

此处参数输入可采用.bat文件:



3)vqimg_dec:根据码书文件和压缩后的文件重构原始图像

    调用格式:

vqimg_dec [-i cmpfile] [-o imageout] [-h]
-i cmpfile:压缩文件名
-o imageout:重建图像文件名
-h 帮助

此处参数输入可采用.bat文件:




3  图片测试结果

1)图像大小:256*256 像素

i   美女.img



ii   狒狒.img


2)图像大小:512*512 像素

i   辣椒.img


3)图像大小:800*1280 像素

i   花.img





附:所用原图

i 美女


ii 狒狒


iii 辣椒


iv 花

原创粉丝点击