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 | |
---|
7 | RootDir='1_DATA' |
---|
8 | %RootFolder=fullfile('/fsnet/project/coriolis/2018/18JEVERB',RootDir); |
---|
9 | %RootFolder=fullfile('/fsnet/project/edt/2021/21CORIOFARM',RootDir) |
---|
10 | RootFolder=fullfile('/fsnet/project/coriolis/2024/24PLUME',RootDir) |
---|
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) |
---|
47 | if ~isempty(regexp(ListNamesSubSub{isubsub},'^2024-', 'once')) |
---|
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$', 'once'))% 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$', 'once')); |
---|
79 | end |
---|
80 | status='extract missing'; |
---|
81 | if numel(find(CheckExtract))==1 |
---|
82 | ExtractFolder=fullfile(RootFolder,ListNames{ilist},ListNamesSub{isub},ListNamesSubSub{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'); |
---|
87 | NumberOfFrames=0; |
---|
88 | try |
---|
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 |
---|
97 | catch ME |
---|
98 | disp(['error in ' filename_seq]) |
---|
99 | disp(ME.message) |
---|
100 | end |
---|
101 | DirPng=dir(PngFolder); |
---|
102 | |
---|
103 | if numel(DirPng)==NumberOfFrames+2 |
---|
104 | PngCells=struct2cell(DirPng); |
---|
105 | mm=cell2mat(PngCells(4,:));% check the sizes of extracted images |
---|
106 | sizemax=max(mm); |
---|
107 | sizemin=min(mm(3:end)); |
---|
108 | disp(['max size(Mbytes)=' num2str(sizemax/1000000)]); |
---|
109 | if min(mm(3:end))<0.9*sizemax |
---|
110 | status=['WARNING' 'min size(Mbytes)=' num2str(sizemin/1000000)]; |
---|
111 | else |
---|
112 | Checkdelete=1;% approve deletion of the source bin files |
---|
113 | end |
---|
114 | else |
---|
115 | status=['extraction not finished,' num2str(numel(DirPng)-2) ' images extracted']; |
---|
116 | end |
---|
117 | end |
---|
118 | end |
---|
119 | % |
---|
120 | % |
---|
121 | % Param.InputTable{1}=fullfile(RootFolder,ListDir{ilist});%folder exp |
---|
122 | % ddd=dir(Param.InputTable{1}); |
---|
123 | % Param.InputTable{2}=ddd(3).name; |
---|
124 | % DataFolder=fullfile(Param.InputTable{1},Param.InputTable{2}); |
---|
125 | % ExtractFolder=fullfile(Param.InputTable{1},[Param.InputTable{2} '.extract']); |
---|
126 | % mkdir(ExtractFolder) |
---|
127 | % if ~isempty(XmlFile) |
---|
128 | % copyfile(fullfile(RootFolder,XmlFile),fullfile(DataFolder,[Param.OutputRootFile '.xml'])); |
---|
129 | % end |
---|
130 | % seqname=fullfile(DataFolder,[Param.InputTable{3} Param.InputTable{5}]); |
---|
131 | % [A,FileInfo,timestamps,errormsg]=read_rdvision(seqname,[]); |
---|
132 | % Param.IndexRange.last_i=str2num(FileInfo.numberoffiles); |
---|
133 | % Param.OutputSubDir=Param.InputTable{2}; |
---|
134 | % Param.ActionInput.LogPath= DataFolder; |
---|
135 | % extract_rdvision(Param)% apply the function used in series |
---|
136 | end |
---|
137 | if Checkdelete |
---|
138 | List2delete=[List2delete;ExtractFolder]; |
---|
139 | %rmdir(ExtractFolder,'s') |
---|
140 | elseif ~isempty(status) |
---|
141 | List2check=[List2check;[ExtractFolder ' ' status]]; |
---|
142 | end |
---|
143 | end |
---|
144 | end |
---|
145 | List2extract |
---|
146 | List2check |
---|
147 | List2delete |
---|
148 | if ~isempty(List2delete) |
---|
149 | Answer = questdlg('delete listed folders(Y/N)'); |
---|
150 | if strcmp(Answer,'Yes') |
---|
151 | for ifolder=1:numel(List2delete) |
---|
152 | rmdir(List2delete{ifolder},'s') |
---|
153 | end |
---|
154 | end |
---|
155 | end |
---|
156 | 'END' |
---|