Hauptinhalt

cp2tform

(Not recommended) Infer spatial transformation from control point pairs

cp2tform is not recommended. Use fitgeotform2d instead.

Description

tform = cp2tform(movingPoints,fixedPoints,transformationType) infers a spatial transformation from control point pairs and returns this transformation as a tform structure. Some of the transformation types have optional additional parameters, shown in the following syntaxes.

example

tform = cp2tform(movingPoints,fixedPoints,'polynomial',degree) lets you specify the order of the polynomials to use.

tform = cp2tform(movingPoints,fixedPoints,'lwm',n) creates a mapping by inferring a polynomial at each control point using neighboring control points. The mapping at any location depends on a weighted average of these polynomials. You can optionally specify the number of points, n, used to infer each polynomial. The n closest points are used to infer a polynomial of order 2 for each control point pair.

tform = cp2tform(movingPoints,fixedPoints,'piecewise linear') creates a Delaunay triangulation of the fixed control points, and maps corresponding moving control points to the fixed control points. The mapping is linear (affine) for each triangle and continuous across the control points but not continuously differentiable as each triangle has its own mapping.

[tform,usedMP,usedFP,badMP,badFP] = cp2tform(movingPoints,fixedPoints,'piecewise linear') returns in usedMP and usedFP the control points that were used for the piecewise linear transformation. This syntax also returns in badMP and badFP the control points that were eliminated because they were middle vertices of degenerate fold-over triangles.

tform = cp2tform(cpstruct,transformationType,___) uses a cpstruct structure to store the control point coordinates of the moving and fixed images.

[tform,usedMP,usedFP] = cp2tform(cpstruct,transformationType,___) also returns in usedMP and usedFP the control points that were used for the transformation. Unmatched and predicted points are not used. See cpstruct2pairs.

Examples

collapse all

Transform an image, use the cp2tform function to return the transformation, and compare the angle and scale of the tform to the angle and scale of the original transformation:

I = checkerboard;
J = imrotate(I,30);
fixedPoints = [11 11; 41 71];
movingPoints = [14 44; 70 81];
cpselect(J,I,movingPoints,fixedPoints);
 
t = cp2tform(movingPoints,fixedPoints,'nonreflective similarity');

Recover angle and scale by checking how a unit vector parallel to the x-axis is rotated and stretched.

u = [0 1]; 
v = [0 0]; 
[x, y] = tformfwd(t,u,v); 
dx = x(2) - x(1); 
dy = y(2) - y(1); 
angle = (180/pi) * atan2(dy, dx) 
scale = 1 / sqrt(dx^2 + dy^2)

Input Arguments

collapse all

Control points in the moving image, specified as an m-by-2 matrix. Each row specifies the [x y] coordinates of a control point.

Example: [11 11; 41 71]

Data Types: double

Control points in the fixed image, specified as an m-by-2 matrix. Each row specifies the [x y] coordinates of a control point.

Example: [14 44; 70 81]

Data Types: double

Type of transformation, specified as one of the following, listed in order of increasing complexity. The cp2tform function requires a minimum number of control point pairs to infer a structure of each transform type.

Transformation Type

Description

Minimum Number of Control Point Pairs

Example

'nonreflective similarity'

Use this transformation when shapes in the moving image are unchanged, but the image is distorted by some combination of translation, rotation, and scaling. Straight lines remain straight, and parallel lines are still parallel.

2

Original and transformed checkerboard image. The transformed image appears rotated 45 degrees.

'similarity'

Same as 'nonreflective similarity' with the addition of optional reflection.

3

Original and transformed checkerboard image. The transformed image appears rotated 45 degrees.

'affine'

Use this transformation when shapes in the moving image exhibit shearing. Straight lines remain straight, and parallel lines remain parallel, but rectangles become parallelograms.

3

Original and transformed checkerboard image. The transformed image appears sheared in the horizontal direction.

'projective'

Use this transformation when the scene appears tilted. Straight lines remain straight, but parallel lines converge toward vanishing points that might or might not fall within the image.

4

Original and transformed checkerboard image. The transformed image appears tilted out of plane of the image.

'polynomial'

Use this transformation when objects in the image are curved. The higher the order of the polynomial, the better the fit, but the result can contain more curves than the fixed image.

You can specify the degree of the polynomial.

6 (order 2)

10 (order 3)

15 (order 4)

Original and transformed checkerboard image. The transformed image appears curved.

'piecewise linear'

Use this transformation when parts of the image appear distorted differently.

4

Original and transformed checkerboard image. The right side of the transformed image appears stretched horizontally.

'lwm'

Use this transformation (local weighted mean), when the distortion varies locally and piecewise linear is not sufficient.

You can specify the number n of points to use in the local weighed mean calculation.

6 (12 recommended)

Original and transformed checkerboard image. The transformed image appears nonuniformly stretched.

Data Types: char

Preselected control points, specified as a structure. cpstruct contains information about the x- and y-coordinates of all control points in the moving and fixed images, including unpaired and predicted control points. cpstruct2pairs eliminates unmatched and predicted control points, and returns the set of valid control point pairs.

cpstruct is a structure produced by the Control Point Selection tool (cpselect) when you choose the Export Points to Workspace option. For more information, see Export Control Points to the Workspace.

Data Types: struct

Degree of the polynomial transformation, specified as the integer 2, 3, or 4.

Data Types: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

Number of points to use in local weighted mean calculation, specified as a positive integer. n can be as small as 6, but making n small risks generating ill-conditioned polynomials

Output Arguments

collapse all

Transformation, returned as a TFORM structure.

Moving control points that were used to infer the spatial transformation, returned as an n-by-2 matrix. Unmatched and predicted points are not used.

Fixed control points that were used to infer the spatial transformation, returned as an n-by-2 matrix. Unmatched and predicted points are not used.

Moving control points that were eliminated because they were determined to be outliers, returned as a p-by-2 matrix.

Fixed control points that were eliminated because they were determined to be outliers, returned as a p-by-2 matrix.

Tips

  • When transformtype is 'nonreflective similarity', 'similarity', 'affine', 'projective', or 'polynomial', and movingPoints and fixedPoints (or cpstruct) have the minimum number of control points needed for a particular transformation, cp2tform finds the coefficients exactly.

  • If movingPoints and fixedPoints have more than the minimum number of control points, a least-squares solution is found. See mldivide.

  • When either movingPoints or fixedPoints has a large offset with respect to their origin (relative to range of values that it spans), cp2tform shifts the points to center their bounding box on the origin before fitting a tform structure. This enhances numerical stability and is handled transparently by wrapping the origin-centered tform within a custom tform that automatically applies and undoes the coordinate shift as needed. As a result, fields(T) can give different results for different coordinate inputs, even for the same transformation type.

Algorithms

collapse all

cp2tform uses the following general procedure:

  1. Use valid pairs of control points to infer a spatial transformation or an inverse mapping from output space (x,y) to input space (x,y) according to transformtype.

  2. Return the tform structure containing spatial transformation.

The procedure varies depending on the transformtype.

References

[1] Goshtasby, Ardeshir, "Piecewise linear mapping functions for image registration," Pattern Recognition, Vol. 19, 1986, pp. 459-466.

[2] Goshtasby, Ardeshir, "Image registration by local approximation methods," Image and Vision Computing, Vol. 6, 1988, pp. 255-261.

Version History

Introduced before R2006a