DIPlib Documentation - ©1995-2010 Quantitative Imaging Group, Delft University of Technology.

DirectedPathOpening

Morphological filter

SYNOPSIS

#include "dip_morphology.h"

dip_Error DirectedPathOpening ( grey, mask, out, filterParam, closing, constrained )

DATA TYPES

binary, integer, float

FUNCTION

Theoretically, the path opening can be written as the supremum of all the openings with each of the possible linear structuring elements of composed of a set number of pixels in the general orientation of filterParam. The filterParam parameter is interpreted as follows: length is set to max(filterParam). direction is set to round(filterParam/length). direction now contains only values 0, -1 or 1. A 90 degree cone is defined around the given direction, and this cone gives the neighbourhood connectivity. The structuring element is formed by length pixels connected according to this neighbourhood connectivity. For example, in 2D, if filterParam is [10,0], the structuring element will be formed by 10 pixels connected either diagonally or horizontally. It will extend across exactly 10 horizontal pixels, but can vary in shape to adapt to local image content.

If closing is DIP_TRUE, the path closing will be computed instead of the opening.

If constrained is DIP_TRUE, the algorithm is modified as follows: Only one consecutive step is allowed in a direction other than the exact direction specified. For example, following the [10,0] example above, a diagonal step must be followed by at least one horizontal step. This avoids zig-zag lines, especially if the main direction is diagonal. It also reduces the maximal angle that a straight line can deviate from the chosen direction. The unconstrained algorithm will keep lines rotated by up to 45 degrees; the constrained algorithm limits this to 22.5 degrees.

ARGUMENTS

Data typeNameDescription
dip_ImagegreyGrey-value input image
dip_ImagemaskMask image for ROI processing
dip_ImageoutOutput image
dip_FloatArrayfilterParamSize of structuring element
dip_BooleanclosingDIP_FALSE for path opening, DIP_TRUE for path closing
dip_BooleanconstrainedDIP_TRUE for constrained paths, DIP_FALSE for the original path opening algorithm

LITERATURE

H. Talbot and B. Appleton, Efficient complete and incomplete path openings and closings, Image and Vision Computing 25:416-425, 2007.

SEE ALSO

Opening, Closing, PathOpening, AreaOpening

DIPlib on-line documentation | Function reference | Global function index