[1123] | 1 | |
---|
| 2 | %%% extract a series of image folders from RDvision |
---|
| 3 | % to run on the cluster, edit the file extract.sh in the folder TOP_view or SCANSIDE, |
---|
| 4 | % Then oarsub -l "walltime=20:00:00" /fsnet/project/coriolis/2018/18ADDUCE/TOP_View/extract.sh |
---|
| 5 | %%%%%%%%%%%%%% CHOOSE THE ROOT FOLDER %%%%%%%%%% |
---|
| 6 | |
---|
[1159] | 7 | RootDir='1_DATA' |
---|
[1123] | 8 | %RootFolder=fullfile('/fsnet/project/coriolis/2018/18JEVERB',RootDir); |
---|
[1159] | 9 | %RootFolder=fullfile('/fsnet/project/edt/2021/21CORIOFARM',RootDir) |
---|
| 10 | RootFolder=fullfile('/fsnet/project/coriolis/2024/24PLUME',RootDir) |
---|
[1123] | 11 | %ParamFile=fullfile(RootFolder,'extract_param.xml'); |
---|
| 12 | %Param=xml2struct(ParamFile); |
---|
| 13 | |
---|
| 14 | ListStruct=dir(RootFolder); % get structure of the Root directory |
---|
| 15 | index_dir=find(strcmp('isdir',fieldnames(ListStruct)));%detect folder info in structure ListStruct |
---|
| 16 | ListCells=struct2cell(ListStruct);% transform dir struct to a cell arrray |
---|
| 17 | check_dir=cell2mat(ListCells(index_dir,:));% =1 for directories, =0 for files |
---|
| 18 | ListCells=ListCells(:,check_dir); |
---|
| 19 | ListCells(:,1:2)=[]; |
---|
| 20 | ListNames=ListCells(1,:); |
---|
| 21 | List2extract={}; |
---|
| 22 | List2delete={}; |
---|
| 23 | List2check={}; |
---|
| 24 | |
---|
| 25 | %% loop on experiments |
---|
| 26 | for ilist=1:numel(ListNames)%loop on experiments |
---|
| 27 | ListNames{ilist} |
---|
| 28 | SubFolder=fullfile(RootFolder,ListNames{ilist}); |
---|
| 29 | ListStructSub=dir(SubFolder); % get structure of the Root directory |
---|
| 30 | index_dir=find(strcmp('isdir',fieldnames(ListStructSub)));%detect folder info in structure ListStruct |
---|
| 31 | ListCellsSub=struct2cell(ListStructSub);% transform dir struct to a cell arrray |
---|
| 32 | check_dir=cell2mat(ListCellsSub(index_dir,:));% =1 for directories, =0 for files |
---|
| 33 | ListCellsSub=ListCellsSub(:,check_dir); |
---|
| 34 | ListCellsSub(:,1:2)=[]; |
---|
| 35 | ListNamesSub=ListCellsSub(1,:); |
---|
| 36 | ind_rdvision=[]; |
---|
| 37 | for isub=1:numel(ListNamesSub)% loop on data folders of the current experiment |
---|
| 38 | ListStructSubSub=dir(fullfile(RootFolder,ListNames{ilist},ListNamesSub{isub})); % get structure of the Root directory |
---|
| 39 | index_dir=find(strcmp('isdir',fieldnames(ListStructSubSub)));%detect folder info in structure ListStruct |
---|
| 40 | ListCellsSubSub=struct2cell(ListStructSubSub);% transform dir struct to a cell arrray |
---|
| 41 | check_dir=cell2mat(ListCellsSubSub(index_dir,:));% =1 for directories, =0 for files |
---|
| 42 | ListCellsSubSub=ListCellsSubSub(:,check_dir); |
---|
| 43 | ListCellsSubSub(:,1:2)=[]; |
---|
| 44 | ListNamesSubSub=ListCellsSubSub(1,:); |
---|
| 45 | ind_rdvision=[]; |
---|
| 46 | for isubsub=1:numel(ListNamesSubSub) |
---|
[1159] | 47 | if ~isempty(regexp(ListNamesSubSub{isubsub},'^2024-')) |
---|
[1123] | 48 | ind_rdvision=[ind_rdvision isubsub];%detect rdvision folders |
---|
| 49 | end |
---|
| 50 | end |
---|
| 51 | |
---|
| 52 | %% extract the rdvision image series if it was not done |
---|
| 53 | if numel(ind_rdvision)==1% |
---|
| 54 | DataFolder=fullfile(RootFolder,ListNames{ilist},ListNamesSub{isub},ListNamesSubSub{ind_rdvision}); |
---|
| 55 | if isempty(regexp(DataFolder,'.extract$'))% if the detected folder is not .extract |
---|
| 56 | % ExtractFolder=fullfile(Param.InputTable{1},[Param.InputTable{2} '.extract']); |
---|
| 57 | % mkdir(ExtractFolder) |
---|
| 58 | % % if ~isempty(XmlFile) |
---|
| 59 | % % copyfile(fullfile(RootFolder,XmlFile),fullfile(DataFolder,[Param.OutputRootFile '.xml'])); |
---|
| 60 | % % end |
---|
| 61 | % seqname=fullfile(DataFolder,[Param.InputTable{3} Param.InputTable{5}]); |
---|
| 62 | % [A,FileInfo,timestamps,errormsg]=read_rdvision(seqname,[]); |
---|
| 63 | % Param.IndexRange.last_i=str2num(FileInfo.numberoffiles); |
---|
| 64 | % Param.OutputSubDir=Param.InputTable{2}; |
---|
| 65 | % Param.ActionInput.LogPath= DataFolder; |
---|
| 66 | % extract_rdvision(Param)% apply the function used in series |
---|
| 67 | % [ListNames{ilist} ' extracted'] |
---|
| 68 | List2extract=[List2extract;DataFolder]; |
---|
| 69 | end |
---|
| 70 | end |
---|
| 71 | |
---|
| 72 | %% delete the rdvision source if the extraction has been done |
---|
| 73 | Checkdelete=0; |
---|
| 74 | ExtractFolder=fullfile(RootFolder,ListNames{ilist},ListNamesSub{isub}); |
---|
| 75 | status=''; |
---|
| 76 | if numel(ind_rdvision)==2 |
---|
| 77 | for irdvision=1:2 |
---|
| 78 | CheckExtract(irdvision)=isempty(regexp(fullfile(RootFolder,ListNames{ilist},ListNamesSub{isub},ListNamesSubSub{irdvision}), '.extract$')); |
---|
| 79 | end |
---|
| 80 | status='extract missing'; |
---|
| 81 | if numel(find(CheckExtract))==1 |
---|
| 82 | ExtractFolder=fullfile(RootFolder,ListNames{ilist},ListNamesSub{isub},ListNamesSubSub{find(CheckExtract)}); |
---|
| 83 | PngFolder=fullfile(RootFolder,ListNames{ilist},ListNamesSub{isub},'im'); |
---|
| 84 | status='image folder not created'; |
---|
| 85 | if exist(ExtractFolder,'dir') && exist(PngFolder,'dir') |
---|
| 86 | filename_seq=fullfile(ExtractFolder,'im.seq'); |
---|
[1160] | 87 | NumberOfFrames=0; |
---|
[1159] | 88 | try |
---|
[1160] | 89 | s=ini2struct(filename_seq); |
---|
| 90 | FileInfo=s.sequenceSettings; |
---|
| 91 | |
---|
| 92 | if isfield(s.sequenceSettings,'numberoffiles') |
---|
| 93 | NumberOfFrames=str2double(s.sequenceSettings.numberoffiles); |
---|
| 94 | else |
---|
| 95 | status='bad seq file'; |
---|
| 96 | end |
---|
[1159] | 97 | catch ME |
---|
| 98 | disp(['error in ' filename_seq]) |
---|
| 99 | end |
---|
[1160] | 100 | DirPng=dir(PngFolder); |
---|
| 101 | |
---|
[1123] | 102 | if numel(DirPng)==NumberOfFrames+2 |
---|
[1160] | 103 | PngCells=struct2cell(DirPng); |
---|
| 104 | mm=cell2mat(PngCells(4,:));% check the sizes of extracted images |
---|
| 105 | sizemax=max(mm); |
---|
| 106 | sizemin=min(mm(3:end)); |
---|
| 107 | disp(['max size(Mbytes)=' num2str(sizemax/1000000)]); |
---|
| 108 | if min(mm(3:end))<0.9*sizemax |
---|
| 109 | status=['WARNING' 'min size(Mbytes)=' num2str(sizemin/1000000)]; |
---|
| 110 | else |
---|
| 111 | Checkdelete=1;% approve deletion of the source bin files |
---|
| 112 | end |
---|
[1123] | 113 | else |
---|
| 114 | status=['extraction not finished,' num2str(numel(DirPng)-2) ' images extracted']; |
---|
| 115 | end |
---|
| 116 | end |
---|
| 117 | end |
---|
| 118 | % |
---|
| 119 | % |
---|
| 120 | % Param.InputTable{1}=fullfile(RootFolder,ListDir{ilist});%folder exp |
---|
| 121 | % ddd=dir(Param.InputTable{1}); |
---|
| 122 | % Param.InputTable{2}=ddd(3).name; |
---|
| 123 | % DataFolder=fullfile(Param.InputTable{1},Param.InputTable{2}); |
---|
| 124 | % ExtractFolder=fullfile(Param.InputTable{1},[Param.InputTable{2} '.extract']); |
---|
| 125 | % mkdir(ExtractFolder) |
---|
| 126 | % if ~isempty(XmlFile) |
---|
| 127 | % copyfile(fullfile(RootFolder,XmlFile),fullfile(DataFolder,[Param.OutputRootFile '.xml'])); |
---|
| 128 | % end |
---|
| 129 | % seqname=fullfile(DataFolder,[Param.InputTable{3} Param.InputTable{5}]); |
---|
| 130 | % [A,FileInfo,timestamps,errormsg]=read_rdvision(seqname,[]); |
---|
| 131 | % Param.IndexRange.last_i=str2num(FileInfo.numberoffiles); |
---|
| 132 | % Param.OutputSubDir=Param.InputTable{2}; |
---|
| 133 | % Param.ActionInput.LogPath= DataFolder; |
---|
| 134 | % extract_rdvision(Param)% apply the function used in series |
---|
| 135 | end |
---|
| 136 | if Checkdelete |
---|
| 137 | List2delete=[List2delete;ExtractFolder]; |
---|
| 138 | %rmdir(ExtractFolder,'s') |
---|
| 139 | elseif ~isempty(status) |
---|
| 140 | List2check=[List2check;[ExtractFolder ' ' status]]; |
---|
| 141 | end |
---|
| 142 | end |
---|
| 143 | end |
---|
| 144 | List2extract |
---|
| 145 | List2check |
---|
| 146 | List2delete |
---|
| 147 | if ~isempty(List2delete) |
---|
| 148 | Answer = questdlg('delete listed folders(Y/N)'); |
---|
| 149 | if strcmp(Answer,'Yes') |
---|
| 150 | for ifolder=1:numel(List2delete) |
---|
| 151 | rmdir(List2delete{ifolder},'s') |
---|
| 152 | end |
---|
| 153 | end |
---|
[1160] | 154 | end |
---|
| 155 | 'END' |
---|