zigzag扫描matlab,ZIGZAG扫描的MATLAB实现 | 学步园

zigzag扫描matlab,ZIGZAG扫描的MATLAB实现 | 学步园转自阿须数码 用 MATLAB 实现 MPEG 中的 ZIG ZAG 扫描 觉得有点研究价值 实现的方法也很巧妙 下面给一个参照 MPEG 提供的方法 functionb zigzag a 这是参照 Universityof 提供的 MPEG 源代码的基础上编制的 Copyright c 1995TheRegen

转自阿须数码,用MATLAB实现MPEG中的 ZIG-ZAG 扫描。觉得有点研究价值,实现的方法也很巧妙。

下面给一个参照MPEG提供的方法:

===

function b=zigzag(a)

% 这是参照 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

% zig zag order. 下标从零开始,因为是从MPEG的C代码拷贝过来的

zigzag = [ 0, 1, 8, 16, 9, 2, 3, 10, …

17, 24, 32, 25, 18, 11, 4, 5, …

12, 19, 26, 33, 40, 48, 41, 34, …

27, 20, 13, 6, 7, 14, 21, 28, …

35, 42, 49, 56, 57, 50, 43, 36, …

29, 22, 15, 23, 30, 37, 44, 51, …

58, 59, 52, 45, 38, 31, 39, 46, …

53, 60, 61, 54, 47, 55, 62, 63];

zigzag = zigzag + 1;  % 下标加1,符合MATLAB的下标习惯

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

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

===

程序运行结果:

?a=magic(8)

a =

64     2     3    61    60     6     7    57

9    55    54    12    13    51    50    16

17    47    46    20    21    43    42    24

40    26    27    37    36    30    31    33

32    34    35    29    28    38    39    25

41    23    22    44    45    19    18    48

49    15    14    52    53    11    10    56

8    58    59     5     4    62    63     1

?b=zigzag(a)

b =

Columns 1 through 12

64     9     2     3    55    17    40    47    54    61    60    12

Columns 13 through 24

46    26    32    41    34    27    20    13     6     7    51    21

Columns 25 through 36

37    35    23    49     8    15    22    29    36    43    50    57

Columns 37 through 48

16    42    30    28    44    14    58    59    52    45    38    31

Columns 49 through 60

24    33    39    19    53     5     4    11    18    25    48    10

Columns 61 through 64

62    63    56     1

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/205573.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午5:42
下一篇 2026年3月19日 下午5:42


相关推荐

  • AI赋能亚马逊运营:高效生成高质量产品主图的实战指南

    AI赋能亚马逊运营:高效生成高质量产品主图的实战指南

    2026年3月15日
    2
  • java二分法查找_java实现二分法查找

    java二分法查找_java实现二分法查找什么是二分法查找 二分法也就是折半查找 在有序的数列中查找指定的元素 设定最小索引 low 和最大索引 height 1 还有中间值 mid low height 1 2 这种查找 如果中间值比指定元素小让 low mid 1 如果中间值比指定元素大 让 height mid 1 代码实现 免费视频教程分享 java 视频教程 importjava util ArrayList importj

    2026年3月17日
    2
  • 苹果套路直播计算机隐藏版,套路计算器app,套路计算器隐藏官网版app预约 v1.0 – 浏览器家园…

    苹果套路直播计算机隐藏版,套路计算器app,套路计算器隐藏官网版app预约 v1.0 – 浏览器家园…套路计算器隐藏官网版app软件是一款最新人气计算器玩法,大家可以在这里发现非常多有趣的玩法,超级适合大家进行整蛊以及活跃气氛适应的,计算器里面会有各种好玩有趣的公式,帮你计算出各种想要的问题回答,非常类似于星座方面的玩法,说不定可以帮你解决你心中的各种问题疑问,如果你想尝试的话,就赶紧下载体验吧。套路计算器隐藏官网版app软件特色:1、玩法非常简单,输入自己的想要提的问题,就可以自动算出结果!2、…

    2022年4月30日
    550
  • JRtplib开发笔记(三):JRtplib库编程使用说明

    原博主博客地址:https://blog.csdn.net/qq21497936本文章博客地址:https://blog.csdn.net/qq21497936/article/details/84957120《JRtplib开发笔记(一):JRtplib简介、JThread库编译》:https://blog.csdn.net/qq21497936/article/details/8478…

    2022年4月7日
    86
  • nocas随记

    nocas随记springboot 加载多个配置中心的配置文件 spring application name service1naco config enabled false 关闭配置 server addr 127 0 0 1 8848 配置中心地址 file ertension yaml dataid 的名称就

    2026年3月19日
    2
  • 数据库SQL优化大总结之 百万级数据库优化方案

    数据库SQL优化大总结之 百万级数据库优化方案网上关于 SQL 优化的教程很多 但是比较杂乱 近日有空整理了一下 写出来跟大家分享一下 其中有错误和不足的地方 还请大家纠正补充 这篇文章我花费了大量的时间查找资料 修改 排版 希望大家阅读之后 感觉好的话推荐给更多的人 让更多的人看到 纠正以及补充 nbsp 1 对查询进行优化 要尽量避免全表扫描 首先应考虑在 where 及 orderby 涉及的列上建立索引 2 应尽量避免在 w

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号