| 1 |
function []=averagesFields(doInitFiles,doWriteMean,rep_out,suff_out,varargin); |
| 2 |
global averagesFields_count; |
| 3 |
|
| 4 |
%algorithm: |
| 5 |
% first call (doInitFiles=1 doWriteMean=0) -> init files, arrays and set counter to 0 |
| 6 |
% loop calls (doInitFiles=0 doWriteMean=0) -> increment counter and arrays |
| 7 |
% dump calls (doInitFiles=0 doWriteMean=1) -> write one record, re-initialize arrays and counter |
| 8 |
% final call (doInitFiles=-1 doWriteMean=0) -> close files |
| 9 |
|
| 10 |
%input: varargin is a series of structures |
| 11 |
|
| 12 |
if doInitFiles==1&doWriteMean==0; |
| 13 |
averagesFields_count=1; |
| 14 |
for icur=1:length(varargin); |
| 15 |
eval(['global struct' num2str(icur) '; struct' num2str(icur) '=varargin{icur}; ']); |
| 16 |
vars_struct=fieldnames(varargin{icur}); |
| 17 |
eval(['global fid_struct' num2str(icur) '; fid_struct' num2str(icur) '=zeros(1,length(vars_struct));']); |
| 18 |
for vcur=1:length(vars_struct); |
| 19 |
tmp1=cell2mat(vars_struct(vcur)); tmp2=[rep_out tmp1 suff_out]; |
| 20 |
eval(['fid_struct' num2str(icur) '(vcur)=fopen(''' tmp2 ''',''w'',''b'');']); |
| 21 |
end |
| 22 |
end |
| 23 |
|
| 24 |
elseif doInitFiles==0&doWriteMean==0; |
| 25 |
averagesFields_count=averagesFields_count+1; |
| 26 |
for icur=1:length(varargin); |
| 27 |
eval(['global struct' num2str(icur) ';']); |
| 28 |
vars_struct=fieldnames(varargin{icur}); |
| 29 |
for vcur=1:length(vars_struct); |
| 30 |
tmp1=cell2mat(vars_struct(vcur)); |
| 31 |
eval(['struct' num2str(icur) '.' tmp1 '=struct' num2str(icur) '.' tmp1 '+varargin{icur}.' tmp1 ';']); |
| 32 |
end |
| 33 |
end |
| 34 |
|
| 35 |
elseif doInitFiles==0&doWriteMean==1; |
| 36 |
for icur=1:length(varargin); |
| 37 |
eval(['global fid_struct' num2str(icur) ' struct' num2str(icur) ';']); |
| 38 |
vars_struct=fieldnames(varargin{icur}); |
| 39 |
for vcur=1:length(vars_struct); |
| 40 |
tmp1=cell2mat(vars_struct(vcur)); |
| 41 |
eval(['fwrite(fid_struct' num2str(icur) '(vcur),struct' num2str(icur) '.' tmp1 '/averagesFields_count,''float32'');']); |
| 42 |
eval(['struct' num2str(icur) '.' tmp1 '(:)=0;']); |
| 43 |
end |
| 44 |
end |
| 45 |
averagesFields_count=0; |
| 46 |
|
| 47 |
elseif doInitFiles==-1&doWriteMean==0; |
| 48 |
for icur=1:length(varargin); |
| 49 |
eval(['global fid_struct' num2str(icur) ' struct' num2str(icur) ';']); |
| 50 |
vars_struct=fieldnames(varargin{icur}); |
| 51 |
for vcur=1:length(vars_struct); eval(['fclose(fid_struct' num2str(icur) '(vcur));']); end; |
| 52 |
eval(['clear struct' num2str(icur) ';']); |
| 53 |
end |
| 54 |
averagesFields_count=[]; |
| 55 |
|
| 56 |
else |
| 57 |
fprintf('error in averagesFields \n'); |
| 58 |
averagesFields_count=[]; |
| 59 |
end |
| 60 |
|