Mercurial > hg > smallbox
view DL/Majorization Minimization DL/AudioDicoLearning/DLMM_Audio.m @ 173:7426503fc4d1 danieleb
added ramirez_dl dictionary learning case
author | Daniele Barchiesi <daniele.barchiesi@eecs.qmul.ac.uk> |
---|---|
date | Thu, 17 Nov 2011 11:15:02 +0000 |
parents | b14209313ba4 |
children |
line wrap: on
line source
function [] = DLMM_Audio(m,n,l,it,Lambda,admiss) M = str2num(m); N = str2num(n); L = str2num(l); IT = str2num(it); lambda = str2num(Lambda); load(['Param',num2str(M),'X',num2str(N),'X',num2str(L),'kADCT2X01.mat']) method = ['bn';'un']; res = 1; while method(res)~=admiss res = res+1; end [PhiN,PhiM] = size(Phio); Phi = randn(M,N); Phi = Phi*diag(1./sqrt(sum(Phi.^2))); [PhiN,L] = size(x); phim = PhiM; unhat = zeros(PhiM,L); maxIST = 10; maxIDU = 10; it = 1; ert(1) = norm(Phi*unhat-x,'fro')^2 + lambda*(sum(sum(abs(unhat)))); while it <= IT it % %%%%%% Iterative Soft-Thresholding for Sparse Approximation %%%%% tau2 = .1+(svds(Phi,1))^2; eps = 3*10^-4; map = 0; % Projecting on the selected space (0=no,1=yes) [unhat,er] = mm1(Phi,x,unhat,tau2,lambda,maxIST,eps,map); er %%%%%% Majorisation Minimisation for Dictionary Update %%%%%% c = .1 + svds(unhat,1)^2; eps = 10^-7; [Phi,unhat] = dict_update_REG_cn(Phi,x,unhat,maxIDU,eps,'un'); %%%%% ert(it+1) = norm(Phi*unhat-x,'fro')^2 + lambda*(sum(sum(abs(unhat)))); it = it+1; end save(['DLMMl1',num2str(PhiN),'X',num2str(PhiM),'X',num2str(L),'iK',method(res,:),'Lambda',num2str(lambda),'Audio.mat'],'Phi','x','unhat','ert','lambda')