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 |
|