unpackbasiscoeff.sci

来自「小波分解源代码」· SCI 代码 · 共 37 行

SCI
37
字号
function x = UnpackBasisCoeff(basis,pkt)
// UnpackBasisCoeff -- Extract basis coefficients from packet table
//  Usage
//    x = UnpackBasisCoeff(basis,pkt)
//  Inputs
//    basis     basis tree
//    pkt       packet table (wavelet- or cosine-)
//  Outputs
//    x         coefficients of signal in that basis
//
//  Copyright Aldo I Maalouf

	[n,L] = size(pkt);
	x = zeros(1,n);
//
// initialize tree traversal stack
//
	dstack = zeros(1,2^L);
	bstack = zeros(1,2^L);
	k = 1;
	dstack(k) = 0;
	bstack(k) = 0;
//
	while(k > 0),
		d = dstack(k); b = bstack(k); k=k-1;
		if(basis(node(d,b)) == 0) ,  // terminal node
			   x(packet(d,b,n)) = pkt(packet(d,b,n),d+1)';
		else
			   k = k+1;
			   dstack(k) = d+1; bstack(k) = 2*b;
			   k = k+1;
			   dstack(k) = d+1; bstack(k) = 2*b+1;
		 end
	end
	endfunction

⌨️ 快捷键说明

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