Applies a linear transformation to an image using cubic or linear
interpolation. It eliminates all range tests from the inner loop, but
falls back from cubic to quadratic interpolation (which range tests) around
the edges of the input image area.
array - The input image array
bray - The output image array
nxa,nya - The dimensions of array
nxb,nyb - The dimensions of bray
amat - A 2x2 matrix to specify rotation, scaling, and skewing
xc,yc - The coordinates of the center of array
xt,yt - The translation to add to the final image. The
center of the output array is taken as nxb / 2., nyb / 2.
scale - A multiplicative scale factor for the intensities
dmean - Mean intensity of image or other value with which to fill
empty image area
linear - Set greater than 0 to do linear interpolation or less than zero for
nearest neighbor interpolation
The coordinate transformation from (Xi, Yi) in the input image to the
(Xo, Yo) in the output image is given by:
Xo = a11(Xi - Xc) + a12(Yi - Yc) + nxb/2. + xt
Yo = a21(Xi - Xc) + a22(Yi - Yc) + nyb/2. + yt
where Xi is a coordinate running from 0 at the left edge of the first pixel
to nxa at the right edge of the last pixel in X, and similarly for Y.
When calling from C, indices in amat are transposed: a11 = amat[0][0],
a12 = amat[1][0], a21 = amat[0][1], a22 = amat[1][1]
To call from Fortran, use arguments of the same type and in the same order.
Indices in amat are in logical order: a11 = amat(1,1), a12 = amat(1,2),
etc.
This routine is now parallelized with OpenMP. The allowed threads is
proportional to the square root of output image area, falling to 1 at about
32x32.
Selects which filter to use in image reduction with type and sets the scaling factor with zoom, a value that must be less than 1. The type can be 0 for a box (equivalent to binning), 1 for a Blackman window, 2 for a triangle filter, 3 for a Mitchell filter, or 4 or 5 for Lanczos 2 or Lanczos 3. The total width of the filter in the source image is returned in outWidth. Returns 1 for a filter type out of range or 2 for a zoom out of range.
Fortran wrapper for selectZoomFilter
Like selectZoomFilter but it allows separate zooms in X and Y given by xzoom and yzoom, with respective filter widths returned in outWidthX and outWidthY.
Fortran wrapper for selectZoomFilterXY
Sets a factor for scaling the output values from image reduction of data types other than bytes and RGB.
Reduces an image using the interpolation filter and zoom specified in
selectZoomFilter.
slines - array of line pointers for the input image
aXsize, aYsize - size of input image
aXoff, aYoff - coordinate in the input image at which the lower left edge of the
lower left pixel of the output starts, where input coordinates are zero at the lower
left edge of the first input pixel
bXsize, bYsize - size of output image to be created, potentially from a subset of
the input in X or Y and into a subset of the output array
bXdim - X dimension of the full output image array
bXoff - Index of first pixel in X to fill in output array
dtype - Type of data, a SLICE_MODE_... value. BYTE, FLOAT, RGB, SHORT, and USHORT
are allowed; the output type is the same as the input unless mapping is used. Two
special cases are also allowed with RGBA data stored in unsigned integers with the
fourth channel ignored: with -SLICE_MODE_RGB or -SLICE_MODE_RGB - 2 for non-monochrome
data, R, G, and B channels are filtered separately and placed into the output followed
by a 0 byte for -SLICE_MODE_RGB or 255 for -SLICE_MODE_RGB - 2; with
-SLICE_MODE_RGB - 1 or -SLICE_MODE_RGB - 3 for monochrome data, just the first channel
is filtered and replicated into R, G, and B values in the output followed by a 0 byte
for -SLICE_MODE_RGB - 1 or 255 for -SLICE_MODE_RGB - 3. Mapping is
not allowed in either case.
outData - Output array, or address of first line to fill in a larger output array.
The array is the same data type as the input unless mapping is being done, in which
case it must be unsigned integers.
cindex - Unsigned integer RGBA values to map byte or short data into, or NULL for
no mapping
bindex - Byte values to map RGB data into, or NULL for no mapping. Each channel is
mapped the same and a fourth channel is added with zero.
Returns 1 if no filter has been selected, 2 for an unsupported data type, 3 for an
attempt to map float data or the special RGBA data, 4 if needed input coordinates to
compose the output image go out of range, or 5 for a memory allocation error.
This function is parallelized with OpenMP and uses the same formula as cubinterp for
reducing the number of threads for small images.
Fortran wrapper for zoomWithFilter
Performs image reduction using zoomWithFilter and can be used the same way as
cubinterp could be for scaling an image down and shifting it. The zoom and filter
must already be specified with selectZoomFilter .
array - The input image array
bray - The output image array
nxa,nya - The dimensions of array
nxb,nyb - The dimensions of bray
xc,yc - The coordinates of the center of array
xt,yt - The translation to add to the final image. The
center of the output array is taken as nxb / 2., nyb / 2.
dmean - Mean intensity of image or other value with which to fill empty
image area
Returns the same error values as zoomWithFilter
Fortran wrapper for zoomFiltInterp
Returns the normalized value of the filter selected by selectZoomFilter at the distance radius from the center of the filter. Returns 0 if no filter was selected.
Fortran wrapper for zoomFiltValue
Returns the value of the selected filter function at the given radius in zoomed-down pixels; i.e., there is no normalization or scaling of radius by the zoom.
Extracts a portion of an array into a portion of another array with optional summing
of pixels (binning) by the factor nbin. array has the input, with X dimension
nxDim, and the range of coordinates to extract is given in xStart, xEnd,
yStart, and yEnd * (inclusive, numbered from 0). The slice mode is in
type, and can be byte, short, unsigned short, float, or RGB.
brray receives the output, with the output size returned in nxr and nyr.
nxBdim can specify the X dimension of brray or be 0 to have data packed
contigously (X dimension equals X size); bxOffset and byOffset can indicate X and
Y offsets into brray. The output will have the same mode as the input and will be
the average of binned values, except in two cases. If the input is bytes or RGB and
keepByte is 0 or -1, then the output will be signed short integers and will be
the sum or the average, respectively, of the binned values, and for RGB data the output
will be an equal sum or average of red, green, and blue values. brray can be the
same as array, provided that its X dimension is not bigger than the input size,
unless the binning is 1, the input is bytes and keepByte is not greater than 0.
The output size is obtained by integer division of the input size
by the binning. If the remainder of this division is nonzero, the data are
centered in the output array as nearly as possible. Specifically, the
coordinates of the lower left corner of the output array are offset by
((nx % nbin) / 2, (ny % nbin) / 2)
relative to the input array. Returns 1 for an unsupported data type, 2 for an
input X range bigger than nxDim, or 3 for an output range bigger than the output
X dimension plus offset.
Extracts a portion of an array into another array with optional summing of pixels (binning) by the factor nbin. It calls extractAndBinIntoArray with output X dimension and offsets of 0 to produce a contiguously packed output in brray. Other arguments are as described there. brray can be the same as array unless the binning is 1, the input is bytes and keepByte is not greater than 0. Returns 1 for an unsupported data type or 2 for an input X range bigger than nxDim.
Fortran wrapper for extractWithBinning with floating point data
Calls extractWithBinning to simply repack a portion of a 2D float array sequentially into a 1-D array
Fortran wrapper for call to repackFloatImage with an unneeded argument nyin.
Reduces a full array in size by summing pixels (binning) by the factor nbin. array has the input, with dimensions nxin by nyin. It simply calls extractWithBinning with ranges of 0 to nxin - 1 and 0 to nyin - 1; other arguments have the same meaning as there. brray can be the same as array, and nxr, nyr can be the same variables as nxin, nyin. Returns 1 for an unsupported data type.
Fortran wrapper for reduceByBinning with floating point data, called as reduce_by_binning. Again, the output variables can safely be the same as the input variables.
Bins a slice of data in array, with X dimension nxDim, by binning factors of binFacX and binFacY in X and Y, and adds it into the slice in brray with a weighting of zWeight. The number of binned pixels to produce in X and Y is given by nxBin and nyBin, and brray is contiguous (has X dimension nxBin).
Fortran wrapper for binIntoSlice
In these functions, the transform can have either 2 or 3 rows of 3 columns, with the rows argument indicating the number of rows. Existing values in a third row are ignored, and the third row is returned with 0, 0, 1. The Fortran wrappers call with rows equal to 2.
Linear transforms specify the following operation on centered coordinates:
xp = a11 * x + a12 * y + dx
yp = a21 * x + a22 * y + dy
Here is a comprehensive list of the locations of these components:
generic C 9 C 6 Fortran (2,3)
a11 0 0 0 (1,1)
a21 1 1 1 (2,1)
a12 rows 3 2 (1,2)
a22 rows+1 4 3 (2,2)
dx 2*rows 6 4 (1,3)
dy 2*rows+1 7 5 (2,3)
Copies transform f1 to f2, which have rows1 and rows2 rows, respectively.
Multiples transform f1 (the one applied first) by f2 (the one applied second) and places the result in prod, which can be the same as f1 or f2.
Takes the inverse of transform f and returns the result in finv, which can be the same as f.
Applies transform f to the point x, y, with the center of transformation at xcen, ycen, and returns the result in xp, yp, which can be the same as x, y.
Given a set of rotations angles about the X, Y, and Z axes in the first, second, and
third elements of angles, finds the 3-D rotation matrix and returns it in matrix.
The number of rows in the matrix is specified by rows, which should be 3 when calling
with a packed 3x3 matrix, or 4 when calling with an Imat data array. The order of
data elements in the array is r11, r21, r31, etc. These are the conventions:
R premultiplies column vector of coordinates:
|xnew| | r11 r12 r13 | |xold|
|ynew| = | r21 r22 r23 | |yold|
|znew| | r31 r32 r33 | |zold|
rotations applied in the order Z first, X last
ie R = XYZ
rotations are right-handed - i.e., positive angle rotates counterclockwise when
looking down the respective axis
X =
| 1 0 0 |
| 0 cosa -sina |
| 0 sina cosa |
Y =
| cosb 0 sinb |
| 0 1 0 |
| -sinb 0 cosb |
Z =
| cosg -sinb 0 |
| sing cosg 0 |
| 0 0 1 |
Fortran wrapper to anglesToMatrix assuming matrix has 3 rows
Given a 3D rotation matrix in matrix, whose number of rows is rows, it finds the angles of rotation about the three axes, in the order Z, Y, X, and returns them in x, y, and z. Returns 1 if the determinant of the matrix is not near 1. Angles are in degrees. The conventions of anglesToMatrix are followed.
Fortran wrapper to matrixToAngles that assumes matrix has three rows and that places X, Y, and Z rotations into angles. If the determinant is not 1, it exits with matrix and determinant output and an error message. This function is callable from C with this name.
Inverts the 3x3 matrix in m1 into m2.
Converts a 2 by 2 transformation matrix into four "natural" parameters of
image transformation. The transformation is specified by a11, a12,
a21, and a22, where
x' = a11 * x + a12 * y
y' = a21 * x + a22 * y
In the converted transformation, theta is overall rotation, smag is
overall magnification, str is a unidirectional stretch, and phi is the
angle of the stretch axis. Two equivalent solutions are possible, with the
stretch axis in the first or fourth quadrant. The function returns the
solution that makes the magnification smag nearer to 1.0.
Fortran wrapper to amatToRotmagstr, where amat is dimensioned (2,*) or otherwise has elements in the order a11, a21, a12, a22.
Obtains a 2 by 2 transformation from four parameters of image transformation: theta is overall rotation, smag is overall magnification, str is a unidirectional stretch, and phi is the angle of the stretch axis, where angles are in degrees. The transformation is returned in a11, a12, a21, and a22.
Fortran wrapper to rotmagstrToAmat, where amat is dimensioned (2,*) or otherwise has elements in the order a11, a21, a12, a22.
Converts a 2 by 2 transformation matrix into four "semi-natural" parameters of
image transformation. The transformation is specified by a11, a12,
a21, and a22, where
x' = a11 * x + a12 * y
y' = a21 * x + a22 * y
In the converted transformation, theta is overall rotation, smag is overall
magnification, ydtheta is the rotation of the Y axis minus the rotation of the X
axis, and ydmag is the stretch along the Y axis minus the stretch along the X axis.
Fortran wrapper to amatToRotMag, where amat is dimensioned (2,*) or otherwise has elements in the order a11, a21, a12, a22.
Converts axial rotation and stretch specifications into a transformation matrix in a11, a12, a21, and a22. theta is overall rotation, smag is overall magnification, ydtheta is the rotation of the Y axis minus the rotation of the X axis, and ydmag is the stretch along the Y axis minus the stretch along the X axis.
Fortran wrapper to rotMagToAmat, where amat is dimensioned (2,*) or otherwise has elements in the order a11, a21, a12, a22.