idamnjanovic@10
|
1 function y = sampgrid(x,blocksize,varargin)
|
idamnjanovic@10
|
2 %SAMPGRID Sample a multi-dimensional matrix on a regular grid.
|
idamnjanovic@10
|
3 % Y = SAMPGRID(X,BLOCKSIZE,I1,I2,...,Ip) extracts block samples of size
|
idamnjanovic@10
|
4 % BLOCKSIZE from the p-dimensional matrix X, arranging the samples as the
|
idamnjanovic@10
|
5 % column vectors of the matrix Y. The locations of the (1,1,..,1)-th
|
idamnjanovic@10
|
6 % elements of each block are given in the index vectors I1,I2,..Ip. The
|
idamnjanovic@10
|
7 % total number of samples taken is length(I1)xlength(I2)x...xlength(Ip).
|
idamnjanovic@10
|
8 % BLOCKSIZE should either be a p-element vector of the form [N1,N2,...Np],
|
idamnjanovic@10
|
9 % or a scalar N which is shorthand for the square block size [N N ... N].
|
idamnjanovic@10
|
10 %
|
idamnjanovic@10
|
11 % Example: Sample a set of blocks uniformly from a 2D image.
|
idamnjanovic@10
|
12 %
|
idamnjanovic@10
|
13 % n = 512; blocknum = 20000; blocksize = [8 8];
|
idamnjanovic@10
|
14 % im = rand(n,n);
|
idamnjanovic@10
|
15 % [i1,i2] = reggrid(size(im)-blocksize+1, blocknum);
|
idamnjanovic@10
|
16 % blocks = sampgrid(im, blocksize, i1, i2);
|
idamnjanovic@10
|
17 %
|
idamnjanovic@10
|
18 % See also REGGRID.
|
idamnjanovic@10
|
19
|
idamnjanovic@10
|
20 % Ron Rubinstein
|
idamnjanovic@10
|
21 % Computer Science Department
|
idamnjanovic@10
|
22 % Technion, Haifa 32000 Israel
|
idamnjanovic@10
|
23 % ronrubin@cs
|
idamnjanovic@10
|
24 %
|
idamnjanovic@10
|
25 % November 2007
|
idamnjanovic@10
|
26
|
idamnjanovic@10
|
27
|
idamnjanovic@10
|
28 p = ndims(x);
|
idamnjanovic@10
|
29
|
idamnjanovic@10
|
30 if (numel(blocksize)==1)
|
idamnjanovic@10
|
31 blocksize = ones(1,p)*blocksize;
|
idamnjanovic@10
|
32 end
|
idamnjanovic@10
|
33
|
idamnjanovic@10
|
34 n = zeros(1,p);
|
idamnjanovic@10
|
35 for i = 1:p
|
idamnjanovic@10
|
36 n(i) = length(varargin{i});
|
idamnjanovic@10
|
37 end
|
idamnjanovic@10
|
38
|
idamnjanovic@10
|
39 nsamps = prod(n);
|
idamnjanovic@10
|
40
|
idamnjanovic@10
|
41 % create y of the same class as x
|
idamnjanovic@10
|
42 y = zeros(prod(blocksize),nsamps,class(x));
|
idamnjanovic@10
|
43
|
idamnjanovic@10
|
44 % ids() contains the index of the current block in I1..Ip
|
idamnjanovic@10
|
45 ids = ones(p,1);
|
idamnjanovic@10
|
46
|
idamnjanovic@10
|
47 % block_ids contains the indices of the current block in X
|
idamnjanovic@10
|
48 block_ids = cell(p,1);
|
idamnjanovic@10
|
49 for j = 1:p
|
idamnjanovic@10
|
50 block_ids{j} = varargin{j}(1) : varargin{j}(1)+blocksize(j)-1;
|
idamnjanovic@10
|
51 end
|
idamnjanovic@10
|
52
|
idamnjanovic@10
|
53 for k = 1:nsamps
|
idamnjanovic@10
|
54 block = x(block_ids{:});
|
idamnjanovic@10
|
55 y(:,k) = block(:);
|
idamnjanovic@10
|
56
|
idamnjanovic@10
|
57 % increment ids() and block_ids{}
|
idamnjanovic@10
|
58 if (k<nsamps)
|
idamnjanovic@10
|
59 j = 1;
|
idamnjanovic@10
|
60 while (ids(j) == n(j))
|
idamnjanovic@10
|
61 ids(j) = 1;
|
idamnjanovic@10
|
62 block_ids{j} = varargin{j}(1) : varargin{j}(1)+blocksize(j)-1;
|
idamnjanovic@10
|
63 j = j+1;
|
idamnjanovic@10
|
64 end
|
idamnjanovic@10
|
65 ids(j) = ids(j)+1;
|
idamnjanovic@10
|
66 block_ids{j} = varargin{j}(ids(j)) : varargin{j}(ids(j))+blocksize(j)-1;
|
idamnjanovic@10
|
67 end
|
idamnjanovic@10
|
68 end
|
idamnjanovic@10
|
69
|
idamnjanovic@10
|
70
|
idamnjanovic@10
|
71 %
|
idamnjanovic@10
|
72 % p = ndims(x);
|
idamnjanovic@10
|
73 %
|
idamnjanovic@10
|
74 % n = zeros(1,p);
|
idamnjanovic@10
|
75 % for i = 1:p
|
idamnjanovic@10
|
76 % n(i) = length(varargin{i});
|
idamnjanovic@10
|
77 % end
|
idamnjanovic@10
|
78 %
|
idamnjanovic@10
|
79 % nsamps = prod(n);
|
idamnjanovic@10
|
80 %
|
idamnjanovic@10
|
81 % % create y of the same class as x
|
idamnjanovic@10
|
82 % y = zeros(prod(blocksize),nsamps,class(x));
|
idamnjanovic@10
|
83 %
|
idamnjanovic@10
|
84 % id = cell(p,1);
|
idamnjanovic@10
|
85 % for k = 1:nsamps
|
idamnjanovic@10
|
86 % [id{:}] = ind2sub(n,k);
|
idamnjanovic@10
|
87 % for j = 1:p
|
idamnjanovic@10
|
88 % id{j} = varargin{j}(id{j}) : varargin{j}(id{j})+blocksize(j)-1;
|
idamnjanovic@10
|
89 % end
|
idamnjanovic@10
|
90 % block = x(id{:});
|
idamnjanovic@10
|
91 % y(:,k) = block(:);
|
idamnjanovic@10
|
92 % end
|
idamnjanovic@10
|
93
|