SIVP Toolbox
Last update : June, 2006

fspecial - Create some 2D special filters

Calling Sequence

F = fspecial(type)
F = fspecial(type, op1)
F = fspecial(type, op1, op2)

Parameters

Description

fspecial create some 2D special filters. If no parameters are given, fspecial will uses default values.

The supported filters and the syntax for each filter type are listed in the following list:

F=fspecial('sobel')
returns a 3x3 horizontal edges sobel filter. If you want avertical edges sobel filter, you can use transposition of F. F is [ 1 2 1; 0 0 0; -1 -2 -1].
F=fspecial('prewitt')
returns a 3x3 horizontal edges prewitt filter. If you want avertical edges prewitt filter, you can use transposition of F. F is [ 1 1 1; 0 0 0; -1 -1 -1].
F=fspecial('gaussian', hsize, sigma)
returns a Gaussian lowpass filter. The size of returned filter is determined by parameter hsize. hsize can be a 1x2 vector which indicate the rows and columns of F. If hsize is a scalar, F is a square matrix. The default value for hsize is [3, 3]; the default value for sigma is 0.5.
F=fspecial('laplacian',alpha)
returns a 3-by-3 Laplacian filter. The returned filter is [alpha, 1-alpha, alpha; 1-alpha, -4, 1-alpha; alpha, 1-alpha, alpha]/(alpha+1). The default value for alpha is 0.2.
F=fspecial('log',hsize,sigma)
returns a Laplacian of Gaussian filter. The size of returned filter is determined by parameter hsize. hsize can be a 1x2 vector which indicate the rows and columns of F. If hsize is a scalar, F is a square matrix. The default value for hsize is [5, 5]; the default value for sigma is 0.5.
F=fspecial('average',hsize)
returns an averaging filter. The size of returned filter is determined by parameter hsize. hsize can be a 1x2 vector which indicate the rows and columns of F. If hsize is a scalar, F is a square matrix. The default value for hsize is [3, 3].
F=fspecial('unsharp',alpha)
returns a 3x3 unsharp contrast enhancement filter. alpha must be in the range [0.0, 1.0]. The default value of alpha is 0.2.

Examples


    im = imread('lena.png');
    filter = fspecial('sobel');
    imf = imfilter(im, filter);
    imshow(imf);

Authors

Shiqi Yu <shiqi.yu[at]gmail.com>

Availability

The latest version of SIVP can be found at

http://sivp.sourceforge.net

See Also

imfilter,  filter2,