12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- % RES = upBlur(IM, LEVELS, FILT)
- %
- % Upsample and blur an image. The blurring is done with filter
- % kernel specified by FILT (default = 'binom5'), which can be a string
- % (to be passed to namedFilter), a vector (applied separably as a 1D
- % convolution kernel in X and Y), or a matrix (applied as a 2D
- % convolution kernel). The downsampling is always by 2 in each
- % direction.
- %
- % The procedure is applied recursively LEVELS times (default=1).
- % Eero Simoncelli, 4/97.
- function res = upBlur(im, nlevs, filt)
- %------------------------------------------------------------
- %% OPTIONAL ARGS:
- if (exist('nlevs') ~= 1)
- nlevs = 1;
- end
- if (exist('filt') ~= 1)
- filt = 'binom5';
- end
- %------------------------------------------------------------
- if isstr(filt)
- filt = namedFilter(filt);
- end
- if nlevs > 1
- im = upBlur(im,nlevs-1,filt);
- end
- if (nlevs >= 1)
- if (any(size(im)==1))
- if (size(im,1)==1)
- filt = filt';
- end
- res = upConv(im,filt,'reflect1',(size(im)~=1)+1);
- elseif (any(size(filt)==1))
- filt = filt(:);
- res = upConv(im,filt,'reflect1',[2 1]);
- res = upConv(res,filt','reflect1',[1 2]);
- else
- res = upConv(im,filt,'reflect1',[2 2]);
- end
- else
- res = im;
- end
|