rotate_image — Rotate an image about its center.
rotate_image rotates the
Image counterclockwise by
Phi degrees about its center and stores the result in the
ImageRotate. The output image has the same
size as the input image. The only exception are rotations by 90 and
270 degrees where width and height will be exchanged. The domain of
the input image is ignored, i.e., assumed to be the full rectangle
of the image. The domain of the output image is the intersection of
the transformed rectangle and the rectangle of the output image.
Phi is a multiple of 90 degrees, this operator is much
faster, especially than the general operator
affine_trans_image. The effect of the parameter
Interpolation is the same as in
It is ignored for rotations by 90, 180, and 270 degrees. If it is
necessary to rotate the domain, too, the operator
projective_trans_image must be used.
Additionally, for images of type 'byte', 'int2' or 'uint2' the system parameter 'int_zooming' selects between fast calculation in fixed point arithmetics ('int_zooming' = 'true') and highly accurate calculation in floating point arithmetics ('int_zooming' = 'false'). Except for rotations by 90, 180, or 270 degrees, fixed point calculation can lead to minor gray value deviations. Furthermore, the domain of resulting images can differ as well.
The domain of the input image is ignored, i.e., assumed to be the
full rectangle of the image. The domain of the output image is the
intersection of the transformed rectangle and the rectangle of the
output image. The angle
Phi is given in degrees, not in
radians. For rotations by 90, 180, and 270 degrees
rotate_image is not parallelized internally.
rotate_image can be executed on OpenCL devices if the input
image does not exceed the maximum size of image objects of the
selected device. Due to numerical reasons, there can be slight
differences in the output compared to the execution on the CPU.
→object (byte* / int2* / uint2* / real*) *allowed for compute devices
→object (byte / int2 / uint2 / real)
→(real / integer)
Default value: 90
Suggested values: 90, 180, 270
Typical range of values:
Minimum increment: 0.001
Recommended increment: 0.2
Type of interpolation.
Default value: 'constant'
List of values: 'bicubic', 'bilinear', 'constant', 'nearest_neighbor', 'weighted'
read_image(Image,'monkey') dev_display (Image) rotate_image(Image,RotImage,270,'constant') dev_display (RotImage)