Changeset 845 for trunk/src/series.m
- Timestamp:
- Dec 17, 2014, 12:32:52 PM (10 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/series.m
r844 r845 1308 1308 function RUN_Callback(hObject, eventdata, handles) 1309 1309 1310 %% read the data on the GUI series1311 Param=read_GUI_series(handles);%displayed parameters1312 SeriesData=get(handles.series,'UserData');%hidden parameters1313 if ~isfield(SeriesData,'i1_series')1314 msgbox_uvmat('ERROR','The input field series needs to be refreshed: press REFRESH')1315 return1316 end1317 if isfield(Param,'InputFields')&& isequal(Param.InputFields.FieldName,'get_field...')1318 msgbox_uvmat('ERROR','input field name(s) not defined, select get_field...')1319 return1320 end1321 1322 1310 %% settings of the button RUN 1323 1311 set(handles.RUN,'BusyAction','queue');% activation of STOP button will set BusyAction to 'cancel' … … 1326 1314 drawnow 1327 1315 set(handles.status,'Value',0)% desable status display if relevant 1328 status_Callback(hObject, eventdata, handles) 1316 status_Callback([], eventdata, handles) 1317 1318 %% launch action 1319 errormsg=launch_action(handles); 1320 if ~isempty(errormsg) 1321 msgbox_uvmat('ERROR',errormsg) 1322 end 1323 1324 %% reset the GUI series 1325 update_waitbar(handles.Waitbar,1); % put the waitbar to end position to indicate launching is finished 1326 set(handles.RUN, 'Enable','On') 1327 set(handles.RUN,'BackgroundColor',[1 0 0]) 1328 set(handles.RUN, 'Value',0) 1329 1330 %------------------------------------------------------------------------ 1331 % --- called by RUN_Callback 1332 %------------------------------------------------------------------------ 1333 function errormsg=launch_action(handles) 1334 errormsg='';%default 1335 1336 %% read the data on the GUI series 1337 Param=read_GUI_series(handles);%displayed parameters 1338 SeriesData=get(handles.series,'UserData');%hidden parameters 1339 if ~isfield(SeriesData,'i1_series') 1340 errormsg='The input field series needs to be refreshed: press REFRESH'; 1341 return 1342 end 1343 if isfield(Param,'InputFields')&& isequal(Param.InputFields.FieldName,'get_field...') 1344 errormsg='input field name(s) not defined, select get_field...'; 1345 return 1346 end 1329 1347 1330 1348 %% select the Action mode, 'local', 'background' or 'cluster' (if available) … … 1341 1359 ActionName=Param.Action.ActionName; 1342 1360 ActionPath=Param.Action.ActionPath; 1343 1344 1361 path_series=fileparts(which('series')); 1345 1362 … … 1349 1366 eval(['spath=which(''' ActionName ''');']) %spath = current path of the selected function ACTION 1350 1367 if ~exist(ActionPath,'dir') 1351 msgbox_uvmat('ERROR',['The prescribed function path ' ActionPath ' does not exist']);1368 errormsg=['The prescribed function path ' ActionPath ' does not exist']; 1352 1369 return 1353 1370 end … … 1390 1407 end 1391 1408 if isempty(RunTime) && strcmp(RunMode,'cluster_oar') 1392 msgbox_uvmat('ERROR','RunTime name not found in PARAM.xml, compiled version .sh cannot run on cluster')1409 errormsg='RunTime name not found in PARAM.xml, compiled version .sh cannot run on cluster'; 1393 1410 return 1394 1411 end … … 1463 1480 1464 1481 %% create the output data directory if needed 1465 Outpu Dir='';1482 OutputDir=''; 1466 1483 if isfield(Param,'OutputSubDir') 1467 1484 SubDirOut=[get(handles.OutputSubDir,'String') Param.OutputDirExt]; … … 1472 1489 answer=msgbox_uvmat('INPUT_Y-N',['use existing ouput directory: ' fullfile(Param.InputTable{1,1},SubDirOutNew) ', possibly delete previous data']); 1473 1490 if strcmp(answer,'Cancel') 1474 errormsg='Cancel';1491 set(handles.RUN,'backgroundcolor',[1 0 0]) 1475 1492 return 1476 1493 elseif strcmp(answer,'Yes') … … 1495 1512 [tild,msg1]=mkdir(OutputDir); 1496 1513 if ~strcmp(msg1,'') 1497 msgbox_uvmat('ERROR',['cannot create ' OutputDir ': ' msg1]);%error message for directory creation1514 errormsg=['cannot create ' OutputDir ': ' msg1];%error message for directory creation 1498 1515 return 1499 1516 end … … 1501 1518 if success==0 1502 1519 msgbox_uvmat('WARNING',{['unable to set group write access to ' OutputDir ':']; msg1});%error message for directory creation 1503 return1504 1520 end 1505 1521 end … … 1512 1528 [tild,msg1]=mkdir(DirXml); 1513 1529 if ~strcmp(msg1,'') 1514 msgbox_uvmat('ERROR',['cannot create ' DirXml ': ' msg1]);%error message for directory creation1530 errormsg=['cannot create ' DirXml ': ' msg1];%error message for directory creation 1515 1531 return 1516 1532 end … … 1540 1556 end 1541 1557 if last_i < first_i || last_j < first_j 1542 msgbox_uvmat('ERROR', 'series/Run_Callback:last field index must be larger or equal to the first one') 1543 set(handles.RUN, 'Enable','On'), 1544 set(handles.RUN,'BackgroundColor',[1 0 0]) 1558 errormsg= 'series/Run_Callback:last field index must be larger or equal to the first one'; 1545 1559 return 1546 1560 end … … 1626 1640 end 1627 1641 end 1628 % elseif strcmp(get(handles.OutputDirExt,'Visible'),'off')1629 % msgbox_uvmat('ERROR',['no output file for Action ' ActionName ', use run mode = local']);% a output dir is needed for background option1630 % return1631 1642 else 1632 1643 %% processing on a different session of the same computer (background) or cluster, create executable files … … 1643 1654 [tild,msg1]=mkdir(DirBat); 1644 1655 if ~strcmp(msg1,'') 1645 msgbox_uvmat('ERROR',['cannot create ' DirBat ': ' msg1]);%error message for directory creation1656 errormsg=['cannot create ' DirBat ': ' msg1];%error message for directory creation 1646 1657 return 1647 1658 end … … 1652 1663 [tild,msg1]=mkdir(DirLog); 1653 1664 if ~strcmp(msg1,'') 1654 msgbox_uvmat('ERROR',['cannot create ' DirLog ': ' msg1]);%error message for directory creation1665 errormsg=['cannot create ' DirLog ': ' msg1];%error message for directory creation 1655 1666 return 1656 1667 end … … 1684 1695 [fid,message]=fopen(filebat,'w');% create the executable file 1685 1696 if isequal(fid,-1) 1686 msgbox_uvmat('ERROR', ['creation of .bat file: ' message]);1697 errormsg=['creation of .bat file: ' message]; 1687 1698 return 1688 1699 end … … 1742 1753 for iprocess=1:NbProcess 1743 1754 system([batch_file_list{iprocess} ' &'])% directly execute the command file for each process 1744 msgbox_uvmat('CONFIRMATION',[ActionName ' launched in background: press STATUS to see results'])1755 msgbox_uvmat('CONFIRMATION',[ActionName ' launched in background: press STATUS to see results']) 1745 1756 end 1746 1757 case 'cluster_oar' % option 'oar-parexec' used … … 1755 1766 [tild,msg1]=mkdir(DirOAR); 1756 1767 if ~strcmp(msg1,'') 1757 msgbox_uvmat('ERROR',['cannot create ' DirOAR ': ' msg1]);%error message for directory creation1768 errormsg=['cannot create ' DirOAR ': ' msg1];%error message for directory creation 1758 1769 return 1759 1770 end … … 1785 1796 msgbox_uvmat('CONFIRMATION',[ActionName ' launched in cluster: press STATUS to see results']) 1786 1797 end 1787 1788 %% reset the GUI series1789 update_waitbar(handles.Waitbar,1); % put the waitbar to end position to indicate launching is finished1790 set(handles.RUN, 'Enable','On')1791 set(handles.RUN,'BackgroundColor',[1 0 0])1792 set(handles.RUN, 'Value',0)1793 1798 1794 1799 %------------------------------------------------------------------------ … … 2192 2197 end 2193 2198 set(handles.OutputDirExt,'String',OutputDirExt) 2194 OutputDirVisible='off'; 2195 OutputSubDirMode='auto';%default 2196 SubDirOut=''; 2197 if isfield(ParamOut,'OutputSubDirMode') 2198 OutputSubDirMode=ParamOut.OutputSubDirMode; 2199 end2200 switch OutputSubDirMode 2201 case 'auto';%default 2202 OutputDirVisible='on';2203 SubDir=InputTable(1:end,2); %set of subdirectories2204 SubDirOut=SubDir{1};2205 if numel(SubDir)>12206 for ilist=2:numel(SubDir)2207 SubDirOut=[SubDirOut '-' SubDir{ilist}];2208 end2199 end 2200 OutputDirVisible='off'; 2201 OutputSubDirMode='auto';%default 2202 SubDirOut=''; 2203 if isfield(ParamOut,'OutputSubDirMode') 2204 OutputSubDirMode=ParamOut.OutputSubDirMode; 2205 end 2206 switch OutputSubDirMode 2207 case 'auto';%default 2208 OutputDirVisible='on'; 2209 SubDir=InputTable(1:end,2); %set of subdirectories 2210 SubDirOut=SubDir{1}; 2211 if numel(SubDir)>1 2212 for ilist=2:numel(SubDir) 2213 SubDirOut=[SubDirOut '-' SubDir{ilist}]; 2209 2214 end 2210 case 'first' 2211 OutputDirVisible='on'; 2212 SubDirOut=InputTable{1,2}; %use the first subdir name (+OutputDirExt) as output subdirectory 2213 case 'last' 2214 OutputDirVisible='on'; 2215 SubDirOut=InputTable{end,2}; %use the last subdir name (+OutputDirExt) as output subdirectory 2216 end 2217 set(handles.OutputSubDir,'String',SubDirOut) 2218 set(handles.OutputDirExt,'Visible',OutputDirVisible) 2219 set(handles.OutputSubDir,'Visible',OutputDirVisible) 2220 set(handles.OutputDir_title,'Visible',OutputDirVisible) 2221 SeriesData.ActionName=ActionName;%record ActionName for next use 2222 2223 2224 %% visibility of the run mode (local or background or cluster) 2225 if strcmp(OutputSubDirMode,'none') 2226 RunModeVisible='off';% only local mode available if no output file is produced 2227 else 2228 RunModeVisible='on'; 2229 end 2230 set(handles.RunMode,'Visible',RunModeVisible) 2231 set(handles.ActionExt,'Visible',RunModeVisible) 2232 set(handles.RunMode_title,'Visible',RunModeVisible) 2233 set(handles.ActionExt_title,'Visible',RunModeVisible) 2234 end 2215 end 2216 case 'first' 2217 OutputDirVisible='on'; 2218 SubDirOut=InputTable{1,2}; %use the first subdir name (+OutputDirExt) as output subdirectory 2219 case 'last' 2220 OutputDirVisible='on'; 2221 SubDirOut=InputTable{end,2}; %use the last subdir name (+OutputDirExt) as output subdirectory 2222 end 2223 set(handles.OutputSubDir,'String',SubDirOut) 2224 set(handles.OutputDirExt,'Visible',OutputDirVisible) 2225 set(handles.OutputSubDir,'Visible',OutputDirVisible) 2226 set(handles.OutputDir_title,'Visible',OutputDirVisible) 2227 SeriesData.ActionName=ActionName;%record ActionName for next use 2228 2229 2230 %% visibility of the run mode (local or background or cluster) 2231 if strcmp(OutputSubDirMode,'none') 2232 RunModeVisible='off';% only local mode available if no output file is produced 2233 else 2234 RunModeVisible='on'; 2235 end 2236 set(handles.RunMode,'Visible',RunModeVisible) 2237 set(handles.ActionExt,'Visible',RunModeVisible) 2238 set(handles.RunMode_title,'Visible',RunModeVisible) 2239 set(handles.ActionExt_title,'Visible',RunModeVisible) 2240 2235 2241 2236 2242 %% Expected nbre of output files … … 2987 2993 if ~isfield(Param,'OutputSubDir') 2988 2994 msgbox_uvmat('ERROR','no standard sub-directory definition for output files, use a browser to check the output') 2995 set(handles.status,'BackgroundColor',[0 1 0]) 2989 2996 return 2990 2997 end
Note: See TracChangeset
for help on using the changeset viewer.