ImageTransformation
✖
ImageTransformation
gives an image in which each pixel at position p corresponds to the position f[p] in image.
Details and Options




- In ImageTransformation[image,f] is also known as backward transformation, where the value of every pixel at position {x,y} in the output image is obtained from the position f[{x,y}] in the input image.
- The transformation function f can be one of the following:
-
f an arbitrary function f TransformationFunction[…] a transformation function - For video inputs, the transformation function can also be a function of time (in seconds from the start). The function returns a frame in which each pixel at time t and position p corresponds to the position f[t][p].
- ImageTransformation works with arbitrary 2D and 3D images.
- Possible settings for size are:
-
Automatic automatic image size All same as input image size width explicit width, automatic height {width,height} explicit width and height {width,depth,height} explicit width, depth and height in 3D - For possible width, depth and height specifications, see the reference page for ImageResize.
- In 2D, the range of the coordinate system for the input image is assumed to be
, where
is the aspect ratio. The bottom-left corner of the image corresponds to coordinates
by default.
- In 3D, the range of the coordinate system for the input image is assumed to be
, where
are the image dimensions. The bottom-left front corner of the image corresponds to coordinates
by default.
- Other coordinate systems can be specified by setting the DataRange option.
- ImageTransformation can take the following options:
-
Background 0 background color to use DataRange Automatic range of coordinates in the original image Masking Full region of interest to be transformed Padding 0 padding method PlotRange Automatic range of coordinates in the resulting image Resampling Automatic resampling method - By default, ImageTransformation returns an image with the aspect ratio of the input image.
- Typical settings for DataRange include:
-
Automatic in 2D,
in 3D
Full in 2D,
in 3D
{{left,right},{bottom,top}} explicit coordinate ranges in 2D {{left,right},{front,back},{bottom,top}} explicit coordinate ranges in 3D - The coordinate system of the resulting image is specified by the PlotRange option. Typical settings include:
-
Automatic same as DataRange settings All try to include all of the transformed pixels Full same ranges as the input image {{left,right},…} explicit coordinate ranges - In ImageTransformation[image,f], the pixel dimensions of the resulting image are based on the dimensions of image and the ratio of PlotRange and DataRange.
- The Masking option can be one of the following:
-
All input image only Full input image and padding mask any mask image

Examples
open allclose allBasic Examples (2)Summary of the most common use cases
Scope (13)Survey of the scope of standard use cases
Data (4)

https://wolfram.com/xid/0g7hih41i82-gfrv9x


https://wolfram.com/xid/0g7hih41i82-igkr4a


https://wolfram.com/xid/0g7hih41i82-zvje5z


https://wolfram.com/xid/0g7hih41i82-p4nz4

Transformation (7)
Use any function for the transformation:

https://wolfram.com/xid/0g7hih41i82-9o8k2n


https://wolfram.com/xid/0g7hih41i82-wm9l9x


https://wolfram.com/xid/0g7hih41i82-7rgfnf

Operate explicitly on and
pixel positions:

https://wolfram.com/xid/0g7hih41i82-bfn89b

Operate on the vertical dimension only:

https://wolfram.com/xid/0g7hih41i82-gpejm

Perform a matrix transformation:

https://wolfram.com/xid/0g7hih41i82-ehox3b

Use a TransformationFunction to specify the transformation:

https://wolfram.com/xid/0g7hih41i82-j910pk

Transform frames of a video as a function of time and position:

https://wolfram.com/xid/0g7hih41i82-od3f14

https://wolfram.com/xid/0g7hih41i82-7qbams

Use a 3D transformation function:

https://wolfram.com/xid/0g7hih41i82-t9iru0

Size (2)
By default, the output image is of the same size as the input image:

https://wolfram.com/xid/0g7hih41i82-jzi98t

https://wolfram.com/xid/0g7hih41i82-e2tu9


https://wolfram.com/xid/0g7hih41i82-h59h6

Specify the size of the resulting image:

https://wolfram.com/xid/0g7hih41i82-go48z

Specify width and height explicitly:

https://wolfram.com/xid/0g7hih41i82-fykv75


https://wolfram.com/xid/0g7hih41i82-577n8


https://wolfram.com/xid/0g7hih41i82-ltipfb

Use All to obtain an image of the same size as the original:

https://wolfram.com/xid/0g7hih41i82-dbn6rs

Make a 3D image narrow and tall:

https://wolfram.com/xid/0g7hih41i82-29c5o

Options (7)Common values & functionality for each option
Background (1)
By default, a black background is used:

https://wolfram.com/xid/0g7hih41i82-feaav5

Use a specific color for the background:

https://wolfram.com/xid/0g7hih41i82-21p0fd


https://wolfram.com/xid/0g7hih41i82-ese0ag

Images with an alpha channel use a transparent background by default:

https://wolfram.com/xid/0g7hih41i82-i9dskb

DataRange (2)
By default, the Automatic DataRange is used:

https://wolfram.com/xid/0g7hih41i82-bfgcxm

Use DataRangeFull when defining translation in pixel coordinates:

https://wolfram.com/xid/0g7hih41i82-bev4iv

Specify a custom DataRange:

https://wolfram.com/xid/0g7hih41i82-bu5hl4

Choose a data range symmetric on the axis to show a vertical reflection:

https://wolfram.com/xid/0g7hih41i82-b0gt5w

Vertical reflection transform applied to a 3D image:

https://wolfram.com/xid/0g7hih41i82-jvjqjs

Masking (1)
By default, Masking->Full is used; padding is used for pixels outside of the original image:

https://wolfram.com/xid/0g7hih41i82-pwhgmk

With Masking->All, the Background option value is used for pixels outside of the original image:

https://wolfram.com/xid/0g7hih41i82-lhq9jp


https://wolfram.com/xid/0g7hih41i82-hi9sbz

PlotRange (1)
By default, the output image retains the plot range of the input image:

https://wolfram.com/xid/0g7hih41i82-pg5ca

Use PlotRange->All to view all transformed image pixels:

https://wolfram.com/xid/0g7hih41i82-gtrdwa

Use explicit plot range values:

https://wolfram.com/xid/0g7hih41i82-bnfka4

Rotate image around its center:

https://wolfram.com/xid/0g7hih41i82-eo91ma

Use pixel coordinates with PlotRangeFull option:

https://wolfram.com/xid/0g7hih41i82-f5ph3

Padding (1)
By default, Padding0 is used:

https://wolfram.com/xid/0g7hih41i82-l18yan

https://wolfram.com/xid/0g7hih41i82-6n9aa


https://wolfram.com/xid/0g7hih41i82-k464dk

Using fixed padding for values beyond the image:

https://wolfram.com/xid/0g7hih41i82-brspv


https://wolfram.com/xid/0g7hih41i82-uc4c05


https://wolfram.com/xid/0g7hih41i82-1fcm62

Applications (6)Sample problems that can be solved with this function
Reverse an unknown geometric transformation by determining the transformation function from a pair of images:

https://wolfram.com/xid/0g7hih41i82-c90uw5

Apply the transformation function to the transformed image:

https://wolfram.com/xid/0g7hih41i82-ebxyag


https://wolfram.com/xid/0g7hih41i82-cvz5w5


https://wolfram.com/xid/0g7hih41i82-x6r5q9


https://wolfram.com/xid/0g7hih41i82-p5py9h

Warp a line of text along the vertical axis:

https://wolfram.com/xid/0g7hih41i82-kkzxc7

Use padding to extend the region of the image:

https://wolfram.com/xid/0g7hih41i82-ibtbv3


https://wolfram.com/xid/0g7hih41i82-bzld86

Properties & Relations (2)Properties of the function, and connections to other functions
By default, the returned image retains the size and aspect ratio of the original:

https://wolfram.com/xid/0g7hih41i82-dyxtey

Doing a transformation with a function and its inverse gives back the original image with some blurring due to interpolation:

https://wolfram.com/xid/0g7hih41i82-mzpyba

Interactive Examples (1)Examples with interactive outputs
Neat Examples (6)Surprising or curious use cases
Do mathematical transformations on images:

https://wolfram.com/xid/0g7hih41i82-p53nxz


https://wolfram.com/xid/0g7hih41i82-svwbcv


https://wolfram.com/xid/0g7hih41i82-m6zfnb


https://wolfram.com/xid/0g7hih41i82-ci9fxv


https://wolfram.com/xid/0g7hih41i82-clifwe


https://wolfram.com/xid/0g7hih41i82-cqaf8k


https://wolfram.com/xid/0g7hih41i82-cz0sx9


https://wolfram.com/xid/0g7hih41i82-ki0zlq

Wolfram Research (2010), ImageTransformation, Wolfram Language function, https://reference.wolfram.com/language/ref/ImageTransformation.html (updated 2021).
Text
Wolfram Research (2010), ImageTransformation, Wolfram Language function, https://reference.wolfram.com/language/ref/ImageTransformation.html (updated 2021).
Wolfram Research (2010), ImageTransformation, Wolfram Language function, https://reference.wolfram.com/language/ref/ImageTransformation.html (updated 2021).
CMS
Wolfram Language. 2010. "ImageTransformation." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2021. https://reference.wolfram.com/language/ref/ImageTransformation.html.
Wolfram Language. 2010. "ImageTransformation." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2021. https://reference.wolfram.com/language/ref/ImageTransformation.html.
APA
Wolfram Language. (2010). ImageTransformation. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/ImageTransformation.html
Wolfram Language. (2010). ImageTransformation. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/ImageTransformation.html
BibTeX
@misc{reference.wolfram_2025_imagetransformation, author="Wolfram Research", title="{ImageTransformation}", year="2021", howpublished="\url{https://reference.wolfram.com/language/ref/ImageTransformation.html}", note=[Accessed: 04-April-2025
]}
BibLaTeX
@online{reference.wolfram_2025_imagetransformation, organization={Wolfram Research}, title={ImageTransformation}, year={2021}, url={https://reference.wolfram.com/language/ref/ImageTransformation.html}, note=[Accessed: 04-April-2025
]}