forked from vlfeat/matconvnet-fcn
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgetDatasetStatistics.m
29 lines (25 loc) · 937 Bytes
/
getDatasetStatistics.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
function stats = getDatasetStatistics(imdb)
train = find(imdb.images.set == 1 & imdb.images.segmentation) ;
% Class statistics
classCounts = zeros(21,1) ;
for i = 1:numel(train)
fprintf('%s: computing segmentation stats for training image %d\n', mfilename, i) ;
lb = imread(sprintf(imdb.paths.classSegmentation, imdb.images.name{train(i)})) ;
ok = lb < 255 ;
classCounts = classCounts + accumarray(lb(ok(:))+1, 1, [21 1]) ;
end
stats.classCounts = classCounts ;
% Image statistics
for t=1:numel(train)
fprintf('%s: computing RGB stats for training image %d\n', mfilename, t) ;
rgb = imread(sprintf(imdb.paths.image, imdb.images.name{train(t)})) ;
rgb = single(rgb) ;
z = reshape(permute(rgb,[3 1 2 4]),3,[]) ;
n = size(z,2) ;
rgbm1{t} = sum(z,2)/n ;
rgbm2{t} = z*z'/n ;
end
rgbm1 = mean(cat(2,rgbm1{:}),2) ;
rgbm2 = mean(cat(3,rgbm2{:}),3) ;
stats.rgbMean = rgbm1 ;
stats.rgbCovariance = rgbm2 - rgbm1*rgbm1' ;