|
Size: 1741
Comment:
|
Size: 1608
Comment:
|
| Deletions are marked like this. | Additions are marked like this. |
| Line 12: | Line 12: |
| Line 13: | Line 14: |
| if exist('file_out')~=1, % if not output file specified: write to current working directory cwd = pwd; file_out = fullfile( cwd, 'GrandMean.fif' ); end; if exist('files')~=1, % you can specify a list of files here (e.g. on-line averages for all subjects in your study) files = {'/fullpath/file4subj1.fif', ... '/fullpath/file4subj2.fif', ... '/fullpath/file4subj3.fif'}; end; |
% output file name for grand-mean data file_out = '/fullpath/GrandMean.fif'; % List of fiff-files to be averaged fiff_files = {'/fullpath/file4subj1.fif', ... '/fullpath/file4subj2.fif', ... '/fullpath/file4subj3.fif'}; |
| Line 28: | Line 29: |
| nr_files = length(files); | nr_files = length(fiff_files); |
| Line 30: | Line 33: |
| for f = 1:nr_files, % read all files and average all that might be relevant fprintf(1, '%s\n', files{f}); data = fiff_read_evoked(files{f}); if f==1, |
for ff = 1:nr_files, % read all files and average all that might be relevant fprintf(1, '%s\n', fiff_files{ff}); data = fiff_read_evoked(fiff_files{ff}); if ff==1, |
| Line 39: | Line 42: |
| Line 40: | Line 44: |
| Line 41: | Line 46: |
Averaging Fiff-files
Simple Matlab script for averaging of Fiff-files. It assumes that all data files have identical data parameters (e.g. after interpolation).
% Compute the grand-mean for a list of Fiff-files in cell array "files{}"
% The string "file_out" specifies the file name for output
% The first file of the list will be used as a template for Fiff-output
% This obviously assumes that all files have identical parameters (e.g. are
% interpolated to a standard sensor array)
% OH, March 2009
addpath /opt/mne/matlab/toolbox/; % fiff read/write tools
% output file name for grand-mean data
file_out = '/fullpath/GrandMean.fif';
% List of fiff-files to be averaged
fiff_files = {'/fullpath/file4subj1.fif', ...
'/fullpath/file4subj2.fif', ...
'/fullpath/file4subj3.fif'};
fid = fopen(file_out, 'a');
if fid==-1,
fprintf(1, 'Cannot access output file %s\n', file_out);
return;
end;
fclose(fid);
nr_files = length(fiff_files);
epoch_gm = [0];
for ff = 1:nr_files, % read all files and average all that might be relevant
fprintf(1, '%s\n', fiff_files{ff});
data = fiff_read_evoked(fiff_files{ff});
if ff==1,
data_templ = data; % first data set will be used as template for output
end;
epoch_gm = epoch_gm + data.evoked.epochs; % average MEG data epoch
end;
epoch_gm = epoch_gm/nr_files;
data_templ.evoked.epoch = epoch_gm; % insert averaged data into template structure
fiff_write_evoked(file_out, data_templ); % Write average
% The end of this