Mercurial > hg > aimmat
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 |