forked from pdollar/toolbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfevalImages.m
124 lines (119 loc) · 4.71 KB
/
fevalImages.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
function X = fevalImages( fHandle, prms, srcDir, name, ext, ...
nStr, nEnd, nDigits )
% Used to apply the same operation to all images in given directory.
%
% For each image in srcDir, loads the image, applies the function in
% fHandle and stores the result. The result x=fHandle(I,prms{:}) on the
% ith image is stored in X(:,...:,i). If the size of x depends on the size
% of I, then all images in the directory must have the same size. Also I
% may have a different format depending on how it is stored on disk -
% example: MxN for grayscale, MxNx3 for RGB, MxNx4 for CMYK. This function
% is similar to fevalArrays, except instead of operating on images in
% memory it operates on images on disk. For long operations shows progress
% info.
%
% The srcDir must contain nothing but images. Either the images follow no
% naming convention, or they follow a very rigid naming convention that
% consists of a string followed by an nDigits number specifying the image
% number, followed by an extension. The advantage of the more rigid naming
% convention is that it allows a certain range of images to be operated on,
% specified by [nStr,nEnd]. For example, to operate on images
% "rats0003.tif ... rats0113.tif" in directory '../rats/' use:
% fevalImages( fHandle, prms, '../rats/', 'rats' , 'tif', 3, 113, 4 );
% If the parameter name is specified ('rats' in the example above), the
% rigid naming convention is assumed. All further input arguments are
% optional. imwrite2 writes images in the format described above.
%
% A limitation of fevalImages is that it does not pass state information
% to fHandle. For example, fHandle may want to know how many times it's
% been called. This can be overcome by saving state information inside
% fHandle using 'persistent' variables. For an example see imwrite2 (which
% uses persistent variables with fevalArrays).
%
% USAGE
% X = fevalImages( fHandle, prms, srcDir, [name], [ext],
% [nStr], [nEnd], [nDigits] )
%
% INPUTS
% fHandle - function to apply to each image [see above]
% prms - cell array of additional parameters to fHandle (may be {} )
% srcDir - directory containing images
% name - [] base name of images
% ext - [] extension of image
% nStr - [] image number on which to start
% nEnd - [] image number on which to end
% nDigits - [] number of digits for filename index
%
% OUTPUTS
% X - output array [see above]
%
% EXAMPLE
% % reads in all images in directory (note that fHandle is identity):
% X = fevalImages( @(x) x, {}, srcDir );
% % reads in different sized images into cell array:
% X = fevalImages( @(x) {x}, {}, srcDir );
% % reads in all images converting to grayscale:
% X = fevalImages( @(x) rgb2gray(x), {}, srcDir );
%
% See also FEVALARRAYS, IMWRITE2, PERSISTENT, TICSTATUS
%
% Piotr's Computer Vision Matlab Toolbox Version 2.40
% Copyright 2014 Piotr Dollar. [pdollar-at-gmail.com]
% Licensed under the Simplified BSD License [see external/bsd.txt]
narginchk( 3, 8 );
%%% Check if srcDir is valid and add '/' at end if needed
if( ~isempty(srcDir) )
if(~exist(srcDir,'dir'))
error( ['fevalImages: directory ' srcDir ' not found' ] ); end;
if( srcDir(end)~='\' && srcDir(end)~='/' ); srcDir(end+1) = '/'; end;
end
%%% get appropriate filenames
if( nargin<=3 ) % no convention followed
dirCont = dir(srcDir); dirCont = dirCont(3:end);
filenames = {dirCont.name}; n = length(dirCont);
else % strict convention followed
if( nargin<8 || isempty(nDigits) || isunix )
dirCont = dir([srcDir name '*.' ext]);
else
dirCont = dir([srcDir name repmat('?',[1 nDigits]) '.' ext '*' ]);
end;
filenames = {dirCont.name};
n = length(dirCont);
if( n==0 ); error( ['No images found in ' srcDir] ); end;
if( nargin<5 || isempty(ext));
ext=dirCont(1).name; ext=ext(end-2:end);
end;
if( nargin<6 || isempty(nStr)); nStr = 0; end;
if( nargin<7 || isempty(nEnd)); nEnd = n-1+nStr; end;
if( nargin<8 || isempty(nDigits))
nDigits = length(dirCont(1).name)-length(ext)-1-length(name); end;
n = nEnd-nStr+1;
end;
if( n==0 ); X=[]; return; end;
%%% load each image and apply func
ticId = ticStatus('fevalImages',[],40);
for i=1:n
% load image
if( nargin==3 )
I = imread( [srcDir filenames{i}] );
else
nstr = int2str2( i+nStr-1, nDigits );
try
I = imread([srcDir name nstr '.' ext ] );
catch %#ok<CTCH>
error( ['Unable to read image: ' srcDir name nstr '.' ext] );
end;
end
% apply fHandle to I
x = feval( fHandle, I, prms{:} );
if (i==1)
ndx = ndims(x);
if(ndx==2 && size(x,2)==1); ndx=1; end;
onesNdx = ones(1,ndx);
X = repmat( x, [onesNdx,n] );
indsX = {':'}; indsX = indsX(onesNdx);
else
X(indsX{:},i) = x;
end;
tocStatus( ticId, i/n );
end;