Mercurial > hg > smallbox
view util/classes/@audio/unbuffer.m @ 177:714fa7b8c1ad danieleb
added ramirez dl (to be completed) and MOCOD dictionary update
author | Daniele Barchiesi <daniele.barchiesi@eecs.qmul.ac.uk> |
---|---|
date | Thu, 17 Nov 2011 11:18:25 +0000 |
parents | 1495bdfa13e9 |
children |
line wrap: on
line source
function s = unbuffer(obj) %% Check inputs and Defaults if ~isprop(obj,'bufferOperator') || isempty(obj.bufferOperator) error('You must buffer a signal before unbuffer it, come on!'); end switch lower(obj.bufferOperator.method) %Unbuffer using overlap-add method case 'standard' w = obj.bufferOperator.window(obj.bufferOperator.wLength); S = diag(1./w)*obj.S; %Non overlapping case if obj.bufferOperator.overlap == 0 s = S(:); %Overlapping case else Stemp = S(1:obj.bufferOperator.wLength-obj.bufferOperator.overlap,1:end); s = [Stemp(:); S(obj.bufferOperator.wLength-obj.bufferOperator.overlap+1:end,end)]; end %Unbuffer using inverse lot with identity local transform case 'lot' s = ilot(obj.S(:),obj.bufferOperator.wLength,'id',... obj.bufferOperator.overlap,obj.bufferOperator.window); otherwise error('Please specify a valid buffer method'); end