Changeset 1157
- Timestamp:
- Jul 11, 2024, 4:13:03 PM (2 months ago)
- Location:
- trunk/src
- Files:
-
- 1 added
- 12 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/fullfile_uvmat.m
r1127 r1157 63 63 64 64 %% default input 65 if iscell(NomType) 66 NomType=NomType{1} 67 end 65 68 if ~exist('j2','var') 66 69 j2=[]; -
trunk/src/get_field.m
r1127 r1157 509 509 VarIndex=find(strcmp(VarName,Field.Display.ListVarName),1); 510 510 DimCell=Field.Display.VarDimName{VarIndex}; 511 % y_index=get(handles.Coord_y,'Value'); 512 % y_menu=get(handles.Coord_y,'String'); 513 % if isempty(y_menu) 514 % return 515 % else 516 % YName=y_menu{y_index}; 517 % end 511 518 512 519 513 %% set list of possible coordinates 520 % test_component=zeros(size(Field.Display.VarDimName));%=1 when variable #ilist is eligible as unstructured coordinate 514 521 515 test_coord=zeros(size(Field.Display.VarDimName)); %=1 when variable #ilist is eligible as structured coordiante 522 % ListCoord={''};523 % dim_var=Field.Display.VarDimName{y_index};%list of dimensions of the selected variable524 516 525 517 for ilist=1:numel(Field.Display.VarDimName) 526 dimnames=Field.Display.VarDimName{ilist}; %list of dimensions for variable #ilist 527 if isequal(dimnames,DimCell)||isequal(dimnames(1:end-1),DimCell)||isequal(dimnames(2:end),DimCell) 528 test_coord(ilist)=1; 529 end 530 end 531 ListCoord=Field.Display.ListVarName(find(test_coord)); 518 %dimnames=Field.Display.VarDimName{ilist}; %list of dimensions for variable #ilist 519 % if isequal(dimnames,DimCell)||isequal(dimnames(1:end-1),DimCell)||isequal(dimnames(2:end),DimCell) 520 % if numel(dimnames)==1 || 521 % test_coord(ilist)=1; 522 % end 523 end 524 ListCoord=Field.Display.ListVarName;%(find(test_coord)); 532 525 set(handles.Coord_y,'String',ListCoord) 533 526 val_y=1; … … 984 977 %----------------------------------------------------------------------- 985 978 Field=get(handles.get_field,'UserData'); 986 index=name2index(VarName,Field.ListVarName); 979 index=name2index(VarName,Field.ListVarName); %index of the selectd variable 987 980 if ~isempty(index) 988 set(handles.variables,'Value',index+1) 981 set(handles.variables,'Value',index+1) %indicate which variable is selected in the list (+1 because of the '*' display) 989 982 variables_Callback(handles.variables, VarName, handles) 990 983 end -
trunk/src/get_file_info.m
r1134 r1157 78 78 FileInfo.FileType=regexprep(FileExt,'^.','');% eliminate the dot of the extension; 79 79 case {'.seq','.sqb'} 80 [ A,FileInfo,timestamps,errormsg]=read_rdvision(fileinput,[]);80 [~,FileInfo,timestamps,errormsg]=read_rdvision(fileinput,[]); 81 81 case '.im7' 82 82 try … … 89 89 FileInfo.TimeName='timestamp'; 90 90 for ilist=1:numel(Input.Attributes) 91 if strcmp(Input.Attributes{ilist}.Name,'_Date')92 DateString=Input.Attributes{ilist}.Value;93 end94 if strcmp(Input.Attributes{ilist}.Name,'_Time')95 TimeString=Input.Attributes{ilist}.Value;96 end91 % if strcmp(Input.Attributes{ilist}.Name,'_Date') 92 % DateString=Input.Attributes{ilist}.Value; 93 % end 94 % if strcmp(Input.Attributes{ilist}.Name,'_Time') 95 % TimeString=Input.Attributes{ilist}.Value; 96 % end 97 97 end 98 98 catch ME … … 175 175 FileInfo.FileType='netcdf'; 176 176 FileInfo.ListVarName=Data.ListVarName; 177 FileInfo.VarAttribute=Data.VarAttribute; 177 178 end 178 179 end -
trunk/src/msgbox_uvmat.m
r1127 r1157 10 10 % title: string indicating the type of message box (the title is displayed in the upper bar of the fig): 11 11 % ='INPUT_TXT'(default), input data is asked in an edit box 12 % = 'INPUT_MENU', input data must be selected from a menu choice 12 13 % ='CONFIMATION'', 'ERROR', 'WARNING','RULER' the figure remains opened until a button 'OK' is pressed 13 14 % ='RULER' is used for display of length and angle from the ruler tool. … … 16 17 % ='WAITING...' the figure remains open until the program deletes it 17 18 % display: displayed text 18 % default_answer: default answer in the edit box (only used with title='INPUT_TXT' )19 % default_answer: default answer in the edit box (only used with title='INPUT_TXT' or 'INPUT_MENU') 19 20 20 21 %======================================================================= … … 69 70 set(handles.figure1,'Units','pixels') 70 71 FigPos=[100 150 500 50];%default position 72 if strcmp(title,'INPUT_MENU') 73 FigPos=[100 150 500 200];%default position 74 end 71 75 if exist('Position','var') && numel(Position)>=2 72 76 FigPos(1)=Position(1); … … 164 168 set(handles.edit_box, 'Visible', 'on'); 165 169 set(handles.edit_box,'String', default_answer) 170 set(handles.edit_box,'Max',2);% allows for multiple selection 166 171 else 167 172 set(handles.text1, 'Position', [0.15 0.3 0.85 0.7]); -
trunk/src/nc2struct.m
r1127 r1157 27 27 % additional arguments: 28 28 % -no additional arguments: all the variables of the NetCDF file are read. 29 % - empty argument []: the field structure with the names of variables is read, without their values 29 30 % -a cell array, ListVarName, made of char strings {'VarName1', 'VarName2',...} ) 30 31 % if ListVarName=[] or {}, no variable value is read (only global attributes and list of variables and dimensions) -
trunk/src/series/civ2vel_3C.m
r1155 r1157 418 418 MergeData.VarDimName={'coord_x','coord_y',{'coord_y','coord_x'},{'coord_y','coord_x'}... 419 419 {'coord_y','coord_x'},{'coord_y','coord_x'}}; 420 MergeData.VarAttribute{1}.Role='coord_x'; 421 MergeData.VarAttribute{2}.Role='coord_y'; 422 MergeData.VarAttribute{3}.Role='vector_x'; 423 MergeData.VarAttribute{4}.Role='vector_y'; 424 MergeData.VarAttribute{5}.Role='vector_z'; 425 MergeData.VarAttribute{6}.Role='ancillary'; 420 426 MergeData.VarAttribute{6}.unit='pixel'; %error estimate expressed in pixel 421 427 if CheckZ -
trunk/src/series/civ_3D.m
r1156 r1157 130 130 end 131 131 132 [ tild,i1_series,i2_series,j1_series,j2_series]=get_file_series(Param);132 [~,i1_series,~,j1_series,~]=get_file_series(Param); 133 133 iview_A=0;% series index (iview) for the first image series 134 134 iview_B=0;% series index (iview) for the second image series (only non zero for option 'shift' comparing two image series ) … … 156 156 PairCiv1=Param.ActionInput.PairIndices.ListPairCiv1; 157 157 158 [i1_series_Civ1,i2_series_Civ1,j1_series_Civ1,j2_series_Civ1, check_bounds,NomTypeNc]=...158 [i1_series_Civ1,i2_series_Civ1,j1_series_Civ1,j2_series_Civ1,~,NomTypeNc]=... 159 159 find_pair_indices(PairCiv1,i1_series{1},j1_series{1},MinIndex_i,MaxIndex_i,MinIndex_j,MaxIndex_j); 160 160 … … 168 168 %% prepare output Data 169 169 ListGlobalAttribute={'Conventions','Program','CivStage'}; 170 Data.Conventions='uvmat/civdata';% states the conventions used for the description of field variables and attributes 171 Data.Program='civ_series'; 170 Data.Conventions='uvmat/civdata_3D';% states the conventions used for the description of field variables and attributes 171 Data.Program='civ_3D'; 172 if isfield(Param,'UvmatRevision') 173 Data.Program=[Data.Program ', uvmat r' Param.UvmatRevision]; 174 end 172 175 Data.CivStage=0;%default 173 176 list_param=(fieldnames(Param.ActionInput.Civ1))'; 174 175 176 177 list_param(strcmp('TestCiv1',list_param))=[];% remove the parameter TestCiv1 from the list 178 Civ1_param=regexprep(list_param,'^.+','Civ1_$0');% insert 'Civ1_' before each string in list_param 179 Civ1_param=[{'Civ1_ImageA','Civ1_ImageB','Civ1_Time','Civ1_Dt'} Civ1_param]; %insert the names of the two input images 177 180 Data.ListGlobalAttribute=[ListGlobalAttribute Civ1_param]; 178 % set the list of variables 179 Data.ListVarName={'Civ1_X','Civ1_Y','Civ1_U','Civ1_V','Civ1_W','Civ1_C','Civ1_FF'};% cell array containing the names of the fields to record 180 Data.VarDimName={'nb_vec_1','nb_vec_1','nb_vec_1','nb_vec_1','nb_vec_1','nb_vec_1','nb_vec_1'}; 181 Data.VarAttribute{1}.Role='coord_x'; 182 Data.VarAttribute{2}.Role='coord_y'; 183 Data.VarAttribute{3}.Role='vector_x'; 184 Data.VarAttribute{4}.Role='vector_y'; 185 Data.VarAttribute{5}.Role='vector_z'; 186 Data.VarAttribute{6}.Role='ancillary'; 187 Data.VarAttribute{7}.Role='errorflag'; 181 % set the list of variables 182 Data.ListVarName={'Coord_z','Coord_y','Coord_x','Civ1_X','Civ1_Y','Civ1_U','Civ1_V','Civ1_W','Civ1_C','Civ1_FF'};% cell array containing the names of the fields to record 183 Data.VarDimName={'npz','npy','npx',{'npz','npy','npx'},{'npz','npy','npx'},{'npz','npy','npx'},{'npz','npy','npx'},... 184 {'npz','npy','npx'},{'npz','npy','npx'},{'npz','npy','npx'}}; 185 Data.VarAttribute{1}.Role='coord_x'; 186 Data.VarAttribute{2}.Role='coord_y'; 187 Data.VarAttribute{3}.Role='vector_x'; 188 Data.VarAttribute{4}.Role='vector_y'; 189 Data.VarAttribute{5}.Role='vector_z'; 190 Data.VarAttribute{6}.Role='ancillary'; 191 Data.VarAttribute{7}.Role='errorflag'; 192 Data.Coord_z=j1_series_Civ1; 193 % path for output nc file 194 OutputPath=fullfile(Param.OutputPath,num2str(Param.Experiment),num2str(Param.Device),[Param.OutputSubDir Param.OutputDirExt]); 188 195 189 196 %% get timing from the ImaDoc file or input video … … 227 234 par_civ1.ImageA=zeros(2*SearchRange_z+1,npy,npx); 228 235 par_civ1.ImageB=zeros(2*SearchRange_z+1,npy,npx); 236 237 229 238 230 239 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% … … 268 277 269 278 Data.CivStage=1; 270 % output nc file271 ncfile_out=fullfile_uvmat(OutputPath, Param.InputTable{1,2},Param.InputTable{1,3},Param.InputTable{1,5},...272 NomTypeNc,i1_series_Civ1(ifield),i2_series_Civ1(ifield),j1_series_Civ1(ifield),j2_series_Civ1(ifield));279 280 ncfile_out=fullfile_uvmat(OutputPath,'',Param.InputTable{1,3},'.nc',... 281 '_1-1',i1_series_Civ1(ifield),i2_series_Civ1(ifield)); %output file name 273 282 274 283 if ~CheckOverwrite && exist(ncfile_out,'file') … … 284 293 disp('civ1 started') 285 294 286 287 % read input images (except in mode Test where it is introduced directly in Param.ActionInput.Civ1.ImageNameA and B) 288 289 par_civ1.ImageA=zeros(2*SearchRange_z+1,npy,npx); 295 % read input images by vertical blocks with nbre of images equal to 2*SearchRange+1, 296 par_civ1.ImageA=zeros(2*SearchRange_z+1,npy,npx);%image block initiation 290 297 par_civ1.ImageB=zeros(2*SearchRange_z+1,npy,npx); 291 %first vertical block centered at image index islice=par_civ1.Dz 292 islice=par_civ1.Dz; 293 for iz=1:par_civ1.Dz+SearchRange_z 294 ImageName_A=fullfile_uvmat(RootPath_A,SubDir_A,RootFile_A,FileExt_A,NomType_A,i1_series_Civ1(1,ifield),[],j1_series_Civ1(iz,1));% 298 299 z_index=1;%first vertical block centered at image index z_index=par_civ1.Dz 300 for iz=1:par_civ1.Dz+SearchRange_z 301 j_image_index=j1_series_Civ1(iz,1)% j index of the current image 302 ImageName_A=fullfile_uvmat(RootPath_A,SubDir_A,RootFile_A,FileExt_A,NomType_A,i1_series_Civ1(1,ifield),[],j_image_index);% 295 303 A= read_image(ImageName_A,FileType_A); 296 ImageName_B=fullfile_uvmat(RootPath_B,SubDir_B,RootFile_B,FileExt_B,NomType_B,i2_series_Civ1(1,ifield),[],j 1_series_Civ1(iz,1));304 ImageName_B=fullfile_uvmat(RootPath_B,SubDir_B,RootFile_B,FileExt_B,NomType_B,i2_series_Civ1(1,ifield),[],j_image_index); 297 305 B= read_image(ImageName_B,FileType_B); 298 306 par_civ1.ImageA(iz+par_civ1.Dz-1,:,:) = A; 299 307 par_civ1.ImageB(iz+par_civ1.Dz-1,:,:) = B; 300 end 301 % caluclate velocity data (y and v in indices, reverse to y component) 302 [Data.Civ1_X(islice,:,:),Data.Civ1_Y(islice,:,:), utable, vtable,wtable, ctable, FF, result_conv, errormsg] = civ3D (par_civ1); 308 end 309 % calculate velocity data at the first position z, corresponding to j_index=par_civ1.Dz 310 [Data.Civ1_X(1,:,:),Data.Civ1_Y(1,:,:), Data.Civ1_U(1,:,:), Data.Civ1_V(1,:,:),Data.Civ1_W(1,:,:),... 311 Data.Civ1_C(1,:,:), Data.Civ1_FF(1,:,:), result_conv, errormsg] = civ3D (par_civ1); 312 if ~isempty(errormsg) 313 disp_uvmat('ERROR',errormsg,checkrun) 314 return 315 end 316 for z_index=2:floor((NbSlice-1)/par_civ1.Dz)% loop on slices 317 par_civ1.ImageA=circshift(par_civ1.ImageA,-par_civ1.Dz);%shift the indices in the image block upward by par_civ1.Dz 318 par_civ1.ImageB=circshift(par_civ1.ImageA,-par_civ1.Dz); 319 for iz=1:par_civ1.Dz %read the new images at the end of the image block 320 j_image_index=j1_series_Civ1(z_index*par_civ1.Dz+SearchRange_z-par_civ1.Dz+iz,1) 321 ImageName_A=fullfile_uvmat(RootPath_A,SubDir_A,RootFile_A,FileExt_A,NomType_A,i1_series_Civ1(1,ifield),[],j_image_index);% 322 A= read_image(ImageName_A,FileType_A); 323 ImageName_B=fullfile_uvmat(RootPath_B,SubDir_B,RootFile_B,FileExt_B,NomType_B,i2_series_Civ1(1,ifield),[],j_image_index); 324 B= read_image(ImageName_B,FileType_B); 325 par_civ1.ImageA(2*SearchRange_z+1-par_civ1.Dz+iz,:,:) = A; 326 par_civ1.ImageB(2*SearchRange_z+1-par_civ1.Dz+iz,:,:) = B; 327 end 328 % caluclate velocity data (y and v in indices, reverse to y component) 329 [Data.Civ1_X(z_index,:,:),Data.Civ1_Y(z_index,:,:), Data.Civ1_U(z_index,:,:), Data.Civ1_V(z_index,:,:),Data.Civ1_W(z_index,:,:),... 330 Data.Civ1_C(z_index,:,:), Data.Civ1_FF(z_index,:,:), result_conv, errormsg] = civ3D (par_civ1); 331 303 332 if ~isempty(errormsg) 304 333 disp_uvmat('ERROR',errormsg,checkrun) 305 334 return 306 335 end 307 for islice=2*par_civ1.Dz:NbSlice% loop on slices for the first image in the pair 308 par_civ1.ImageA=circshift(par_civ1.ImageA,-par_civ1.Dz);%shift the indces in the block upward by par_civ1.Dz 309 par_civ1.ImageB=circshift(par_civ1.ImageA,-par_civ1.Dz); 310 for iz=1:par_civ1.Dz 311 ImageName_A=fullfile_uvmat(RootPath_A,SubDir_A,RootFile_A,FileExt_A,NomType_A,i1_series_Civ1(1,ifield),[],j1_series_Civ1(islice+SearchRange_z-par_civ1.Dz+iz,1));% 312 A= read_image(ImageName_A,FileType_A); 313 ImageName_B=fullfile_uvmat(RootPath_B,SubDir_B,RootFile_B,FileExt_B,NomType_B,i2_series_Civ1(1,ifield),[],j1_series_Civ1(islice+SearchRange_z-par_civ1.Dz+iz,1)); 314 B= read_image(ImageName_B,FileType_B); 315 par_civ1.ImageA(2*SearchRange_z+1-par_civ1.Dz+iz,:,:) = A; 316 par_civ1.ImageB(2*SearchRange_z+1-par_civ1.Dz+iz,:,:) = B; 317 end 318 % caluclate velocity data (y and v in indices, reverse to y component) 319 [Data.Civ1_X(islice,:,:),Data.Civ1_Y(islice,:,:), utable, vtable,wtable, ctable, FF, result_conv, errormsg] = civ3D (par_civ1); 320 if ~isempty(errormsg) 321 disp_uvmat('ERROR',errormsg,checkrun) 322 return 323 end 324 325 end 336 end 337 Data.Civ1_C=double(Data.Civ1_C); 338 Data.Civ1_C(Data.Civ1_C==Inf)=0; 339 [npz,npy,npx]=size(Data.Civ1_X); 340 Data.Coord_z=1:npz; 341 Data.Coord_y=1:npy; 342 Data.Coord_x=1:npx; 326 343 % case of mask TO ADAPT 327 344 if par_civ1.CheckMask&&~isempty(par_civ1.Mask) … … 668 685 end 669 686 Data.ListGlobalAttribute=[Data.ListGlobalAttribute Fix2_param]; 670 Data.Civ2_FF=d ouble(detect_false(Param.ActionInput.Fix2,Data.Civ2_C,Data.Civ2_U,Data.Civ2_V,Data.Civ2_FF));687 Data.Civ2_FF=detect_false(Param.ActionInput.Fix2,Data.Civ2_C,Data.Civ2_U,Data.Civ2_V,Data.Civ2_FF); 671 688 Data.CivStage=Data.CivStage+1; 672 689 end … … 728 745 time_total=toc(tstart); 729 746 disp(['ellapsed time ' num2str(time_total/60,2) ' minutes']) 730 disp(['time image reading ' num2str(time_input,2) ' s'])731 747 disp(['time civ1 ' num2str(time_civ1,2) ' s']) 732 748 disp(['time patch1 ' num2str(time_patch1,2) ' s']) 733 749 disp(['time civ2 ' num2str(time_civ2,2) ' s']) 734 750 disp(['time patch2 ' num2str(time_patch2,2) ' s']) 735 disp(['time other ' num2str((time_total-time_input-time_civ1-time_patch1-time_civ2-time_patch2),2) ' s']) 736 % end 751 737 752 end 738 753 … … 860 875 for ivec_x=1:nbvec_x 861 876 for ivec_y=1:nbvec_y 862 ivec_y 863 iref=round(par_civ.Grid(ivec_y,ivec_x,1)+0.5)% xindex on the image A for the middle of the correlation box 864 jref=round(par_civ.ImageHeight-par_civ.Grid(ivec_y,ivec_x,2)+0.5)% j index for the middle of the correlation box in the image A 877 iref=round(par_civ.Grid(ivec_y,ivec_x,1)+0.5);% xindex on the image A for the middle of the correlation box 878 jref=round(par_civ.ImageHeight-par_civ.Grid(ivec_y,ivec_x,2)+0.5);% j index for the middle of the correlation box in the image A 865 879 subrange1_x=iref-ibx2:iref+ibx2;% x indices defining the first subimage 866 880 subrange1_y=jref-iby2:jref+iby2;% y indices defining the first subimage … … 918 932 919 933 920 %reference: Oliver Pust, PIV: Direct Cross-Correlation934 921 935 for kz=1:par_civ.SearchBoxSize(3) 922 936 subima2=squeeze(image2_crop(kz,:,:)); … … 928 942 929 943 end 930 [corrmax,z ]=max(max_xy);944 [corrmax,zmax]=max(max_xy); 931 945 932 x=xk(z );933 y=yk(z );946 x=xk(zmax); 947 y=yk(zmax); 934 948 result_conv=(result_conv/corrmax)*255; %normalize, peak=always 255 935 subimage2_crop=squeeze(image2_crop(z ,y:y+2*iby2/mesh,x:x+2*ibx2/mesh));%subimage of image 2 corresponding to the optimum displacement of first image936 sum_square=sum(sum(squeeze(image1_crop(z ,:,:).*image1_crop(z,:,:))));949 subimage2_crop=squeeze(image2_crop(zmax,y:y+2*iby2/mesh,x:x+2*ibx2/mesh));%subimage of image 2 corresponding to the optimum displacement of first image 950 sum_square=sum(sum(squeeze(image1_crop(zmax,:,:).*image1_crop(zmax,:,:)))); 937 951 sum_square=sum_square*sum(sum(subimage2_crop.*subimage2_crop));% product of variances of image 1 and 2 938 952 sum_square=sqrt(sum_square);% srt of the variance product to normalise correlation … … 940 954 941 955 if par_civ.CorrSmooth==1 942 [vector,FF(ivec_y,ivec_x)] = SUBPIXGAUSS ( result_conv(z,:,:),x,y);%TODO: improve by max optimisation along z956 [vector,FF(ivec_y,ivec_x)] = SUBPIXGAUSS (squeeze(result_conv(zmax,:,:)),x,y);%TODO: improve by max optimisation along z 943 957 elseif par_civ.CorrSmooth==2 944 [vector,FF(ivec_y,ivec_x)] = SUBPIX2DGAUSS ( result_conv(z,:,:),x,y);958 [vector,FF(ivec_y,ivec_x)] = SUBPIX2DGAUSS (squeeze(result_conv(zmax,:,:)),x,y); 945 959 else 946 [vector,FF(ivec_y,ivec_x)] = quadr_fit( result_conv(z,:,:),x,y);960 [vector,FF(ivec_y,ivec_x)] = quadr_fit(squeeze(result_conv(zmax,:,:)),x,y); 947 961 end 948 962 utable(ivec_y,ivec_x)=vector(1)*mesh+shiftx(ivec_y,ivec_x); … … 952 966 iref=round(xtable(ivec_y,ivec_x)+0.5);% nearest image index for the middle of the vector 953 967 jref=round(ytable(ivec_y,ivec_x)+0.5); 954 wtable(ivec_y,ivec_x)=z -kref;968 wtable(ivec_y,ivec_x)=zmax-kref; 955 969 % eliminate vectors located in the mask 956 970 if checkmask && (iref<1 || jref<1 ||iref>npx_ima || jref>npy_ima ||( par_civ.Mask(jref,iref)<200 && par_civ.Mask(jref,iref)>=100)) … … 962 976 963 977 else 964 FF(ivec_y,ivec_x)= 1;978 FF(ivec_y,ivec_x)=true; 965 979 end 966 980 end … … 975 989 % OUPUT: 976 990 % vector = optimum displacement vector with subpixel correction 977 % F =flag: =0 OK 978 % =-2 , warning: max too close to the edge of the search box (1 pixel margin) 991 % FF =flag: ='true' max too close to the edge of the search box (1 pixel margin) 979 992 % INPUT: 980 993 % x,y: position of the maximum correlation at integer values 981 994 982 function [vector,F ] = SUBPIXGAUSS (result_conv,x,y)995 function [vector,FF] = SUBPIXGAUSS (result_conv,x,y) 983 996 %------------------------------------------------------------------------ 984 % vector=[0 0]; %default 985 F=0; 997 vector=[0 0]; %default 986 998 [npy,npx]=size(result_conv); 987 999 result_conv(result_conv<1)=1; %set to 1 correlation values smaller than 1 (=0 by discretisation, to avoid divergence in the log) 988 1000 %the following 8 lines are copyright (c) 1998, Uri Shavit, Roi Gurka, Alex Liberzon, Technion ??? Israel Institute of Technology 989 1001 %http://urapiv.wordpress.com 990 peaky = y; 991 if y < npy && y > 1 992 f0 = log(result_conv(y,x)); 993 f1 = log(result_conv(y-1,x)); 994 f2 = log(result_conv(y+1,x)); 995 peaky = peaky+ (f1-f2)/(2*f1-4*f0+2*f2); 996 else 997 F=1; % warning flag for vector truncated by the limited search box 998 end 999 peakx=x; 1000 if x < npx-1 && x > 1 1001 f0 = log(result_conv(y,x)); 1002 f1 = log(result_conv(y,x-1)); 1003 f2 = log(result_conv(y,x+1)); 1004 peakx = peakx+ (f1-f2)/(2*f1-4*f0+2*f2); 1005 else 1006 F=1; % warning flag for vector truncated by the limited search box 1007 end 1008 vector=[peakx-floor(npx/2)-1 peaky-floor(npy/2)-1]; 1002 FF=false; 1003 peaky = y; 1004 if y < npy && y > 1 1005 f0 = log(result_conv(y,x)); 1006 f1 = log(result_conv(y-1,x)); 1007 f2 = log(result_conv(y+1,x)); 1008 peaky = peaky+ (f1-f2)/(2*f1-4*f0+2*f2); 1009 else 1010 FF=true; % error flag for vector truncated by the limited search box in y 1011 end 1012 peakx=x; 1013 if x < npx-1 && x > 1 1014 f0 = log(result_conv(y,x)); 1015 f1 = log(result_conv(y,x-1)); 1016 f2 = log(result_conv(y,x+1)); 1017 peakx = peakx+ (f1-f2)/(2*f1-4*f0+2*f2); 1018 else 1019 FF=true; % warning flag for vector truncated by the limited search box in x 1020 end 1021 vector=[peakx-floor(npx/2)-1 peaky-floor(npy/2)-1]; 1009 1022 1010 1023 %------------------------------------------------------------------------ -
trunk/src/series/civ_series.m
r1156 r1157 301 301 end 302 302 if CheckInputFile 303 OutputPath=fullfile(Param.OutputPath, num2str(Param.Experiment),num2str(Param.Device));303 OutputPath=fullfile(Param.OutputPath,Param.Experiment,Param.Device); 304 304 if iview_A==0 % no nc file has been entered 305 305 ncfile=fullfile_uvmat(OutputPath,Param.InputTable{1,2},Param.InputTable{1,3},Param.InputTable{1,5},... -
trunk/src/series/sliding_average.m
r1127 r1157 1 %'sliding_average _natalya'1 %'sliding_average': calculate the time correlation function at each point 2 2 %------------------------------------------------------------------------ 3 % function ParamOut= sliding_average(Param)3 % function ParamOut=turb_correlation_time(Param) 4 4 % 5 5 %%%%%%%%%%% GENERAL TO ALL SERIES ACTION FCTS %%%%%%%%%%%%%%%%%%%%%%%%%%% … … 39 39 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% 40 40 %======================================================================= 41 % Copyright 2008-202 4, LEGI UMR 5519 / CNRS UGA G-INP, Grenoble, France41 % Copyright 2008-2022, LEGI UMR 5519 / CNRS UGA G-INP, Grenoble, France 42 42 % http://www.legi.grenoble-inp.fr 43 % Joel.Sommeria - Joel.Sommeria (A) univ-grenoble-alpes.fr43 % Joel.Sommeria - Joel.Sommeria (A) legi.cnrs.fr 44 44 % 45 45 % This file is part of the toolbox UVMAT. … … 65 65 ParamOut.VelType='off';% menu for selecting the velocity type (options 'off'/'one'/'two', 'off' by default) 66 66 ParamOut.FieldName='one';% menu for selecting the field (s) in the input file(options 'off'/'one'/'two', 'off' by default) 67 ParamOut.FieldTransform = 'o n';%can use a transform function67 ParamOut.FieldTransform = 'off';%can use a transform function 68 68 ParamOut.ProjObject='off';%can use projection object39(option 'off'/'on', 69 69 ParamOut.Mask='off';%can use mask option (option 'off'/'on', 'off' by default) 70 70 ParamOut.OutputDirExt='.tfilter';%set the output dir extension 71 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 72 % filecell=get_file_series(Param);%check existence of the first input file 73 % if ~exist(filecell{1,1},'file') 74 % msgbox_uvmat('WARNING','the first input file does not exist') 75 % end 71 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 72 73 %% check the first input file in the series 74 first_j=[];% 75 if isfield(Param.IndexRange,'first_j'); first_j=Param.IndexRange.first_j; end 76 PairString=''; 77 if isfield(Param.IndexRange,'PairString'); PairString=Param.IndexRange.PairString; end 78 [i1,i2,j1,j2] = get_file_index(Param.IndexRange.first_i,first_j,PairString); 79 FirstFileName=fullfile_uvmat(Param.InputTable{1,1},Param.InputTable{1,2},Param.InputTable{1,3},... 80 Param.InputTable{1,5},Param.InputTable{1,4},i1,i2,j1,j2); 81 if exist(FirstFileName,'file') 82 FileInfo=get_file_info(FirstFileName); 83 if ~(isfield(FileInfo,'FileType')&& strcmp(FileInfo.FileType,'netcdf')) 84 msgbox_uvmat('ERROR','this fct works only on netcdf files (fields projected on a grid, notraw civ data)') 85 return 86 end 87 else 88 msgbox_uvmat('ERROR',['the input file ' FirstFileName ' does not exist']) 89 return 90 end 91 92 %% setting of intput parameters 93 % answer = msgbox_uvmat('INPUT_MENU','select the variables to filter',ListVarName'); 94 % ParamOut.ListVarName=ListVarName(answer); 95 answer = msgbox_uvmat('INPUT_TXT','set the filering window length','3'); 96 ParamOut.WindowLength=str2double(answer); 97 98 % [ParamOut.ActionInput,errormsg] = set_param_input(ListParam,DefaultValue,ParamIn); 99 % if ~isempty(errormsg) 100 % msgbox_uvmat('ERROR',errormsg) 101 % end 102 % [ParamOut,errormsg] = set_param_input(ListParam,DefaultValue,ParamIn); 76 103 return 77 104 end … … 184 211 nbmissing=0; 185 212 186 %% initialisation manip Coriolis 187 char_index=regexp(SubDir{1},'waves_L1_'); 188 switch(SubDir{1}(char_index+9)) 189 case '1' 190 amplitude=2.5 %oscillation amplitude 191 T=24.46; 192 t0=3 ;% dt=0.5 s, torus at its max x at the beginning of motion, i0=7 193 case '2' 194 amplitude=5 %oscillation amplitude 195 T=24.47; 196 t0=8.5; % dt=1/3 s -> image index of starting motion = 26, % torus at its max x at the beginning of motion 197 case '3' 198 amplitude=10 %oscillation amplitude 199 T=24.45; 200 t0=6.5-T/2;% dt=0.25, torus at its minimum x at the beginning of motion 201 case '4' 202 amplitude=15 %oscillation amplitude 203 T=24.48; 204 t0=3.4; %dt=0.2 -> i0=18 image index of starting motion, % torus at its max x at the beginning of motion 205 end 206 %NbPeriod=2; %number of periods for the sliding average 207 NbPeriod=4; %number of periods for the sliding average 208 omega=2*2*pi/T;%harmonic 209 Lscale=15;%diameter of the torus, length scale for normalisation 210 Uscale=amplitude*omega; 211 212 DataOut.ListGlobalAttribute= {'Conventions','Time'}; 213 %% initialisation output data 214 215 DataOut.ListGlobalAttribute= {'Conventions'}; 213 216 DataOut.Conventions='uvmat'; 214 DataOut.ListVarName={'coord_y','coord_x','Umean','Vmean','Ucos','Vcos','Usin','Vsin','DUDXsin','DUDXcos','DUDYsin','DVDXsin','DVDXcos'... 215 ,'DVDYsin','Ustokes','Vstokes'}; 216 DataOut.VarDimName={'coord_y','coord_x',{'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'},... 217 {'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'},... 218 {'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'},{'coord_y','coord_x'}}; 217 DataOut.ListVarName={'Time','coord_y','coord_x','Ufilter','Vfilter'}; 218 DataOut.VarDimName={'Time','coord_y','coord_x',{'Time','coord_y','coord_x'},{'Time','coord_y','coord_x'}}; 219 219 220 220 %%%%%%%%%%%%%%%% loop on field indices %%%%%%%%%%%%%%%% … … 226 226 return 227 227 end 228 [Data,tild,errormsg]=nc2struct(filecell{1, end});229 Time_ end=Data.Time;230 dt=(Time_ end-Time_1)/(NbField-1); %time interval231 NpTime= round(NbPeriod*T/dt+1);228 [Data,tild,errormsg]=nc2struct(filecell{1,2}); 229 Time_2=Data.Time; 230 dt=(Time_2-Time_1); %time interval 231 NpTime=21; %Nbre de champ pour la moyenne glissante (choisir impair) 232 232 233 233 OutputPath=fullfile(Param.OutputPath,num2str(Param.Experiment),num2str(Param.Device)); … … 246 246 %%%%%%%%%%% MAIN RUNNING OPERATIONS %%%%%%%%%%%% 247 247 if index==1 %first field 248 DataOut.coord_x=Field.coord_x /Lscale;249 DataOut.coord_y=Field.coord_y /Lscale;248 DataOut.coord_x=Field.coord_x; 249 DataOut.coord_y=Field.coord_y; 250 250 npy=numel(DataOut.coord_y); 251 251 npx=numel(DataOut.coord_x); 252 Umean=zeros(NpTime,npy,npx); 253 Vmean=zeros(NpTime,npy,npx); 254 Ucos=zeros(NpTime,npy,npx); 255 Vcos=zeros(NpTime,npy,npx); 256 Usin=zeros(NpTime,npy,npx); 257 Vsin=zeros(NpTime,npy,npx); 258 DUDXcos=zeros(NpTime,npy,npx); 259 DUDXsin=zeros(NpTime,npy,npx); 260 DUDYsin=zeros(NpTime,npy,npx); 261 DVDXcos=zeros(NpTime,npy,npx); 262 DVDXsin=zeros(NpTime,npy,npx); 263 DVDYsin=zeros(NpTime,npy,npx); 264 end 265 Time(index)=Field.Time-t0;%time from the start of the motion 266 Umean=circshift(Umean,[-1 0 0]); %shift U by ishift along the first index 267 Vmean=circshift(Vmean,[-1 0 0]); %shift U by ishift along the first index 268 Ucos=circshift(Ucos,[-1 0 0]); %shift U by ishift along the first index 269 Vcos=circshift(Vcos,[-1 0 0]); %shift U by ishift along the first index 270 Usin=circshift(Usin,[-1 0 0]); %shift U by ishift along the first index 271 Vsin=circshift(Vsin,[-1 0 0]); %shift U by ishift along the first index 272 DUDXcos=circshift(DUDXcos,[-1 0 0]); 273 DUDXsin=circshift(DUDXsin,[-1 0 0]); 274 DUDYsin=circshift(DUDYsin,[-1 0 0]); 275 DVDXcos=circshift(DVDXcos,[-1 0 0]); 276 DVDXsin=circshift(DVDXsin,[-1 0 0]); 277 DVDYsin=circshift(DVDYsin,[-1 0 0]); 278 Umean(end,:,:)=Field.U; 279 Vmean(end,:,:)=Field.V; 280 Ucos(end,:,:)=Field.U*cos(omega*Time(index)); 281 Vcos(end,:,:)=Field.V*cos(omega*Time(index)); 282 Usin(end,:,:)=Field.U*sin(omega*Time(index)); 283 Vsin(end,:,:)=Field.V*sin(omega*Time(index)); 284 DUDXcos(end,:,:)=Field.DUDX*cos(omega*Time(index)); 285 DUDXsin(end,:,:)=Field.DUDX*sin(omega*Time(index)); 286 DUDYsin(end,:,:)=Field.DUDY*sin(omega*Time(index));% ParamOut=[];%default output 287 288 DVDXcos(end,:,:)=Field.DVDX*cos(omega*Time(index)); 289 DVDXsin(end,:,:)=Field.DVDX*sin(omega*Time(index)); 290 DVDYsin(end,:,:)=Field.DVDY*sin(omega*Time(index)); 291 DataOut.Time=(Time(index)-(NpTime-1)*dt/2)/T;%time inperiods from the beginning of the oscillation (torus at max abscissa) 292 DataOut.Umean=(1/Uscale)*squeeze(nanmean(Umean,1)); 293 DataOut.Vmean=(1/Uscale)*squeeze(nanmean(Vmean,1)); 294 DataOut.Ucos=2*(1/Uscale)*squeeze(nanmean(Ucos,1)); 295 DataOut.Vcos=2*(1/Uscale)*squeeze(nanmean(Vcos,1)); 296 DataOut.Usin=2*(1/Uscale)*squeeze(nanmean(Usin,1)); 297 DataOut.Vsin=2*(1/Uscale)*squeeze(nanmean(Vsin,1)); 298 DataOut.DUDXcos=2*squeeze(nanmean(DUDXcos,1)); 299 DataOut.DUDXsin=2*squeeze(nanmean(DUDXsin,1)); 300 DataOut.DUDYsin=2*squeeze(nanmean(DUDYsin,1)); 301 DataOut.DVDXcos=2*squeeze(nanmean(DVDXcos,1)); 302 DataOut.DVDXsin=2*squeeze(nanmean(DVDXsin,1)); 303 DataOut.DVDYsin=2*squeeze(nanmean(DVDYsin,1)); 304 DataOut.Ustokes=(1/omega)*(1/Uscale)*(DataOut.Ucos.*DataOut.DUDXsin+DataOut.Vcos.*DataOut.DUDYsin); 305 DataOut.Vstokes=(1/omega)*(1/Uscale)*(DataOut.Ucos.*DataOut.DVDXsin+DataOut.Vcos.*DataOut.DVDYsin); 252 Ufilter=zeros(NpTime,npy,npx); 253 Vfilter=zeros(NpTime,npy,npx); 254 end 255 Time(index)=Field.Time;%time 256 Ufilter=circshift(Ufilter,[-1 0 0]); %shift U by ishift along the first index 257 Vfilter=circshift(Vfilter,[-1 0 0]); %shift U by ishift along the first index 258 Ufilter(end,:,:)=Field.U; 259 Vfilter(end,:,:)=Field.V; 260 DataOut.Time=(Time(index)-(NpTime-1)*dt/2);%mid time 261 DataOut.Ufilter=squeeze(nanmean(Ufilter,1)); 262 DataOut.Vfilter=squeeze(nanmean(Vfilter,1)); 263 306 264 307 265 % writing the result file as netcdf file 308 i1=i1_series{1}(index) ;266 i1=i1_series{1}(index)-ceil(NpTime/2); 309 267 OutputFile=fullfile_uvmat(OutputPath,OutputDir,RootFileOut,'.nc',NomTypeOut,i1); 310 268 errormsg=struct2nc(OutputFile, DataOut); -
trunk/src/series/test_filter_tps.m
r1156 r1157 72 72 % check the existence of the first file in the series 73 73 first_j=[];% note that the function will propose to cover the whole range of indices 74 if isfield(Param.IndexRange,'MinIndex_j'); first_j=Param.IndexRange.MinIndex_j; end 75 last_j=[]; 76 if isfield(Param.IndexRange,'MaxIndex_j'); last_j=Param.IndexRange.MaxIndex_j; end 74 if isfield(Param.IndexRange,'first_j'); first_j=Param.IndexRange.first_j; end 77 75 PairString=''; 78 76 if isfield(Param.IndexRange,'PairString'); PairString=Param.IndexRange.PairString; end … … 81 79 Param.InputTable{1,5},Param.InputTable{1,4},i1,i2,j1,j2); 82 80 if ~exist(FirstFileName,'file') 83 msgbox_uvmat(' WARNING',['the firstinput file ' FirstFileName ' does not exist'])81 msgbox_uvmat('ERROR',['the input file ' FirstFileName ' does not exist']) 84 82 return 85 else86 [i1,i2,j1,j2] = get_file_index(Param.IndexRange.last_i,last_j,PairString);87 LastFileName=fullfile_uvmat(Param.InputTable{1,1},Param.InputTable{1,2},Param.InputTable{1,3},...88 Param.InputTable{1,5},Param.InputTable{1,4},i1,i2,j1,j2);89 if ~exist(FirstFileName,'file')90 msgbox_uvmat('WARNING',['the last input file ' LastFileName ' does not exist'])91 end92 83 end 93 84 … … 114 105 end 115 106 else 116 msgbox_uvmat('ERROR', ['invalid file type input: ' FileType ' not a civ data'])107 msgbox_uvmat('ERROR','invalid file type input: test_filter_tps proceeds raw civ data') 117 108 return 118 109 end -
trunk/src/set_param_input.m
r1145 r1157 9 9 10 10 function [ParamOut,errormsg] = set_param_input(ListParam,DefaultValue,ParamIn,Comment) 11 ParamOut=[]; 11 12 errormsg=[]; 12 13 NbParam=numel(ListParam); … … 32 33 end 33 34 dlg_title = 'get the input parameters'; 34 answer = inputdlg(ListParam,dlg_title,NbParam,prompt); 35 options.Resize='on'; 36 answer = inputdlg(ListParam,dlg_title,NbParam,prompt,options); 37 %answer = msgbox_uvmat('INPUT_TXT',ListParam); 35 38 if isempty(answer) 36 39 return -
trunk/src/struct2nc.m
r1127 r1157 38 38 function [errormsg,nc]=struct2nc(flname,Data,action,ListDimName,DimValue,VarDimIndex) 39 39 nc=[]; 40 errormsg=''; 40 41 if ~ischar(flname) 41 42 errormsg='invalid input for the netcf file name'; … … 81 82 end 82 83 if ~testvar 83 eval(['cte=Data.' keys{iattr} ';'])84 cte=Data.(keys{iattr}); 84 85 if (ischar(cte) ||isnumeric(cte)) && ~isempty(cte)%&& ~isequal(cte,'') 85 86 %write constant only if it is numeric or char string, and not empty … … 106 107 %% create the variables 107 108 varid=nan(1,length(Data.ListVarName)); 109 VarClass=cell(1,length(ListVarName)); 108 110 for ivar=1:length(ListVarName) 109 111 if isfield(Data,ListVarName{ivar}) … … 141 143 netcdf.endDef(nc); %put in data mode 142 144 143 %% fill the variables with input data 145 %% fill the variables with input data except in mode 'keep_open' (variables will be filled later) 144 146 if ~(exist('action','var') && strcmp(action,'keep_open')) 145 147 for ivar=1:length(ListVarName) … … 169 171 end 170 172 end 173 if ~ (exist('action','var') && strcmp(action,'keep_open')) 171 174 netcdf.close(nc) 172 175 [success,errormsg] = fileattrib(flname ,'+w');% allow writing access for the group of users 176 end 173 177 %'check_field_structure': check the validity of the field struture representation consistant with the netcdf format 174 178 %------------------------------------------------------------------------
Note: See TracChangeset
for help on using the changeset viewer.