source: trunk/src/script_delete_rdvision.m @ 1160

Last change on this file since 1160 was 1160, checked in by sommeria, 6 months ago

script_delete_PCO added

File size: 7.5 KB
RevLine 
[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]7RootDir='1_DATA'
[1123]8%RootFolder=fullfile('/fsnet/project/coriolis/2018/18JEVERB',RootDir);
[1159]9%RootFolder=fullfile('/fsnet/project/edt/2021/21CORIOFARM',RootDir)
10RootFolder=fullfile('/fsnet/project/coriolis/2024/24PLUME',RootDir)
[1123]11%ParamFile=fullfile(RootFolder,'extract_param.xml');
12%Param=xml2struct(ParamFile);
13
14ListStruct=dir(RootFolder); % get structure of the Root directory
15index_dir=find(strcmp('isdir',fieldnames(ListStruct)));%detect folder info in structure ListStruct
16ListCells=struct2cell(ListStruct);% transform dir struct to a cell arrray
17check_dir=cell2mat(ListCells(index_dir,:));% =1 for directories, =0 for files
18ListCells=ListCells(:,check_dir);
19ListCells(:,1:2)=[];
20ListNames=ListCells(1,:);
21List2extract={};
22List2delete={};
23List2check={};
24
25%% loop on experiments
26for 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
143end
144List2extract
145List2check
146List2delete
147if ~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]154end
155'END'
Note: See TracBrowser for help on using the repository browser.