Changeset 764 for trunk/src/series.m
- Timestamp:
- May 2, 2014, 2:03:44 AM (10 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/series.m
r760 r764 582 582 errormsg=['input file ' fileinput ' does not exist']; 583 583 msgbox_uvmat('ERROR',errormsg) 584 set(handles.REFRESH,'BackgroundColor',[1 0 0])% set REFRESH button to red color (end of activation)584 set(handles.REFRESH,'BackgroundColor',[1 0 1])% set REFRESH button to magenta color (refresh still needed) 585 585 return 586 586 end … … 594 594 errormsg='no input file in the series'; 595 595 msgbox_uvmat('ERROR',errormsg) 596 set(handles.REFRESH,'BackgroundColor',[1 0 0])% set REFRESH button to redcolor (end of activation)596 set(handles.REFRESH,'BackgroundColor',[1 0 1])% set REFRESH button to magenta color (end of activation) 597 597 return 598 598 end 599 599 if strcmp(FileType,'txt') 600 600 edit(fileinput) 601 set(handles.REFRESH,'BackgroundColor',[1 0 0])% set REFRESH button to redcolor (end of activation)601 set(handles.REFRESH,'BackgroundColor',[1 0 1])% set REFRESH button to magenta color (end of activation) 602 602 return 603 603 elseif strcmp(FileType,'xml') 604 604 editxml(fileinput) 605 set(handles.REFRESH,'BackgroundColor',[1 0 0])% set REFRESH button to redcolor (end of activation)605 set(handles.REFRESH,'BackgroundColor',[1 0 1])% set REFRESH button to magenta color (end of activation) 606 606 return 607 607 elseif strcmp(FileType,'figure') 608 608 open(fileinput) 609 set(handles.REFRESH,'BackgroundColor',[1 0 0])% set REFRESH button to redcolor (end of activation)609 set(handles.REFRESH,'BackgroundColor',[1 0 1])% set REFRESH button to magenta color (end of activation) 610 610 return 611 611 end … … 624 624 625 625 626 627 626 %% fill the list of file series 628 627 InputTable=get(handles.InputTable,'Data'); … … 630 629 if strcmp(iview,'append') % display the input data as a new line in the table 631 630 iview=size(InputTable,1)+1;% the next line in InputTable becomes the current line 632 %InputTable(iview+1,:)={'','','','',''};633 631 InputTable(iview,:)=[{RootPath},{SubDir},{RootFile},{NomType},{FileExt}]; 634 632 elseif strcmp(iview,'one') % refresh the list of input file series 635 633 iview=1; %the first line in InputTable becomes the current line 636 634 InputTable={'','','','',''}; 637 %InputTable=[{'','','','',''};{'','','','',''}];638 635 InputTable(iview,:)=[{RootPath},{SubDir},{RootFile},{NomType},{FileExt}]; 639 636 set(handles.TimeTable,'Data',[{[]},{[]},{[]},{[]}]) … … 653 650 SeriesData.Time={}; 654 651 end 655 %nbview=size(InputTable,1)-1;% rmq: the last line is set blank to allow manual addition of a line656 652 nbview=size(InputTable,1); 657 653 set(handles.ListView,'String',mat2cell((1:nbview)',ones(nbview,1))) 658 654 set(handles.ListView,'Value',iview) 655 SeriesData.ListViewValue=iview; 656 SeriesData.ListViewMenu=mat2cell((1:nbview)',ones(nbview,1)); 659 657 set(handles.InputTable,'Data',InputTable) 660 658 … … 668 666 ref_i=floor((i1+i2)/2);% reference image number corresponding to the file 669 667 set(handles.num_ref_i,'String',num2str(ref_i)); 670 % set(handles.num_ref_i,'UserData',[i1 i2])%store the indices for future opening671 668 if isempty(j1) 672 669 j1=1; … … 981 978 MaxIndex_i=max(MaxIndex_i); 982 979 range_index=MaxIndex_i-MinIndex_i+1; 983 % scale_y=Position(4)/nbview;984 % scale_x=Position(3)/range_index;985 %x=(0.5:range_index-0.5)*Position(3)/range_index;% set of abscissa representing the whole i index range986 % y=(0.5:nbview-0.5)*Position(4)/nbview;987 980 range_y=max(1,floor(Position(4)/nbview)); 988 981 npx=floor(Position(3)); … … 1010 1003 set(handles.Pairs,'Visible','on') 1011 1004 set(handles.PairString,'Visible','on') 1005 set(handles.SetPairs,'Visible','on') 1012 1006 else 1013 1007 set(handles.Pairs,'Visible','off') 1014 1008 set(handles.PairString,'Visible','off') 1009 set(handles.SetPairs,'Visible','off') 1015 1010 end 1016 1011 … … 1025 1020 switch FileType 1026 1021 case {'civx','civdata'} 1027 [FieldList,ColorList]=set_field_list('U','V','C');1028 set(handles.FieldName,'String',[ {'image'};FieldList;{'get_field...'}]);%standard menu for civx data1029 set(handles.FieldName,'Value', 2) % set menu to 'velocity1022 FieldList=set_field_list('U','V','C'); 1023 set(handles.FieldName,'String',[FieldList;{'get_field...'}]);%standard menu for civx data 1024 set(handles.FieldName,'Value',1) % set menu to 'velocity 1030 1025 set(handles.Coord_x,'Value',1); 1031 1026 set(handles.Coord_x,'String',{'X'}); … … 1233 1228 % check_burst=0; 1234 1229 if isempty(j2_series)% no j pair 1230 ModeValue=1; 1235 1231 if isempty(i2_series) 1236 set(handles.mode,'Value',1)1237 1232 set(handles.mode,'String',{''})% no pair menu to display 1238 1233 else 1239 1234 set(handles.mode,'Value',1) 1240 set(handles.mode,'String',{'series(Di)'})% pair menu with only option Di1235 ModeMenu={'series(Di)'}; % pair menu with only option Di 1241 1236 end 1242 1237 else %existence of j pairs … … 1249 1244 MinIndex_j=min(find(i_max))-1;% min ref index i 1250 1245 if MaxIndex_j==MinIndex_j 1251 set(handles.mode,'Value',1); 1252 set(handles.mode,'String',{'bursts'}) 1253 % check_burst=1; 1246 ModeValue=1; 1247 ModeMenu={'bursts'}; 1254 1248 elseif MaxIndex_i==MinIndex_i 1255 set(handles.mode,'Value',1);1256 set(handles.mode,'String',{'series(Dj)'})1249 ModeValue=1; 1250 ModeMenu={'series(Dj)'}; 1257 1251 else 1258 set(handles.mode,'String',{'bursts';'series(Dj)'})1252 ModeMenu={'bursts';'series(Dj)'}; 1259 1253 if (MaxIndex_j-MinIndex_j)>10 1260 set(handles.mode,'Value',2);%set mode to series(Dj) if more than 10 j values1254 ModeValue=2;%set mode to series(Dj) if more than 10 j values 1261 1255 else 1262 set(handles.mode,'Value',1); 1263 % check_burst=1; 1264 end 1265 end 1266 end 1256 ModeValue=1; 1257 end 1258 end 1259 end 1260 1261 set(handles.mode,'String',ModeMenu) 1262 set(handles.mode,'Value',ModeValue) 1263 SeriesData=get(handles.series,'UserData'); 1264 SeriesData.ModeMenu=ModeMenu; 1265 SeriesData.ModeValue=ModeValue; 1266 set(handles.series,'UserData',SeriesData) 1267 1267 fill_ListPair(handles,i1_series,i2_series,j1_series,j2_series,time) 1268 1268 ListPairs_Callback([],[],handles) … … 1369 1369 1370 1370 %% display list of pairstring 1371 SeriesData=get(handles.series,'UserData'); 1371 1372 displ_pair_list=get(handles.ListPairs,'String'); 1372 1373 NewVal=[]; … … 1377 1378 if ~isempty(NewVal) 1378 1379 set(handles.ListPairs,'Value',NewVal) 1380 SeriesData.ListPairsValue=NewVal; 1379 1381 else 1380 1382 set(handles.ListPairs,'Value',1) 1383 SeriesData.ListPairsValue=1; 1381 1384 end 1382 1385 set(handles.ListPairs,'String',displ_pair) 1386 SeriesData.ListPairsMenu=displ_pair; 1387 set(handles.series,'UserData',SeriesData); 1383 1388 1384 1389 %------------------------------------- … … 1422 1427 Param=read_GUI_series(handles);%displayed parameters 1423 1428 SeriesData=get(handles.series,'UserData');%hidden parameters 1429 1430 1431 1432 %% select the Action mode, 'local', 'background' or 'cluster' (if available) 1433 RunMode='local';%default (needed for first opening of the GUI series) 1434 if isfield(Param.Action,'RunMode') 1435 RunMode=Param.Action.RunMode; 1436 end 1437 ActionExt='.m';%default 1438 if isfield(Param.Action,'ActionExt') 1439 ActionExt=Param.Action.ActionExt;% '.m' or '.sh' (compiled) 1440 end 1441 ActionName=Param.Action.ActionName; 1442 ActionPath=Param.Action.ActionPath; 1443 path_series=fileparts(which('series')); 1444 1445 %% create the Action fct handle if RunMode option = 'local' 1446 if strcmp(RunMode,'local') 1447 if ~isequal(ActionPath,path_series) 1448 eval(['spath=which(''' ActionName ''');']) %spath = current path of the selected function ACTION 1449 if ~exist(ActionPath,'dir') 1450 msgbox_uvmat('ERROR',['The prescribed function path ' ActionPath ' does not exist']); 1451 return 1452 end 1453 if ~isequal(spath,ActionPath) 1454 addpath(ActionPath)% add the prescribed path if not the current one 1455 end 1456 end 1457 eval(['h_fun=@' ActionName ';'])%create a function handle for ACTION 1458 if ~isequal(ActionPath,path_series) 1459 rmpath(ActionPath)% add the prescribed path if not the current one 1460 end 1461 end 1462 1463 %% Get RunTime code from the file PARAM.xml (needed to run compiled functions) 1464 errormsg='';%default error message 1465 xmlfile=fullfile(path_series,'PARAM.xml'); 1466 test_batch=0;%default: ,no batch mode available 1467 if ~exist(xmlfile,'file') 1468 [success,message]=copyfile(fullfile(path_series,'PARAM.xml.default'),xmlfile); 1469 end 1470 RunTime=''; 1471 if strcmp(ActionExt,'.sh') 1472 if exist(xmlfile,'file') 1473 s=xml2struct(xmlfile); 1474 if strcmp(RunMode,'cluster_oar') && isfield(s,'BatchParam') 1475 if isfield(s.BatchParam,'RunTime') 1476 RunTime=s.BatchParam.RunTime; 1477 end 1478 if isfield(s.BatchParam,'NbCore') 1479 NbCore=s.BatchParam.NbCore; 1480 end 1481 elseif (strcmp(RunMode,'background')||strcmp(RunMode,'local')) && isfield(s,'RunParam') 1482 if isfield(s.RunParam,'RunTime') 1483 RunTime=s.RunParam.RunTime; 1484 end 1485 if isfield(s.RunParam,'NbCore') 1486 NbCore=s.RunParam.NbCore; 1487 end 1488 end 1489 end 1490 if isempty(RunTime) && strcmp(RunMode,'cluster_oar') 1491 msgbox_uvmat('ERROR','RunTime name not found in PARAM.xml, compiled version .sh cannot run on cluster') 1492 return 1493 end 1494 end 1495 1496 %% If a compiled version has been selected (ext .sh) check weather it needs to be recompiled 1497 % ActionExtList=get(handles.ActionExt,'String'); 1498 % ActionExt=ActionExtList{get(handles.ActionExt,'Value')}; 1499 % ActionList=get(handles.ActionName,'String'); 1500 % ActionName=ActionList{get(handles.ActionName,'Value')}; 1501 % TransformPath=''; 1502 % if ~isempty(get(handles.ActionExt,'UserData')) 1503 % TransformPath=get(handles.ActionExt,'UserData'); 1504 % end 1505 if strcmp(ActionExt,'.sh') 1506 TransformPath=''; 1507 if ~isempty(get(handles.ActionExt,'UserData')) 1508 TransformPath=get(handles.ActionExt,'UserData'); 1509 end 1510 set(handles.series,'Pointer','watch') % set the mouse pointer to 'watch' 1511 set(handles.ActionExt,'BackgroundColor',[1 1 0]) 1512 ActionFullName=fullfile(get(handles.ActionPath,'String'),[ActionName '.sh']); 1513 if ~exist(ActionFullName,'file') 1514 answer=msgbox_uvmat('INPUT_Y-N','compiled version has not been created: compile now?'); 1515 if strcmp(answer,'Yes') 1516 set(handles.ActionExt,'BackgroundColor',[1 1 0]) 1517 path_uvmat=fileparts(which('series')); 1518 currentdir=pwd; 1519 cd(get(handles.ActionPath,'String'))% go to the directory of Action 1520 % addpath(get(handles.TransformPath,'String')) 1521 addpath(path_uvmat)% add the path to uvmat to run the fct 'compile' 1522 % addpath(fullfile(path_uvmat,'transform_field'))% add the path to uvmat to run the fct 'compile' 1523 compile(ActionName,TransformPath) 1524 cd(currentdir) 1525 end 1526 else 1527 sh_file_info=dir(fullfile(get(handles.ActionPath,'String'),[ActionName '.sh'])); 1528 m_file_info=dir(fullfile(get(handles.ActionPath,'String'),[ActionName '.m'])); 1529 if isfield(m_file_info,'datenum') && m_file_info.datenum>sh_file_info.datenum 1530 set(handles.ActionExt,'BackgroundColor',[1 1 0]) 1531 drawnow 1532 answer=msgbox_uvmat('INPUT_Y-N',[ActionName '.sh needs to be updated: recompile now?']); 1533 if strcmp(answer,'Yes') 1534 path_uvmat=fileparts(which('series')); 1535 currentdir=pwd; 1536 cd(get(handles.ActionPath,'String'))% go to the directory of Action 1537 % addpath(get(handles.TransformPath,'String')) 1538 addpath(path_uvmat)% add the path to uvmat to run the fct 'compile' 1539 addpath(fullfile(path_uvmat,'transform_field'))% add the path to uvmat to run the fct 'compile' 1540 compile(ActionName,TransformPath) 1541 cd(currentdir) 1542 end 1543 end 1544 end 1545 set(handles.ActionExt,'BackgroundColor',[1 1 1]) 1546 set(handles.series,'Pointer','arrow') % set the mouse pointer to 'watch 1547 end 1548 1549 %% set nbre of cluster cores and processes 1550 switch RunMode 1551 case {'local','background'} 1552 NbCore=1;% no need to split the calculation 1553 case 'cluster_oar' 1554 if strcmp(Param.Action.ActionExt,'.m')% case of Matlab function (uncompiled) 1555 NbCore=1;% one core used only (limitation of Matlab licences) 1556 msgbox_uvmat('WARNING','Number of cores =1: select the compiled version civ_matlab.sh for multi-core processing'); 1557 extra_oar=''; 1558 else 1559 answer=inputdlg({'Number of cores (max 36)','extra oar options'},'oarsub parameter',1,{'12',''}); 1560 NbCore=str2double(answer{1}); 1561 extra_oar=answer{2}; 1562 end 1563 end 1564 if ~isfield(Param.IndexRange,'NbSlice') 1565 Param.IndexRange.NbSlice=[]; 1566 end 1567 if isempty(Param.IndexRange.NbSlice) 1568 NbProcess=NbCore;% choose one process per core 1569 else 1570 NbProcess=Param.IndexRange.NbSlice;% the nbre of run processes is equal to the number of slices 1571 NbCore=min(NbCore,NbProcess);% at least one process per core 1572 end 1424 1573 1425 1574 %% create the output data directory if needed … … 1478 1627 end 1479 1628 end 1480 end1481 1482 %% select the Action mode, 'local', 'background' or 'cluster' (if available)1483 RunMode='local';%default (needed for first opening of the GUI series)1484 if isfield(Param.Action,'RunMode')1485 RunMode=Param.Action.RunMode;1486 end1487 ActionExt='.m';%default1488 if isfield(Param.Action,'ActionExt')1489 ActionExt=Param.Action.ActionExt;% '.m' or '.sh' (compiled)1490 end1491 ActionName=Param.Action.ActionName;1492 ActionPath=Param.Action.ActionPath;1493 path_series=fileparts(which('series'));1494 1495 %% create the Action fct handle if RunMode option = 'local'1496 if strcmp(RunMode,'local')1497 if ~isequal(ActionPath,path_series)1498 eval(['spath=which(''' ActionName ''');']) %spath = current path of the selected function ACTION1499 if ~exist(ActionPath,'dir')1500 msgbox_uvmat('ERROR',['The prescribed function path ' ActionPath ' does not exist']);1501 return1502 end1503 if ~isequal(spath,ActionPath)1504 addpath(ActionPath)% add the prescribed path if not the current one1505 end1506 end1507 eval(['h_fun=@' ActionName ';'])%create a function handle for ACTION1508 if ~isequal(ActionPath,path_series)1509 rmpath(ActionPath)% add the prescribed path if not the current one1510 end1511 end1512 1513 %% Get RunTime code from the file PARAM.xml (needed to run compiled functions)1514 errormsg='';%default error message1515 xmlfile=fullfile(path_series,'PARAM.xml');1516 test_batch=0;%default: ,no batch mode available1517 if ~exist(xmlfile,'file')1518 [success,message]=copyfile(fullfile(path_series,'PARAM.xml.default'),xmlfile);1519 end1520 RunTime='';1521 if strcmp(ActionExt,'.sh')1522 if exist(xmlfile,'file')1523 s=xml2struct(xmlfile);1524 if strcmp(RunMode,'cluster_oar') && isfield(s,'BatchParam')1525 if isfield(s.BatchParam,'RunTime')1526 RunTime=s.BatchParam.RunTime;1527 end1528 if isfield(s.BatchParam,'NbCore')1529 NbCore=s.BatchParam.NbCore;1530 end1531 elseif (strcmp(RunMode,'background')||strcmp(RunMode,'local')) && isfield(s,'RunParam')1532 if isfield(s.RunParam,'RunTime')1533 RunTime=s.RunParam.RunTime;1534 end1535 if isfield(s.RunParam,'NbCore')1536 NbCore=s.RunParam.NbCore;1537 end1538 end1539 end1540 if isempty(RunTime) && strcmp(RunMode,'cluster_oar')1541 msgbox_uvmat('ERROR','RunTime name not found in PARAM.xml, compiled version .sh cannot run on cluster')1542 return1543 end1544 end1545 1546 %% set nbre of cluster cores and processes1547 switch RunMode1548 case {'local','background'}1549 NbCore=1;% no need to split the calculation1550 case 'cluster_oar'1551 if strcmp(Param.Action.ActionExt,'.m')% case of Matlab function (uncompiled)1552 NbCore=1;% one core used only (limitation of Matlab licences)1553 msgbox_uvmat('WARNING','Number of cores =1: select the compiled version civ_matlab.sh for multi-core processing');1554 extra_oar='';1555 else1556 answer=inputdlg({'Number of cores (max 36)','extra oar options'},'oarsub parameter',1,{'12',''});1557 NbCore=str2double(answer{1});1558 extra_oar=answer{2};1559 end1560 end1561 if ~isfield(Param.IndexRange,'NbSlice')1562 Param.IndexRange.NbSlice=[];1563 end1564 if isempty(Param.IndexRange.NbSlice)1565 NbProcess=NbCore;% choose one process per core1566 else1567 NbProcess=Param.IndexRange.NbSlice;% the nbre of run processes is equal to the number of slices1568 NbCore=min(NbCore,NbProcess);% at least one process per core1569 1629 end 1570 1630 … … 2245 2305 Param=read_GUI(handles.series); 2246 2306 Param.InputTable=Param.InputTable(1,:); 2247 2307 % check the existence of the first file in the series 2248 2308 first_j=[]; 2249 2309 if isfield(Param.IndexRange,'first_j'); first_j=Param.IndexRange.first_j; end … … 2255 2315 FirstFileName=fullfile_uvmat(Param.InputTable{1,1},Param.InputTable{1,2},Param.InputTable{1,3},... 2256 2316 Param.InputTable{1,5},Param.InputTable{1,4},i1,i2,j1,j2); 2257 % filecell=get_file_series(Param);2258 %2259 2317 if exist(FirstFileName,'file') 2260 2318 ParamIn.SeriesInput=1; … … 2266 2324 VName=GetFieldData.PanelVectors.vector_y; 2267 2325 YName={GetFieldData.Coordinates.Coord_y}; 2268 CName=GetFieldData.PanelVectors.vec_color;2269 2326 FieldList={['vec(' UName ',' VName ')'];... 2270 2327 ['norm(' UName ',' VName ')'];... 2271 2328 UName;VName}; 2272 VecColorList={['norm(' UName ',' VName ')'];... 2273 UName;VName}; 2274 if ~isempty(CName) 2275 VecColorList=[{CName};VecColorList]; 2276 end 2277 case 'scalar' 2329 case {'scalar','pick variables'} 2278 2330 FieldList=GetFieldData.PanelScalar.scalar; 2279 2331 YName={GetFieldData.Coordinates.Coord_y}; 2280 2332 if ischar(FieldList) 2281 FieldList={FieldList};2333 FieldList={FieldList}; 2282 2334 end 2283 2335 case '1D plot' 2284 2336 YName=GetFieldData.PanelOrdinate.ordinate; 2285 % case 'civdata...'%reinitiate input, return to automatic civ data reading 2286 % display_file_name(handles,FileName,1) 2337 case 'civdata...' 2338 FieldList=set_field_list('U','V','C'); 2339 set(handles.FieldName,'Value',2) % set menu to 'velocity 2340 XName='X'; 2341 YName='y'; 2287 2342 end 2288 2343 if ~strcmp(GetFieldData.FieldOption,'civdata...') … … 2307 2362 ParamIn.TimeDimName=GetFieldData.Time.TimeName; 2308 2363 end 2309 set(handles.Coord_x,'String',{XName})2310 set(handles.Coord_y,'String',YName)2311 set(handles.FieldName,'Value',1)2312 set(handles.FieldName,'String',[FieldList; {'get_field...'}]);2313 end2364 end 2365 set(handles.Coord_x,'String',{XName}) 2366 set(handles.Coord_y,'String',YName) 2367 set(handles.FieldName,'Value',1) 2368 set(handles.FieldName,'String',[FieldList; {'get_field...'}]); 2314 2369 end 2315 2370 end … … 2321 2376 field_str=get(handles.FieldName_1,'String'); 2322 2377 field_index=get(handles.FieldName_1,'Value'); 2323 field=field_str{field_index}; 2324 if isequal(field,'get_field...') 2325 hget_field=findobj(allchild(0),'name','get_field_1'); 2326 if ~isempty(hget_field) 2327 delete(hget_field) 2328 end 2329 SeriesData=get(handles.series,'UserData'); 2330 filename=SeriesData.CurrentInputFile_1; 2331 if exist(filename,'file') 2332 hget_field=get_field(filename); 2333 set(hget_field,'name','get_field_1') 2334 end 2335 % elseif isequal(field,'more...') 2336 % str=calc_field; 2337 % [ind_answer,v] = listdlg('PromptString','Select a file:',... 2338 % 'SelectionMode','single',... 2339 % 'ListString',str); 2340 % % edit the choice in the fields and actionname menu 2341 % scalar=cell2mat(str(ind_answer)); 2342 % update_menu(handles.FieldName_1,scalar) 2378 field=field_str{field_index(1)}; 2379 if isequal(field,'get_field...') 2380 hget_field=findobj(allchild(0),'name','get_field'); 2381 if ~isempty(hget_field) 2382 delete(hget_field)%delete opened versions of get_field 2383 end 2384 Param=read_GUI(handles.series); 2385 Param.InputTable=Param.InputTable(1,:); 2386 % check the existence of the first file in the series 2387 first_j=[]; 2388 if isfield(Param.IndexRange,'first_j'); first_j=Param.IndexRange.first_j; end 2389 if isfield(Param.IndexRange,'last_j'); last_j=Param.IndexRange.last_j; end 2390 PairString=''; 2391 if isfield(Param.IndexRange,'PairString'); PairString=Param.IndexRange.PairString; end 2392 [i1,i2,j1,j2] = get_file_index(Param.IndexRange.first_i,first_j,PairString); 2393 FirstFileName=fullfile_uvmat(Param.InputTable{1,1},Param.InputTable{1,2},Param.InputTable{1,3},... 2394 Param.InputTable{1,5},Param.InputTable{1,4},i1,i2,j1,j2); 2395 if exist(FirstFileName,'file') 2396 ParamIn.SeriesInput=1; 2397 GetFieldData=get_field(FirstFileName,ParamIn); 2398 FieldList={}; 2399 switch GetFieldData.FieldOption 2400 case 'vectors' 2401 UName=GetFieldData.PanelVectors.vector_x; 2402 VName=GetFieldData.PanelVectors.vector_y; 2403 FieldList={['vec(' UName ',' VName ')'];... 2404 ['norm(' UName ',' VName ')'];... 2405 UName;VName}; 2406 case {'scalar','pick variables'} 2407 FieldList=GetFieldData.PanelScalar.scalar; 2408 if ischar(FieldList) 2409 FieldList={FieldList}; 2410 end 2411 case '1D plot' 2412 2413 case 'civdata...' 2414 FieldList=set_field_list('U','V','C'); 2415 set(handles.FieldName,'Value',2) % set menu to 'velocity 2416 end 2417 if ~strcmp(GetFieldData.FieldOption,'civdata...') 2418 TimeNameStr=GetFieldData.Time.SwitchVarIndexTime; 2419 switch TimeNameStr 2420 case 'file index' 2421 set(handles.TimeName,'String',''); 2422 case 'attribute' 2423 set(handles.TimeName,'String',['att:' GetFieldData.Time.TimeName]); 2424 case 'variable' 2425 set(handles.TimeName,'String',['var:' GetFieldData.Time.TimeName]) 2426 set(handles.NomType,'String','*') 2427 set(handles.RootFile,'String',[get(handles.RootFile,'String') get(handles.FileIndex,'String')])% A VERIFIER !!!!!! 2428 set(handles.FileIndex,'String','') 2429 ParamIn.TimeVarName=GetFieldData.Time.TimeName; 2430 case 'matrix_index' 2431 set(handles.TimeName,'String',['dim:' GetFieldData.Time.TimeName]); 2432 set(handles.NomType,'String','*') 2433 set(handles.RootFile,'String',[get(handles.RootFile,'String') get(handles.FileIndex,'String')]) 2434 set(handles.FileIndex,'String','') 2435 ParamIn.TimeDimName=GetFieldData.Time.TimeName; 2436 end 2437 end 2438 set(handles.FieldName_1,'Value',1) 2439 set(handles.FieldName_1,'String',[FieldList; {'get_field...'}]); 2440 end 2343 2441 end 2344 2442 … … 2927 3025 ActionList=get(handles.ActionName,'String'); 2928 3026 ActionName=ActionList{get(handles.ActionName,'Value')}; 2929 TransformPath=''; 2930 if ~isempty(get(handles.ActionExt,'UserData')) 2931 TransformPath=get(handles.ActionExt,'UserData'); 2932 end 2933 if strcmp(ActionExt,'.sh') 2934 set(handles.series,'Pointer','watch') % set the mouse pointer to 'watch' 2935 set(handles.ActionExt,'BackgroundColor',[1 1 0]) 2936 ActionFullName=fullfile(get(handles.ActionPath,'String'),[ActionName '.sh']); 2937 if ~exist(ActionFullName,'file') 2938 answer=msgbox_uvmat('INPUT_Y-N','compiled version has not been created: compile now?'); 2939 if strcmp(answer,'Yes') 2940 set(handles.ActionExt,'BackgroundColor',[1 1 0]) 2941 path_uvmat=fileparts(which('series')); 2942 currentdir=pwd; 2943 cd(get(handles.ActionPath,'String'))% go to the directory of Action 2944 % addpath(get(handles.TransformPath,'String')) 2945 addpath(path_uvmat)% add the path to uvmat to run the fct 'compile' 2946 % addpath(fullfile(path_uvmat,'transform_field'))% add the path to uvmat to run the fct 'compile' 2947 compile(ActionName,TransformPath) 2948 cd(currentdir) 2949 end 2950 else 2951 sh_file_info=dir(fullfile(get(handles.ActionPath,'String'),[ActionName '.sh'])); 2952 m_file_info=dir(fullfile(get(handles.ActionPath,'String'),[ActionName '.m'])); 2953 if isfield(m_file_info,'datenum') && m_file_info.datenum>sh_file_info.datenum 2954 set(handles.ActionExt,'BackgroundColor',[1 1 0]) 2955 drawnow 2956 answer=msgbox_uvmat('INPUT_Y-N',[ActionName '.sh needs to be updated: recompile now?']); 2957 if strcmp(answer,'Yes') 2958 path_uvmat=fileparts(which('series')); 2959 currentdir=pwd; 2960 cd(get(handles.ActionPath,'String'))% go to the directory of Action 2961 % addpath(get(handles.TransformPath,'String')) 2962 addpath(path_uvmat)% add the path to uvmat to run the fct 'compile' 2963 addpath(fullfile(path_uvmat,'transform_field'))% add the path to uvmat to run the fct 'compile' 2964 compile(ActionName,TransformPath) 2965 cd(currentdir) 2966 end 2967 end 2968 end 2969 set(handles.ActionExt,'BackgroundColor',[1 1 1]) 2970 set(handles.series,'Pointer','arrow') % set the mouse pointer to 'watch 2971 end 2972 2973 3027 % TransformPath=''; 3028 % if ~isempty(get(handles.ActionExt,'UserData')) 3029 % TransformPath=get(handles.ActionExt,'UserData'); 3030 % end 3031 % if strcmp(ActionExt,'.sh') 3032 % set(handles.series,'Pointer','watch') % set the mouse pointer to 'watch' 3033 % set(handles.ActionExt,'BackgroundColor',[1 1 0]) 3034 % ActionFullName=fullfile(get(handles.ActionPath,'String'),[ActionName '.sh']); 3035 % if ~exist(ActionFullName,'file') 3036 % answer=msgbox_uvmat('INPUT_Y-N','compiled version has not been created: compile now?'); 3037 % if strcmp(answer,'Yes') 3038 % set(handles.ActionExt,'BackgroundColor',[1 1 0]) 3039 % path_uvmat=fileparts(which('series')); 3040 % currentdir=pwd; 3041 % cd(get(handles.ActionPath,'String'))% go to the directory of Action 3042 % % addpath(get(handles.TransformPath,'String')) 3043 % addpath(path_uvmat)% add the path to uvmat to run the fct 'compile' 3044 % % addpath(fullfile(path_uvmat,'transform_field'))% add the path to uvmat to run the fct 'compile' 3045 % compile(ActionName,TransformPath) 3046 % cd(currentdir) 3047 % end 3048 % else 3049 % sh_file_info=dir(fullfile(get(handles.ActionPath,'String'),[ActionName '.sh'])); 3050 % m_file_info=dir(fullfile(get(handles.ActionPath,'String'),[ActionName '.m'])); 3051 % if isfield(m_file_info,'datenum') && m_file_info.datenum>sh_file_info.datenum 3052 % set(handles.ActionExt,'BackgroundColor',[1 1 0]) 3053 % drawnow 3054 % answer=msgbox_uvmat('INPUT_Y-N',[ActionName '.sh needs to be updated: recompile now?']); 3055 % if strcmp(answer,'Yes') 3056 % path_uvmat=fileparts(which('series')); 3057 % currentdir=pwd; 3058 % cd(get(handles.ActionPath,'String'))% go to the directory of Action 3059 % % addpath(get(handles.TransformPath,'String')) 3060 % addpath(path_uvmat)% add the path to uvmat to run the fct 'compile' 3061 % addpath(fullfile(path_uvmat,'transform_field'))% add the path to uvmat to run the fct 'compile' 3062 % compile(ActionName,TransformPath) 3063 % cd(currentdir) 3064 % end 3065 % end 3066 % end 3067 % set(handles.ActionExt,'BackgroundColor',[1 1 1]) 3068 % set(handles.series,'Pointer','arrow') % set the mouse pointer to 'watch 3069 % end 2974 3070 2975 3071 … … 3022 3118 function series_WindowButtonMotionFcn(hObject, eventdata, handles) 3023 3119 set(hObject,'Pointer','arrow'); 3120 3121 3122 % --- Executes on button press in SetPairs. 3123 function SetPairs_Callback(hObject, eventdata, handles) 3124 3125 %% create the GUI set_pairs 3126 set(0,'Unit','points') 3127 ScreenSize=get(0,'ScreenSize');% get the size of the screen, to put the fig on the upper right 3128 Width=300;% fig width in points (1/72 inch) 3129 Height=min(0.8*ScreenSize(4),300); 3130 Left=ScreenSize(3)- Width-40; %right edge close to the right, with margin=40 3131 Bottom=ScreenSize(4)-Height-40; %put fig at top right 3132 hfig=findobj(allchild(0),'Tag','set_slice'); 3133 if ~isempty(hfig),delete(hfig), end; %delete existing version of the GUI 3134 hfig=figure('name','set_pairs','tag','set_pairs','MenuBar','none','NumberTitle','off','Unit','points','Position',[Left,Bottom,Width,Height]); 3135 BackgroundColor=get(hfig,'Color'); 3136 hh=0.14; % box height (relative) 3137 ii=0.01; % gap between uicontrols 3138 3139 ww=0.9; % box width (relative) 3140 SeriesData=get(handles.series,'UserData'); 3141 % first raw of the GUI 3142 uicontrol('Style','text','Units','normalized', 'Position', [0.02 0.9 0.5 0.1],'BackgroundColor',BackgroundColor,... 3143 'String','row to edit #','FontUnits','points','FontSize',12,'FontWeight','bold','ForegroundColor','blue','HorizontalAlignment','right');%title 3144 uicontrol('Style','popupmenu','Units','normalized', 'Position', [0.54 0.8 0.3 0.2],'tag','ListView','BackgroundColor',[1 1 1],... 3145 'String',SeriesData.ListViewMenu,'Value',SeriesData.ListViewValue,'FontUnits','points','FontSize',12,'FontWeight','bold','TooltipString','''ListView'':choice of the file series w for pair display'); 3146 % second raw of the GUI 3147 uicontrol('Style','text','Units','normalized', 'Position', [0.02 0.8 0.7 0.1],'BackgroundColor',BackgroundColor,... 3148 'String','mode of index pairing:','FontUnits','points','FontSize',12,'FontWeight','bold','ForegroundColor','blue','HorizontalAlignment','left');%title 3149 uicontrol('Style','popupmenu','Units','normalized', 'Position', [0.02 0.58 ww 0.2],'tag','Mode','BackgroundColor',[1 1 1],'Callback',@(hObject,eventdata)ModeMenu_Callback(hObject,eventdata),... 3150 'String',SeriesData.ModeMenu,'Value',SeriesData.ModeValue,'FontUnits','points','FontSize',12,'FontWeight','bold','TooltipString','''Mode'': choice of the image pair mode'); 3151 % third raw 3152 uicontrol('Style','text','Units','normalized', 'Position', [0.02 0.6 0.7 0.1],'BackgroundColor',BackgroundColor,... 3153 'String','pair choice:','FontUnits','points','FontSize',12,'FontWeight','bold','ForegroundColor','blue','HorizontalAlignment','left');%title 3154 uicontrol('Style','listbox','Units','normalized', 'Position', [0.02 0.16 ww 0.4],'tag','ListPairs','BackgroundColor',[1 1 1],'Callback',@(hObject,eventdata)ListPairsMenu_Callback(hObject,eventdata),... 3155 'String',SeriesData.ListPairsMenu,'Value',SeriesData.ListPairsValue,'FontUnits','points','FontSize',12,'FontWeight','bold','TooltipString','''ListPairs'': menu for selecting the image pair'); 3156 % last raw of the GUI: pushbuttons 3157 wwp=(1-4*ii)/3; %width of the push buttons 3158 uicontrol('Style','pushbutton','Units','normalized', 'Position', [ii ii wwp hh],'BackgroundColor',[0 1 0],'String','OK','Callback',@(hObject,eventdata)OK_Callback(hObject,eventdata),... 3159 'FontWeight','bold','FontUnits','points','FontSize',12,'TooltipString','''OK'': apply the output to the current field series in uvmat'); 3160 drawnow 3161 3162 function ModeMenu_Callback(hObject,eventdata) 3163 hseries=findobj(allchild(0),'tag','series'); 3164 hhseries=guidata(hseries); 3165 SeriesData=get(hseries,'UserData'); 3166 hListView=findobj(get(hObject,'parent'),'Tag','ListView'); 3167 iview=get(hListView,'Value'); 3168 hMode=findobj(get(hObject,'parent'),'Tag','Mode'); 3169 mode_list=get(hMode,'String'); 3170 mode=mode_list{get(hMode,'Value')}; 3171 if isequal(mode,'bursts') 3172 enable_i(hhseries,'On') 3173 enable_j(hhseries,'Off') %do not display j index scanning in burst mode (j is fixed by the burst choice) 3174 else 3175 enable_i(hhseries,'On') 3176 enable_j(hhseries,'Off') 3177 end 3178 fill_ListPair(hhseries,SeriesData.i1_series{iview},SeriesData.i2_series{iview},... 3179 SeriesData.j1_series{iview},SeriesData.j2_series{iview},SeriesData.Time{iview}) 3180 ListPairs_Callback([],[],hhseries) 3181 3182 %------------------------------------------------------------- 3183 % --- Executes on selection in ListPairs. 3184 function ListPairsMenu_Callback(hObject,eventdata) 3185 %------------------------------------------------------------ 3186 list_pair=get(hObject,'String');%get the menu of image pairs 3187 if isempty(list_pair) 3188 string=''; 3189 else 3190 string=list_pair{get(hObject,'Value')}; 3191 string=regexprep(string,',.*','');%removes time indication (after ',') 3192 end 3193 hseries=findobj(allchild(0),'tag','series'); 3194 hPairString=findobj(hseries,'tag','PairString'); 3195 PairString=get(hPairString,'Data'); 3196 hListView=findobj(get(hObject,'parent'),'Tag','ListView'); 3197 iview=get(hListView,'Value'); 3198 PairString{iview,1}=string; 3199 % report the selected pair string to the table PairString 3200 set(hPairString,'Data',PairString) 3201 3202 %------------------------------------------------------------- 3203 % --- Executes on selection in ListPairs. 3204 function OK_Callback(hObject,eventdata) 3205 %------------------------------------------------------------ 3206 delete(get(hObject,'parent')) 3207
Note: See TracChangeset
for help on using the changeset viewer.