annotate aim-mat/tools/@signal/rampamplitude.m @ 4:537f939baef0 tip

various bug fixes and changed copyright message
author Stefan Bleeck <bleeck@gmail.com>
date Tue, 16 Aug 2011 14:37:17 +0100
parents 20ada0af3d7d
children
rev   line source
tomwalters@0 1 % method of class @signal
tomwalters@0 2 %
tomwalters@0 3 % INPUT VALUES:
tomwalters@0 4 %
tomwalters@0 5 % RETURN VALUE:
tomwalters@0 6 %
tomwalters@0 7 %
bleeck@3 8 % This external file is included as part of the 'aim-mat' distribution package
bleeck@3 9 % (c) 2011, University of Southampton
bleeck@3 10 % Maintained by Stefan Bleeck (bleeck@gmail.com)
bleeck@3 11 % download of current version is on the soundsoftware site:
bleeck@3 12 % http://code.soundsoftware.ac.uk/projects/aimmat
bleeck@3 13 % documentation and everything is on http://www.acousticscale.org
bleeck@3 14
tomwalters@0 15
tomwalters@0 16 function sig=rampamplitude(sig,rt,type)
tomwalters@0 17
tomwalters@0 18 if nargin < 3
tomwalters@0 19 type='linear';
tomwalters@0 20 end
tomwalters@0 21 if nargin < 2
tomwalters@0 22 rt=0.01;
tomwalters@0 23 end
tomwalters@1 24 if rt==0
tomwalters@1 25 return
tomwalters@1 26 end
tomwalters@0 27
tomwalters@0 28 if strcmp(type,'linear')
tomwalters@0 29 first_bin=1;
bleeck@3 30 nr_point=time2bin(sig,rt);
tomwalters@0 31 last_bin=nr_point;
tomwalters@0 32 ramp=linspace(0,1,(last_bin-first_bin));
tomwalters@0 33 sig=sig*ramp;
tomwalters@0 34
tomwalters@0 35 first_bin=getnrpoints(sig)-nr_point;
tomwalters@0 36 start_time_hintere_rampe=bin2time(sig,first_bin);
tomwalters@0 37 last_bin=time2bin(sig,getlength(sig));
tomwalters@0 38 damp=linspace(1,0,(last_bin-first_bin));
tomwalters@0 39 try
tomwalters@0 40 sig=mult(sig,damp,start_time_hintere_rampe,rt);
tomwalters@0 41 end
tomwalters@0 42 p=1;
tomwalters@0 43 end