% BLOCKAVE - make block average of concatenated data sets of same size
% Each data set is assumed to be of size (chans,frames).
% Usage:
% >> aveout = blockave(data,frames)
% >> aveout = blockave(data,frames,epochs,weights)
% Inputs:
% data = data matrix of size (chans,frames*epochs)
% frames = columns per data epoch
% epochs = vector of epochs to average {default|0 -> all}
% weights = vector of epoch weights {default|0 -> equal}
% non-equal weights are normalized internally to sum=1
% Output:
% aveout = averaged data of size (chans, frames)
%
% Author: Scott Makeig, SCCN/INC/UCSD, La Jolla, 1998
% Copyright (C) 1998 Scott Makeig, SCCN/INC/UCSD, scott@sccn.ucsd.edu
%
% This file is part of EEGLAB, see http://www.eeglab.org
% for the documentation and details.
%
% Redistribution and use in source and binary forms, with or without
% modification, are permitted provided that the following conditions are met:
%
% 1. Redistributions of source code must retain the above copyright notice,
% this list of conditions and the following disclaimer.
%
% 2. Redistributions in binary form must reproduce the above copyright notice,
% this list of conditions and the following disclaimer in the documentation
% and/or other materials provided with the distribution.
%
% THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
% AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
% IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
% ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
% LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
% CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
% SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
% INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
% CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
% ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
% THE POSSIBILITY OF SUCH DAMAGE.
% 5-14-98 improved error checking, allowed 2 args -sm
% 01-25-02 reformated help & license -ad
function ave = blockave(data,frames,epochs,weights)
if nargin < 2
help blockave
return
end
if nargin<3
epochs = 0;
end
if nargin<4
weights = nan;
end
if nargin>4
help blockave
end
[chans,framestot]=size(data);
nepochs = floor(framestot/frames);
if nepochs*frames ~= framestot
fprintf('blockave(): frames arg does not divide data length,\n');
return
end
if max(epochs) > nepochs
help blockave
return
end
if min(epochs) < 1
if size(epochs,1)>1 || size(epochs,2) > 1
help blockave
return
else
epochs = 1:nepochs;
end
end
if ~isnan(weights)
if length(weights) ~= nepochs
fprintf(...
'blockave(): number of weights (%d) must match number of epochs (%d).\n',...
length(weights), nepochs);
end
weights = weights/sum(weights); % normalize
end
ave = zeros(chans,frames);
epochs = epochs(:)'; % make epochs a row vector
n = 1;
for e=epochs
if isnan(weights)
ave = ave + data(:,(e-1)*frames+1:e*frames);
else
ave = ave + weights(n)*data(:,(e-1)*frames+1:e*frames);
n = n+1;
end
end
ave = ave/length(epochs);