zoukankan      html  css  js  c++  java
  • ZIGZAG扫描的MATLAB实现

    2004年10月29日 18:29:00

    转自阿须数码,用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); % 将输入块变成1x64的向量
    b = aa(zigzag); % 对 aa 按照查表方式取元素,得到 zig-zag 扫描结果

    ===


     程序运行结果:

    ?a=magic(8)
    a =
        64          61    60          57
           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
           58    59          62    63     1

    ?b=zigzag(a)
    b =
      Columns 1 through 12
        64             55    17    40    47    54    61    60    12
      Columns 13 through 24
        46    26    32    41    34    27    20    13          51    21
      Columns 25 through 36
        37    35    23    49       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          11    18    25    48    10
      Columns 61 through 64
        62    63    56     1



    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=158885


  • 相关阅读:
    通达OA二次开发
    通达OA 工作流程 表单设计 高级应用
    PLSQL Develop PlugIn 之脚本自动匹配补全工具CnPlugin
    Oracle性能优化之SQL语句
    Linux重置root密码步骤
    ORA-03113:通信通道的文件结尾解决
    Bat脚本实现MySQL数据库SQL文件备份
    访问父级组件实例
    访问根实例
    插槽其它示例
  • 原文地址:https://www.cnblogs.com/feisky/p/1586541.html
Copyright © 2011-2022 走看看