⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ghm.m

📁 多小波分析工具箱
💻 M
字号:
function b=GHM(a)
%GHM Single-level discrete 2-D multiwavelet transform.
%   GHM performs a single-level 2-D multiwavelet decomposition
%   using GHM multiwavelet with four multi-filters
%
%   Y = GHM(X) computes the approximation
%   coefficients matrix LL and details coefficients matrices 
%   LH, HL, HH, obtained by a multiwavelet decomposition of the 
%   input matrix X and puts the result in Y=[LL,LH;HL,HH].
%
%   The size of Y is double that of X which should be
%   a square matrix of size NxN where N is power of 2 since
%   X is vectorized by a repeated row preprocessing.
%   LL, LH, HL, and HH will have the size NxN
%   See also IGHM, GHMAP, IGHMAP, DD2, IDD2, WAVEDEC2, WAVEINFO.

%   Auth: Dr. Bessam Z. Hassan
%   Last Revision: 27-Feb-2004.
%   Copyright 1995-2002 The MathWorks, Inc.
% $Revision: 1.0 $

% initialize the coefficients

H0=[3/(5*sqrt(2)),4/5;-1/20,-3/(10*sqrt(2))];
H1=[3/(5*sqrt(2)),0;9/20,1/sqrt(2)];
H2=[0,0;9/20,-3/(10*sqrt(2))];
H3=[0,0;-1/20,0];
G0=[-1/20,-3/(10*sqrt(2));1/(10*sqrt(2)),3/10];
G1=[9/20,-1/sqrt(2);-9/(10*sqrt(2)),0];
G2=[9/20,-3/(10*sqrt(2));9/(10*sqrt(2)),-3/10];
G3=[-1/20,0;-1/(10*sqrt(2)),0];

% check the input

if nargin == 0,
	error('Not enough input arguments.');
end
if isempty(a)
   b = [];
   return
end
[N,M]=size(a);
if N~=2^round(log(N)/log(2))
    error('size of the input should be power of 2');
end
if M~=N
    error('the input matrix must be square');
end

% construct the W matrix

w=[H0,H1,H2,H3;G0,G1,G2,G3];
for i=1:N/2-1
    W(4*(i-1)+1:4*i,4*i-3:4*i+4)=w;
end
W=[W;[[H2,H3;G2,G3],zeros(4,2*N-8),[H0,H1;G0,G1]]];
p=[];X=[];

% oversampling rows (repeated row preprocessing)

X(1:2:2*N,:)=a;X(2:2:2*N,:)=1/sqrt(2)*a;

% row transformation

z=W*X;

% row vector permutation

ii=0:4:2*N-1;jj=sort([ii+1,ii+2]);kk=sort([ii+3,ii+4]);
p=[p;z(jj,:);z(kk,:)];
aa=p';X=[];

% oversampling columns (repeated row preprocessing)

X(1:2:2*N,:)=aa;X(2:2:2*N,:)=1/sqrt(2)*aa;

% column transformation

z=W*X;

% column vector permutation

p=[];
ii=0:4:2*N-1;jj=sort([ii+1,ii+2]);kk=sort([ii+3,ii+4]);
p=[p;z(jj,:);z(kk,:)];
b=p';

% Coefficient permutation

b1=b(1:N,1:N);b2=b(1:N,N+1:2*N);b3=b(N+1:2*N,1:N);b4=b(N+1:2*N,N+1:2*N);
T=[b1(1:2:N,:);b1(2:2:N,:)]';b1=[T(1:2:N,:);T(2:2:N,:)]';
T=[b2(1:2:N,:);b2(2:2:N,:)]';b2=[T(1:2:N,:);T(2:2:N,:)]';
T=[b3(1:2:N,:);b3(2:2:N,:)]';b3=[T(1:2:N,:);T(2:2:N,:)]';
T=[b4(1:2:N,:);b4(2:2:N,:)]';b4=[T(1:2:N,:);T(2:2:N,:)]';
b=[b1,b2;b3,b4];

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -