annotate aim-mat/tools/@signal/mult.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=mult(a,b,start_time,dauer)
tomwalters@0 17 %wenn b ein Vektor ist, werden die Werte einfach multipliziert
tomwalters@0 18 % wenn b eine Struct ist, dann werden sie adäquat multipliziert
tomwalters@0 19
tomwalters@0 20 if(~isobject(a))
tomwalters@0 21 disp('error: only works on signals');
tomwalters@0 22 end
tomwalters@0 23 if nargin < 4
tomwalters@0 24 if isobject(b)
tomwalters@0 25 dauer=GetLength(b);
tomwalters@0 26 end
tomwalters@0 27 end
tomwalters@0 28 if nargin < 3
tomwalters@0 29 start_time=0;
tomwalters@0 30 end
tomwalters@0 31
tomwalters@0 32 % wenn ein Spaltenvektor multipliziert werden soll
tomwalters@0 33 if isnumeric(b)
tomwalters@0 34 sr=getsr(a);
tomwalters@0 35 nr=max(size(b));
tomwalters@0 36 if nr>1
tomwalters@0 37 temp=signal(b,sr); % erzeuge ein neues Signal aus den Werten
tomwalters@0 38 sig=mult(a,temp,start_time,dauer); % und lasse dann die beiden Signale zusammenaddieren
tomwalters@0 39 else
tomwalters@0 40 if nargin <3
tomwalters@0 41 sig=a*b; % einfache Zahl
tomwalters@0 42 else % with starttime and duration
tomwalters@0 43 start=time2bin(a,start_time)+1; % +1, because a signal starts at the first bin
tomwalters@0 44 stop=time2bin(a,start_time+dauer);
tomwalters@0 45 sig=a;
tomwalters@0 46 sig.werte(start:stop)=sig.werte(start:stop)*b;
tomwalters@0 47 end
tomwalters@0 48 end
tomwalters@0 49 return;
tomwalters@0 50 end
tomwalters@0 51
tomwalters@0 52
tomwalters@0 53 % das resultierede Signal kann länger sein als die Ausgangssignale
tomwalters@0 54 % erst feststellen, wie lang das nachher sein soll
tomwalters@0 55 laenge1=getlength(a);
tomwalters@0 56 laenge2=getlength(b); %so lang ist das zweite Signal
tomwalters@0 57 sr1=getsr(a);
tomwalters@0 58 sampletime=1/sr1;
tomwalters@0 59 sr2=getsr(b);
tomwalters@0 60
tomwalters@0 61 if laenge2<dauer
tomwalters@0 62 disp('error: the signal is shorter then the duration');
tomwalters@0 63 return;
tomwalters@0 64 end
tomwalters@0 65
tomwalters@0 66 if sr1~=sr2
tomwalters@0 67 disp('error: samplerates differ - not implemented yet');
tomwalters@0 68 return;
tomwalters@0 69 end
tomwalters@0 70
tomwalters@0 71 lneu=start_time+dauer; % so lang wird das neue Signal
tomwalters@0 72 if lneu<laenge1 % oder es ist nicht länger als vorher
tomwalters@0 73 lneu=laenge1;
tomwalters@0 74 end
tomwalters@0 75
tomwalters@0 76 if fround(lneu,10)-fround(laenge1,10) % wenn das neue Signal länger wird
tomwalters@0 77 temp=signal(lneu,sr1,a.name,a.unit_x,a.unit_y,a.start_time);
tomwalters@0 78 % kopiere zuerst das alte Signal
tomwalters@0 79 start=1;
tomwalters@0 80 stop=time2bin(a,laenge1);
tomwalters@0 81 temp.werte(start:stop)=a.werte(start:stop);
tomwalters@0 82 % rekursiver Aufruf, denn nun ist das Signal lang genug
tomwalters@0 83 sig=mult(temp,b,start_time,dauer);
tomwalters@0 84 return;
tomwalters@0 85 end
tomwalters@0 86
tomwalters@0 87 % normalfall: Das Ergebnissignal ist nun höchstens genauso lang
tomwalters@0 88 sig=a; %kopieren des alten Signals in das Rückgabesignal
tomwalters@0 89 start1=time2bin(a,start_time)+1; % +1, because a signal starts at the first bin
tomwalters@0 90 stop1=time2bin(a,start_time+dauer);
tomwalters@0 91 start2=1;
tomwalters@0 92 stop2=time2bin(b,dauer);
tomwalters@0 93 sig.werte(start1:stop1)=sig.werte(start1:stop1).*b.werte(start2:stop2);
tomwalters@0 94
tomwalters@0 95 return;
tomwalters@0 96
tomwalters@0 97
tomwalters@0 98
tomwalters@0 99