wolffd@0: function y=logsum(x,d) wolffd@0: %LOGSUM logsum(x,d)=log(sum(exp(x),d)) wolffd@0: % d gives dimension to sum along wolffd@0: wolffd@0: % Copyright (C) Mike Brookes 1998 wolffd@0: % wolffd@0: % Last modified Mon Oct 12 15:47:25 1998 wolffd@0: % wolffd@0: % VOICEBOX is a MATLAB toolbox for speech processing. Home page is at wolffd@0: % http://www.ee.ic.ac.uk/hp/staff/dmb/voicebox/voicebox.html wolffd@0: % wolffd@0: wolffd@0: if nargin==1 wolffd@0: d=[find(size(x)-1) 1]; wolffd@0: d=d(1); wolffd@0: end wolffd@0: n=size(x,d); wolffd@0: if n<=1, y=x; return; end wolffd@0: s=size(x); wolffd@0: p=[d:ndims(x) 1:d-1]; wolffd@0: z=reshape(permute(x,p),n,prod(s)/n); wolffd@0: wolffd@0: y=max(z); wolffd@0: y=y+log(sum(exp(z-y(ones(n,1),:)))); wolffd@0: wolffd@0: s(d)=1; wolffd@0: y=ipermute(reshape(y,s(p)),p); wolffd@0: