Changeset 1002 for trunk/src/series


Ignore:
Timestamp:
Feb 28, 2017, 10:41:54 AM (8 years ago)
Author:
sommeria
Message:

correlation_time and correlation_x corrected

Location:
trunk/src/series
Files:
1 deleted
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/series/extract_multitif.m

    r977 r1002  
    5959%=======================================================================
    6060
    61 function ParamOut=extract_multitif(Param)
     61function ParamOut=extract_multitif_parallel(Param)
    6262
    6363%%%%%%%%%%%%%%%%%    INPUT PREPARATION MODE (no RUN)    %%%%%%%%%%%%%%%%%
     
    6565    ParamOut.AllowInputSort='off';% allow alphabetic sorting of the list of input file SubDir (options 'off'/'on', 'off' by default)
    6666    ParamOut.WholeIndexRange='on';% prescribes the file index ranges from min to max (options 'off'/'on', 'off' by default)
    67     ParamOut.NbSlice=1; % impose calculation in a single process (no parallel processing to avoid 'holes'))
     67    ParamOut.NbSlice='off'; % impose calculation in a single process (no parallel processing to avoid 'holes'))
    6868    ParamOut.VelType='off';% menu for selecting the velocity type (options 'off'/'one'/'two',  'off' by default)
    6969    ParamOut.FieldName='off';% menu for selecting the field (s) in the input file(options 'off'/'one'/'two', 'off' by default)
     
    7373    ParamOut.OutputDirExt='.png';%set the output dir extension
    7474    ParamOut.OutputFileMode='NbSlice';% '=NbInput': 1 output file per input file index, '=NbInput_i': 1 file per input file index i, '=NbSlice': 1 file per slice
    75      ParamOut.CheckOverwriteVisible='on'; % manage the overwrite of existing files (default=1)
     75      ParamOut.CheckOverwriteVisible='on'; % manage the overwrite of existing files (default=1)
    7676    %% root input file(s) and type
    7777    % check the existence of the first file in the series
     
    9595        return
    9696    end
    97     xmlinput=uigetfile_uvmat('pick xml file for timing',fileparts(fileparts(FirstFileName)),'.xml');
    98     [tild,ParamOut.ActionInput.XmlFile]=fileparts(xmlinput);
    99     ParamOut.ActionInput.XmlFile
    100    
     97    ParamOut.ActionInput.XmlFile=uigetfile_uvmat('pick xml file for timing',fileparts(fileparts(FirstFileName)),'.xml'); 
    10198    return
    10299end
     
    111108    checkrun=0;
    112109else
    113 hseries=findobj(allchild(0),'Tag','series');
    114 RUNHandle=findobj(hseries,'Tag','RUN');%handle of RUN button in GUI series
    115 WaitbarHandle=findobj(hseries,'Tag','Waitbar');%handle of waitbar in GUI series
     110    hseries=findobj(allchild(0),'Tag','series');
     111    RUNHandle=findobj(hseries,'Tag','RUN');%handle of RUN button in GUI series
     112    WaitbarHandle=findobj(hseries,'Tag','Waitbar');%handle of waitbar in GUI series
    116113end
    117114
    118115%% list of input images
    119 DirImages=fullfile(Param.InputTable{1,1},Param.InputTable{1,2});
    120 ListStruct=dir(DirImages);   
    121 ListCells=struct2cell(ListStruct);% transform dir struct to a cell arrray
    122 check_bad=strcmp('.',ListCells(1,:))|strcmp('..',ListCells(1,:));%detect the dir '.' to exclude it
    123 check_dir=cell2mat(ListCells(4,:));% =1 for directories, =0 for files
    124 ListFile=ListCells(1,find(~check_dir & ~check_bad));
     116% DirImages=fullfile(Param.InputTable{1,1},Param.InputTable{1,2});
     117% ListStruct=dir(DirImages);
     118% ListCells=struct2cell(ListStruct);% transform dir struct to a cell arrray
     119% check_bad=strcmp('.',ListCells(1,:))|strcmp('..',ListCells(1,:));%detect the dir '.' to exclude it
     120% check_dir=cell2mat(ListCells(4,:));% =1 for directories, =0 for files
     121% ListFile=ListCells(1,find(~check_dir & ~check_bad));
    125122
    126123%% check file names
    127 RootName=regexprep(ListFile{1},'.tif$','')
    128 for ilist=2:numel(ListFile)
    129     rank=regexprep(ListFile{ilist},'.tif$','');
    130     rank=regexprep(rank,['^' RootName '@'],'');
    131     if ~isequal(str2num(rank),ilist-1)
    132         disp(['error in the list of input file # ' num2str(ilist-1)])
    133         return
    134     end
    135 end
     124% RootName=regexprep(ListFile{1},'.tif$','')
     125% rank(1)=1;
     126% for ilist=2:numel(ListFile)
     127%     rank_str=regexprep(ListFile{ilist},'.tif$','');
     128%     rank(ilist)=regexprep(rank_str,['^' RootName '@'],'');
     129% %     if ~isequal(str2num(rank),ilist-1)
     130% %         disp(['error in the list of input file # ' num2str(ilist-1)])
     131% %         return
     132% %     end
     133% end
    136134
    137135%% output directory
    138  OutputDir=fullfile(Param.InputTable{1,1},[Param.OutputSubDir Param.OutputDirExt]);
    139  
    140 %% Timing
    141 XmlInputFile=fullfile(Param.InputTable{1,1},[Param.ActionInput.XmlFile '.xml'])
    142 XmlInput=imadoc2struct(XmlInputFile,'Camera');
     136OutputDir=fullfile(Param.InputTable{1,1},[Param.OutputSubDir Param.OutputDirExt]);
     137
     138%% Timing
     139XmlInputFile=Param.ActionInput.XmlFile;
     140[XmlInput,errormsg]=imadoc2struct(XmlInputFile,'Camera');
     141if ~isempty(errormsg)
     142    disp(['bad xml input file: ' errormsg])
     143    return
     144end
     145ImagesPerLevel=size(XmlInput.Time,2)-1;%100;%use the xmlinformation to get the nbre of j indices
     146
     147%% create the xml file of PCO camera if it does not exist
     148Newxml=fullfile(Param.InputTable{1,1},[Param.InputTable{1,2} '.xml']);
     149if ~exist(Newxml,'file')
     150XmlInput.Camera.CameraName='PCO';
     151XmlInput=rmfield(XmlInput,'Time');
     152XmlInput=rmfield(XmlInput,'TimeUnit');
     153t=struct2xml(XmlInput);
     154t=set(t,1,'name','ImaDoc');
     155save(t,Newxml);
     156end
    143157
    144158%% Main loop
    145159
    146 ImagesPerLevel=size(XmlInput.Time,2)-1;%100;
    147 count=0;
     160
     161% count=0;
    148162%count=316;%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%CORRECTION EXP08: 4684 images -> start at 316 start 67->_11_1
    149163%count=1934%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%CORRECTION EXP07: 3066 images
    150 %% loop on the files 
    151 for ifile=1:numel(ListFile)
    152     update_waitbar(WaitbarHandle,ifile/numel(ListFile))
    153     if ~isempty(RUNHandle)&& ~strcmp(get(RUNHandle,'BusyAction'),'queue')
    154         disp('program stopped by user')
    155         break
    156     end
    157     ImageName=fullfile(DirImages,ListFile{ifile});
     164%% loop on the files
     165% include the first tiff file with no index in the first iteration
     166if Param.IndexRange.first_i==1% first slice of processing
     167    firstindex=0;
     168   count=0;
     169else
     170    firstindex=Param.IndexRange.first_i;
     171    ImageName=fullfile(Param.InputTable{1,1},Param.InputTable{1,2},'im.tif');
    158172    NbFrames=numel(imfinfo(ImageName));
    159     % loop on the frames within the tiff file
    160     for iframe=1:NbFrames       
     173   count=Param.IndexRange.first_i*NbFrames;
     174end
     175for ifile=firstindex:Param.IndexRange.last_i
     176    if firstindex==0 && ifile==0% first slice of processing
     177        ImageName=fullfile(Param.InputTable{1,1},Param.InputTable{1,2},'im.tif')
     178    else
     179        ImageName=fullfile(Param.InputTable{1,1},Param.InputTable{1,2},['im@' num2str(ifile,'%04d') '.tif'])
     180    end
     181    NbFrames=numel(imfinfo(ImageName));
     182    for iframe=1:NbFrames
     183        iframe
    161184        if isequal(ImagesPerLevel,1)% mode series
    162             i_index=count+1;
    163185            OutputFile=fullfile(OutputDir,['img_' num2str(count+1) '.png']);
    164186        else % indices i and j
     
    178200end
    179201
    180 % for ifile=1:numel(ListFile)
    181 %     update_waitbar(WaitbarHandle,ifile/numel(ListFile))
    182 %     if ~isempty(RUNHandle)&& ~strcmp(get(RUNHandle,'BusyAction'),'queue')
    183 %         disp('program stopped by user')
    184 %         break
    185 %     end
    186 %     ImageName=fullfile(DirImages,ListFile{ifile});
    187 %     NbFrames=numel(imfinfo(ImageName));
    188 %     % loop on the frames within the tiff file
    189 %     for iframe=1:NbFrames     
    190 %         A=imread(ImageName,iframe);
    191 %
    192 %         if isequal(ImagesPerLevel,1)% mode series
    193 %             i_index=count+1;
    194 %             OutputFile=fullfile(OutputDir,['img_' num2str(count+1) '.png']);
    195 %         else % indices i and j
    196 %             i_index=fix(count/ImagesPerLevel)+1;
    197 %             j_index=mod(count,ImagesPerLevel)+1;
    198 %             OutputFile=fullfile(OutputDir,['img_' num2str(i_index) '_' num2str(j_index) '.png']);
    199 %         end
    200 %         imwrite(A,OutputFile,'BitDepth',16)
    201 %         count=count+1;
    202 %     end
    203 % end
    204 
    205 %% create the xml file of PCO camera
    206 XmlInput.Camera.CameraName='PCO';
    207 t=struct2xml(XmlInput.Camera);
    208 t=set(t,1,'name','ImaDoc');
    209 save(t,fullfile(Param.InputTable{1,1},'PCO.xml'))
    210 
    211 %% remove initial files if transfer OK
    212 %     if i_index== (size(XmlInput.Time,1)-1)
    213 %
    214 %         [SUCCESS,MESSAGE]=rmdir(DirImages,'s')
    215 %       
    216 %     end
     202
     203
  • trunk/src/series/turb_correlation_time.m

    r1001 r1002  
    5757%=======================================================================
    5858
    59 function ParamOut=turb_stat(Param)
     59function ParamOut=turb_correlation_time(Param)
    6060
    6161%% set the input elements needed on the GUI series when the action is selected in the menu ActionName
     
    6363    ParamOut.AllowInputSort='off';% allow alphabetic sorting of the list of input file SubDir (options 'off'/'on', 'off' by default)
    6464    ParamOut.WholeIndexRange='off';% prescribes the file index ranges from min to max (options 'off'/'on', 'off' by default)
    65     ParamOut.NbSlice='off'; %nbre of slices ('off' by default)
     65    ParamOut.NbSlice=1; %nbre of slices ('off' by default)
    6666    ParamOut.VelType='off';% menu for selecting the velocity type (options 'off'/'one'/'two',  'off' by default)
    6767    ParamOut.FieldName='one';% menu for selecting the field (s) in the input file(options 'off'/'one'/'two', 'off' by default)
     
    277277        FFCorr=false(NpTime+1,npy,npx);
    278278    end
     279    Field.U=Field.U-UMean;
     280    Field.V=Field.V-VMean;
    279281    FF=isnan(Field.U);%|Field.U<-60|Field.U>30;% threshold on U
    280282    Field.U(FF)=0;% set to 0 the nan values,'delta_x'
    281283    Field.V(FF)=0;
    282     Field.U=Field.U-UMean;
    283     Field.V=Field.V-VMean;
    284284    if index<=NpTime+1
    285         U_shift(index,:,:)=Field.U;
    286         V_shift(index,:,:)=Field.V;
    287         FF_shift(index,:,:)=FF;
     285        U_shift(NpTime+2-index,:,:)=Field.U;
     286        V_shift(NpTime+2-index,:,:)=Field.V;
     287        FF_shift(NpTime+2-index,:,:)=FF;
    288288    else
    289         U_shift=circshift(U_shift,[-1 0 0]); %shift U by ishift along the first index
    290         V_shift=circshift(V_shift,[-1 0 0]); %shift U by ishift along the first index
    291         FF_shift=circshift(FF_shift,[-1 0 0]); %shift U by ishift along the first index
    292         U_shift(NpTime+1,:,:)=Field.U;
    293         V_shift(NpTime+1,:,:)=Field.V;
    294         FF_shift(NpTime+1,:,:)=FF;
    295     end
    296     for ishift=1:NpTime% calculate the field U shifted
    297         UUCorr(ishift,:,:)=Field.U.*U_shift(ishift,:,:);
    298         VVCorr(ishift,:,:)=Field.V.*V_shift(ishift,:,:);
    299         UVCorr(ishift,:,:)=Field.U.*V_shift(ishift,:,:);
    300         FFCorr(ishift,:,:)=FF | FF_shift;
     289        U_shift=circshift(U_shift,[1 0 0]); %shift U by ishift along the first index
     290        V_shift=circshift(V_shift,[1 0 0]); %shift U by ishift along the first index
     291        FF_shift=circshift(FF_shift,[1 0 0]); %shift U by ishift along the first index
     292        U_shift(1,:,:)=Field.U;
     293        V_shift(1,:,:)=Field.V;
     294        FF_shift(1,:,:)=FF;
     295    end
     296    for ishift=1:NpTime+1% calculate the field U shifted
     297        UUCorr(ishift,:,:)=Field.U.*squeeze(U_shift(ishift,:,:));
     298        VVCorr(ishift,:,:)=Field.V.*squeeze(V_shift(ishift,:,:));
     299        UVCorr(ishift,:,:)=Field.U.*squeeze(V_shift(ishift,:,:));
     300        FFCorr(ishift,:,:)=FF | squeeze(FF_shift(ishift,:,:));
    301301    end
    302302    DataOut.UUCorr=DataOut.UUCorr+UUCorr;
     
    306306end
    307307%%%%%%%%%%%%%%%% end loop on field indices %%%%%%%%%%%%%%%%
    308 % DataOut.UUCorr=DataOut.UUCorr./DataOut.Counter;
    309 % DataOut.VVCorr=DataOut.VVCorr./DataOut.Counter;
    310 % DataOut.VUVCorr=DataOut.UVCorr./DataOut.Counter;
    311 %DataOut.Counter(DataOut.Counter==0)=1;% put counter to 1 when it is zero
     308DataOut.Counter(DataOut.Counter==0)=1;% put counter to 1 when it is zero (to avoid NaN)
     309DataOut.UUCorr=DataOut.UUCorr./DataOut.Counter;
     310DataOut.VVCorr=DataOut.VVCorr./DataOut.Counter;
     311DataOut.UVCorr=DataOut.UVCorr./DataOut.Counter;
     312
    312313% DataOut.UMean=DataOut.UMean./DataOut.Counter; % normalize the mean
    313314% DataOut.VMean=DataOut.VMean./DataOut.Counter; % normalize the mean
  • trunk/src/series/turb_correlation_x.m

    r1001 r1002  
    5757%=======================================================================
    5858
    59 function ParamOut=turb_stat(Param)
     59function ParamOut=turb_correlation_x(Param)
    6060
    6161%% set the input elements needed on the GUI series when the action is selected in the menu ActionName
     
    290290DataOut.UUCorr=DataOut.UUCorr./DataOut.Counter;
    291291DataOut.VVCorr=DataOut.VVCorr./DataOut.Counter;
    292 DataOut.VUVCorr=DataOut.UVCorr./DataOut.Counter;
     292DataOut.UVCorr=DataOut.UVCorr./DataOut.Counter;
    293293%DataOut.Counter(DataOut.Counter==0)=1;% put counter to 1 when it is zero
    294294% DataOut.UMean=DataOut.UMean./DataOut.Counter; % normalize the mean
Note: See TracChangeset for help on using the changeset viewer.