游程编码和PCX格式的matlab实现
1、 编码
clear, clc
%编码,逐行读入
tic; %开始计时
%预处理
%以只读方式打开原文件%fopen()返回一个文件id值,-1表示打开文件失败
fi = fopen('D:\Code\InformationTheory\PCX\lena1.raw', 'r');
buf = fread(fi); %读取原文件数据至buf数组内,fread()默认以uchar(8bit)作为精度
len = length(buf); %数据长度,即原图像有多少像素点
fclose(fi); %关闭原文件
%以写方式打开原文件,w后面的+表示清除所打开文件中原有的数据后再写入
fo = fopen('D:\Code\InformationTheory\PCX\lena1.cmp', 'w+');
idx = 1; %当前位置
olen = 0; %写出数据长度
while idx <= len
count = 1; %记录重复像素个数,无重复记为1
if buf(idx) ~= buf(idx + 1) %当前像素和后一个像素值不等
%孤立像素且像素值>=192
if buf(idx) >=