matlab zigzag算法,MATLAB 实现zigzag扫描(z字形扫描)

本文介绍了在实现JPEG压缩过程中遇到的Zigzag扫描问题,作者分享了经过修正的MATLAB代码,该代码参照了University of California的MPEG源代码。代码实现了将8x8矩阵转换为1x64行向量的Zigzag扫描,并提供了验证结果和手写推理过程,对理解JPEG压缩和MATLAB编程具有参考价值。
摘要由CSDN通过智能技术生成

今天在做多媒体作业的时候需要实现JPEG压缩,其中一步就是将量化后的块做zigzag扫描。我在网上找了很久,发现反复流传的就一份MATLAB代码,无奈这份代码跑起来结果和我预料的不一致,于是进行了修改,下面是修改后的代码。

function b=zigzag(a)

% 输入是一个8*8的矩阵,输出一个1*64的矩阵(行向量)

% 这是参照 University of California 提供的 MPEG 源代码的基础上编制的。

% Copyright (c) 1995 The Regents of the University of California.

[n,m]=size(a);

if(n~=8 && m~=8)

error('Input array is NOT 8-by-8');

end

% Set up array for fast conversion from row/column coordinates to

zigzag=[1 2 9 17 10 3 4 11

18 25 33 26 19 12 5 6

13 20 27 34 41 49 42 35

28 21 14 7 8 15 22 29

36 43 50 57 58 51 44 37

30 23 16 24 31 38 45 52

59 60 53 46 39 32 40 47

54 61 62 55 48 56 63 64];

aa = reshape(a',1,64); % 将输入块变成1x64的向量

zigzagR = reshape(zigzag',1,64);

b = aa(zigzagR); % 对 aa 按照查表方式取元素,得到 zig-zag 扫描结果

end

验证结果如图:

ec45b9a4d19a981bb4df805b6fcf3413.png

然后下图是手写推理验证:

3d843c7dbbb273efd49fc5c95656cbff.png

希望能对大家有所帮助

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值