diff toolboxes/AudioInpaintingToolbox/Utils/dictionaries/Gabor_Dictionary.m @ 144:19e0af570914 release_1.5

Merge from branch "ivand_dev"
author Ivan <ivan.damnjanovic@eecs.qmul.ac.uk>
date Tue, 26 Jul 2011 15:14:15 +0100
parents 56d719a5fd31
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/toolboxes/AudioInpaintingToolbox/Utils/dictionaries/Gabor_Dictionary.m	Tue Jul 26 15:14:15 2011 +0100
@@ -0,0 +1,57 @@
+function D = Gabor_Dictionary(param)
+% Windowed Gabor dictionary. In this implementation, the dictionary matrix
+% is the concatenation of a DCT (left part of the matrix) and of a DST
+% (right part).
+% Note that one can use this dictionary 
+%  - either by constraining the simulaneous selection of cosine and sine
+%  atoms with same frequency in order to implement Gabor atoms;
+%  - or, without any selection constraint, by considering that the
+%  dictionary is not a Gabor dictionary but the concatenation of a DCT and 
+%  of a DST.
+%
+% Usage:
+%   D = Gabor_Dictionary(param)
+%
+% Inputs [and default values]:
+%   - param.N: frame length [256]
+%   - param.redundancyFactor: redundancy factor to adjust the number of
+%   frequencies [1]. The number of atoms in the dictionary equals 
+%   param.N*param.redundancyFactor
+%   - param.wd: weigthing window function [@wSine]
+%
+% Output:
+%   - Dictionary: D (cosine atoms followed by sine atoms)
+%
+%
+% -------------------
+%
+% Audio Inpainting toolbox
+% Date: June 28, 2011
+% By Valentin Emiya, Amir Adler, Maria Jafari
+% This code is distributed under the terms of the GNU Public License version 3 (http://www.gnu.org/licenses/gpl.txt).
+
+% Check and load default parameters
+defaultParam.N = 256;
+defaultParam.redundancyFactor = 1;
+defaultParam.wd = @wSine;
+
+if nargin<1
+    param = defaultParam;
+else
+    names = fieldnames(defaultParam);
+    for k=1:length(names)
+        if ~isfield(param,names{k}) || isempty(param.(names{k}))
+            param.(names{k}) = defaultParam.(names{k});
+        end
+    end
+end
+K = param.N*param.redundancyFactor; % number of atoms
+wd = param.wd(param.N); % weigthing window
+u = 0:(param.N-1); % time
+k=0:K/2-1; % frequency
+D = diag(wd)*[cos(2*pi/K*(u.'+1/2)*(k+1/2)),sin(2*pi/K*(u.'+1/2)*(k+1/2))];
+
+% normalisation
+D = D*diag(1./sqrt(diag(D'*D)));
+
+return