Reference
DataAugmentation.AdjustBrightness — TypeAdjustBrightness(δ = 0.2)
AdjustBrightness(distribution)Adjust the brightness of an image by a factor chosen uniformly from f ∈ [1-δ, 1+δ] by multiplying each color channel by f.
You can also pass any Distributions.Sampleable from which the factor is selected.
Pixels are clamped to [0,1] unless clamp=false is passed.
Example
using DataAugmentation, TestImages
item = Image(testimage("lighthouse"))
tfm = AdjustBrightness(0.2)
titems = [apply(tfm, item) for _ in 1:8]
showgrid(titems; ncol = 4, npad = 16)DataAugmentation.AdjustContrast — TypeAdjustContrast(factor = 0.2)
AdjustContrast(distribution)Adjust the contrast of an image by a factor chosen uniformly from f ∈ [1-δ, 1+δ].
Pixels c are transformed c + μ*(1-f) where μ is the mean color of the image.
You can also pass any Distributions.Sampleable from which the factor is selected.
Pixels are clamped to [0,1] unless clamp=false is passed.
Example
using DataAugmentation, TestImages
item = Image(testimage("lighthouse"))
tfm = AdjustContrast(0.2)
titems = [apply(tfm, item) for _ in 1:8]
showgrid(titems; ncol = 4, npad = 16)DataAugmentation.BoundingBox — TypeBoundingBox(points, sz)
BoundingBox{N, T, M}(points, bounds)Item wrapper around Keypoints.
Examples
{cell=BoundingBox}
using DataAugmentation, StaticArrays
points = [SVector(10., 10.), SVector(80., 60.)]
item = BoundingBox(points, (100, 100)){cell=BoundingBox}
showitems(item)DataAugmentation.CenterCrop — FunctionCrop(sz, FromCenter())
DataAugmentation.CenterResizeCrop — FunctionScaleKeepAspect(sz) |> CenterCrop(sz) |> PinOrigin()
DataAugmentation.Crop — TypeCrop(sz, FromOrigin())
DataAugmentation.FlipDim — TypeFlipDim{N}(dim)Reflect N dimensional data along the axis of dimension dim. Must satisfy 1 <= dim <= N.
Examples
tfm = FlipDim{2}(1)DataAugmentation.FlipX — TypeFlipX{N}()Flip N dimensional data along the x-axis. 2D images use (r, c) = (y, x) convention such that x-axis flips occur along the second dimension. For N >= 3, x-axis flips occur along the first dimension.
DataAugmentation.FlipY — TypeFlipY{N}()Flip N dimensional data along the y-axis. 2D images use (r, c) = (y, x) convention such that y-axis flips occur along the first dimension. For N >= 3, y-axis flips occur along the second dimension.
DataAugmentation.FlipZ — TypeFlipZ{N}()Flip N dimensional data along the z-axis.
DataAugmentation.Image — TypeImage(image[, bounds]; interpolate=BSpline(Linear()), extrapolate=zero(T))Item representing an N-dimensional image with element type T. Optionally, the interpolation and extrapolation method can be provided. Interpolation here refers to how the values of projected pixels that fall into the transformed content bounds are calculated. Extrapolation refers to how to assign values that fall outside the projected content bounds. The default is linear interpolation and to fill new regions with zero.
The Interpolations package provides numerous methods for use with the interpolate and extrapolate keyword arguments. For instance, BSpline(Linear()) and BSpline(Constant()) provide linear and nearest neighbor interpolation, respectively. In addition Flat(), Reflect() and Periodic() boundary conditions are available for extrapolation.
Examples
using DataAugmentation, Images
imagedata = rand(RGB, 100, 100)
item = Image(imagedata)
showitems(item)If T is not a color, the image will be interpreted as grayscale:
imagedata = rand(Float32, 100, 100)
item = Image(imagedata)
showitems(item)DataAugmentation.Keypoints — TypeKeypoints(points, sz)
Keypoints{N, T, M}(points, bounds)N-dimensional keypoints represented as SVector{N, T}.
Spatial bounds are given by the polygon bounds::Vector{SVector{N, T}} or sz::NTuple{N, Int}.
Examples
{cell=Keypoints}
using DataAugmentation, StaticArrays
points = [SVector(y, x) for (y, x) in zip(4:5:80, 10:6:90)]
item = Keypoints(points, (100, 100)){cell=Keypoints}
showitems(item)DataAugmentation.MaskBinary — TypeMaskBinary(a; interpolate=BSpline(Constant()), extrapolate=Flat())An N-dimensional binary mask. Optionally, the interpolation and extrapolation method can be provided. Interpolation here refers to how the values of projected pixels that fall into the transformed content bounds are calculated. Extrapolation refers to how to assign values that fall outside the projected content bounds. The default is nearest neighbor interpolation and flat extrapolation of the edges into new regions.
The Interpolations package provides numerous methods for use with the interpolate and extrapolate keyword arguments. For instance, BSpline(Linear()) and BSpline(Constant()) provide linear and nearest neighbor interpolation, respectively. In addition Flat(), Reflect() and Periodic() boundary conditions are available for extrapolation.
Examples
using DataAugmentation
mask = MaskBinary(rand(Bool, 100, 100))showitems(mask)DataAugmentation.MaskMulti — TypeMaskMulti(a, [classes]; interpolate=BSpline(Constant()), extrapolate=Flat())An N-dimensional multilabel mask with labels classes. Optionally, the interpolation and extrapolation method can be provided. Interpolation here refers to how the values of projected pixels that fall into the transformed content bounds are calculated. Extrapolation refers to how to assign values that fall outside the projected content bounds. The default is nearest neighbor interpolation and flat extrapolation of the edges into new regions.
The Interpolations package provides numerous methods for use with the interpolate and extrapolate keyword arguments. For instance, BSpline(Linear()) and BSpline(Constant()) provide linear and nearest neighbor interpolation, respectively. In addition Flat(), Reflect() and Periodic() boundary conditions are available for extrapolation.
Examples
using DataAugmentation
mask = MaskMulti(rand(1:3, 100, 100))showitems(mask)DataAugmentation.Maybe — FunctionMaybe(tfm, p = 0.5) <: TransformWith probability p, apply transformation tfm.
DataAugmentation.OneOf — TypeOneOf(tfms)
OneOf(tfms, ps)Apply one of tfms selected randomly with probability ps each or uniformly chosen if no ps is given.
DataAugmentation.PermuteDims — TypePermuteDims(perm)Permute the dimensions of an ArrayItem. perm is a vector or a tuple specifying the permutation, whose length has to match the dimensionality of the ArrayItems data.
Refer to the permutedims documentation for examples of permutation vectors perm.
Supports apply!.
Examples
Preprocessing an image with 3 color channels.
{cell=PermuteDims}
using DataAugmentation, Images
image = Image(rand(RGB, 20, 20))
# Turn image to tensor and permute dimensions 2 and 1
# to convert HWC (height, width, channel) array to WHC (width, height, channel)
tfms = ImageToTensor() |> PermuteDims(2, 1, 3)
apply(tfms, image)DataAugmentation.Polygon — TypePolygon(points, sz)
Polygon{N, T, M}(points, bounds)Item wrapper around Keypoints.
Examples
{cell=Polygon}
using DataAugmentation, StaticArrays
points = [SVector(10., 10.), SVector(80., 20.), SVector(90., 70.), SVector(20., 90.)]
item = Polygon(points, (100, 100)){cell=Polygon}
showitems(item)DataAugmentation.RandomCrop — FunctionCrop(sz, FromRandom())
DataAugmentation.RandomResizeCrop — FunctionScaleKeepAspect(sz) |> RandomCrop(sz) |> PinOrigin()
DataAugmentation.Reflect — TypeReflect(γ)
Reflect(distribution)Reflect 2D spatial data around the center by an angle chosen at uniformly from [-γ, γ], an angle given in degrees.
You can also pass any Distributions.Sampleable from which the angle is selected.
Examples
tfm = Reflect(10)DataAugmentation.Rotate — TypeRotate(γ)
Rotate(distribution)
Rotate(α, β, γ)
Rotate(α_distribution, β_distribution, γ_distribution)Rotate spatial data around its center. Rotate(γ) is a 2D rotation by an angle chosen uniformly from [-γ, γ], an angle given in degrees. Rotate(α, β, γ) is a 3D rotation by angles chosen uniformly from [-α, α], [-β, β], and [-γ, γ], for X, Y, and Z rotations.
You can also pass any Distributions.Sampleable from which the angle is selected.
Examples
tfm2d = Rotate(10)
apply(tfm2d, Image(rand(Float32, 16, 16)))
tfm3d = Rotate(10, 20, 30)
apply(tfm3d, Image(rand(Float32, 16, 16, 16)))DataAugmentation.RotateX — FunctionRotateX(γ)
RotateX(distribution)X-Axis rotation of 3D spatial data around the center by an angle chosen uniformly from [-γ, γ], an angle given in degrees.
You can also pass any Distributions.Sampleable from which the angle is selected.
DataAugmentation.RotateY — FunctionRotateY(γ)
RotateY(distribution)Y-Axis rotation of 3D spatial data around the center by an angle chosen uniformly from [-γ, γ], an angle given in degrees.
You can also pass any Distributions.Sampleable from which the angle is selected.
DataAugmentation.RotateZ — FunctionRotateZ(γ)
RotateZ(distribution)Z-Axis rotation of 3D spatial data around the center by an angle chosen uniformly from [-γ, γ], an angle given in degrees.
You can also pass any Distributions.Sampleable from which the angle is selected.
DataAugmentation.ScaleKeepAspect — TypeScaleKeepAspect(minlengths) <: ProjectiveTransformScales the shortest side of item to minlengths, keeping the original aspect ratio.
Examples
using DataAugmentation, TestImages
image = testimage("lighthouse")
tfm = ScaleKeepAspect((200, 200))
apply(tfm, Image(image))DataAugmentation.ScaleRatio — TypeScaleRatio(minlengths) <: ProjectiveTransformScales the aspect ratio
DataAugmentation.WarpAffine — TypeWarpAffine(σ = 0.1) <: ProjectiveTransformA three-point affine warp calculated by randomly moving 3 corners of an item. Similar to a random translation, shear and rotation.
DataAugmentation.itemdata — Functionitemdata(item)
itemdata(items)Access the data wrapped in item or a tuple of items.
DataAugmentation.showitems — Functionshowitems(items)Visualize items.
DataAugmentation.AbstractArrayItem — Typeabstract type AbstractArrayItem{N, T}Abstract type for all [Item]s that wrap an N-dimensional array with element type T.
DataAugmentation.AbstractItem — Typeabstract type AbstractItemAbstract supertype for all items. To implement items, subtype either Item to create a new item or ItemWrapper to wrap an existing item.
DataAugmentation.ArrayItem — TypeArrayItem(a)An item that contains an array.
DataAugmentation.Buffered — TypeBuffer to store transform results
DataAugmentation.BufferedThreadsafe — TypeBuffer to store transform results (threadsafe)
DataAugmentation.Categorify — TypeCategorify(dict, cols)Label encodes the values of a row present in TabularItem for the columns specified in cols using dict, which contains the column names as dictionary keys and the unique values of column present as dictionary values.
if there are any missing values in the values to be transformed, they are replaced by 1.
Example
using DataAugmentation
cols = [:col1, :col2, :col3]
row = (; zip(cols, ["cat", 2, 3])...)
item = TabularItem(row, cols)
catdict = Dict(:col1 => ["dog", "cat"])
tfm = Categorify(catdict, [:col1])
apply(tfm, item)DataAugmentation.ComposedProjectiveTransform — TypeComposedProjectiveTransform(tfms...)Wrap multiple projective tfms and apply them efficiently. The projections are fused into a single projection and only points inside the final crop are evaluated.
DataAugmentation.FillMissing — TypeFillMissing(dict, cols)Fills the missing values of a row present in TabularItem for the columns specified in cols using dict, which contains the column names as dictionary keys and the value to fill the column with present as dictionary values.
Example
using DataAugmentation
cols = [:col1, :col2, :col3]
row = (; zip(cols, [1, 2, 3])...)
item = TabularItem(row, cols)
fmdict = Dict(:col1 => 100, :col2 => 100)
tfm = FillMissing(fmdict, [:col1, :col2])
apply(tfm, item)DataAugmentation.Identity — TypeIdentity()The identity transformation.
DataAugmentation.ImageToTensor — TypeImageToTensor()Expands an Image{N, T} of size (height, width, ...) to an ArrayItem{N+1} with size (width, height, ..., ch) where ch is the number of color channels of T.
Supports apply!.
Examples
{cell=ImageToTensor}
using DataAugmentation, Images
h, w = 40, 50
image = Image(rand(RGB, h, w))
tfm = ImageToTensor()
apply(tfm, image) # ArrayItem in WHC format of size (50, 40, 3)DataAugmentation.Item — Typeabstract type ItemAbstract supertype of concrete items.
Subtype if you want to create a new item. If you want to wrap an existing item, see ItemWrapper.
DataAugmentation.ItemWrapper — Typeabstract type ItemWrapper{Item}DataAugmentation.MapElem — TypeMapElem(f)Applies f to every element in an [AbstractArrayItem].
DataAugmentation.Normalize — TypeNormalize(means, stds)Normalizes the last dimension of an AbstractArrayItem{N}.
Supports apply!.
Examples
Preprocessing a 3D image with 3 color channels.
{cell=Normalize}
using DataAugmentation, Images
image = Image(rand(RGB, 20, 20, 20))
tfms = ImageToTensor() |> Normalize((0.1, -0.2, -0.1), (1,1,1.))
apply(tfms, image)DataAugmentation.NormalizeRow — TypeNormalizeRow(dict, cols)Normalizes the values of a row present in TabularItem for the columns specified in cols using dict, which contains the column names as dictionary keys and the mean and standard deviation tuple present as dictionary values.
Example
using DataAugmentation
cols = [:col1, :col2, :col3]
row = (; zip(cols, [1, 2, 3])...)
item = TabularItem(row, cols)
normdict = Dict(:col1 => (1, 1), :col2 => (2, 2))
tfm = NormalizeRow(normdict, [:col1, :col2])
apply(tfm, item)DataAugmentation.OneHot — TypeOneHot([T = Float32])One-hot encodes a MaskMulti with n classes and size sz into an array item of size (sz..., n) with element type T. Supports apply!.
item = MaskMulti(rand(1:4, 100, 100), 1:4)
apply(OneHot(), item)DataAugmentation.PinOrigin — TypePinOrigin()Projective transformation that translates the data so that the upper left bounding corner is at the origin (0, 0) (or the multidimensional equivalent).
Projective transformations on images return OffsetArrays, but not on keypoints. Hardware like GPUs do not support OffsetArrays, so they will be unwrapped and no longer match up with the keypoints.
Pinning the data to the origin makes sure that the resulting OffsetArray has the same indices as a regular array, starting at one.
DataAugmentation.ProjectiveTransform — Typeabstract type ProjectiveTransform <: TransformAbstract supertype for projective transformations. See
DataAugmentation.ResizePadDivisible — FunctionScaleKeepAspect(sz) |> PadDivisible(by) |> PinOrigin()
DataAugmentation.ScaleFixed — TypeScaleFixed(sizes)Projective transformation that scales sides to sizes, disregarding aspect ratio.
See also ScaleKeepAspect.
DataAugmentation.Sequence — TypeSequence(transforms...)Transform that applies multiple transformations after each other.
You should not use this explicitly. Instead use compose.
DataAugmentation.ToEltype — TypeToEltype(T)Converts any AbstractArrayItem to an AbstractArrayItem{N, T}.
Supports apply!.
Examples
{cell=ToEltype}
using DataAugmentation
tfm = ToEltype(Float32)
item = ArrayItem(rand(Int, 10))
apply(tfm, item)DataAugmentation.Transform — Typeabstract type TransformAbstract supertype for all transformations.
DataAugmentation.Zoom — TypeZoom(scales = (1, 1.2)) <: ProjectiveTransform
Zoom(distribution)Zoom into an item by a factor chosen from the interval scales or distribution.
DataAugmentation.apply — Functionapply(tfm, item[; randstate])
apply(tfm, items[; randstate])Apply tfm to an item or a tuple items.
DataAugmentation.apply! — Functionapply!(buffer::I, tfm, item::I)Applies tfm to item, mutating the preallocated buffer.
buffer can be obtained with buffer = makebuffer(tfm, item)
apply!(buffer, tfm::Transform, item::I; randstate) = apply(tfm, item; randstate)Default to apply(tfm, item) (non-mutating version).
DataAugmentation.boundsof — Functionboundingranges(ps)Find bounding index ranges for points ps.
DataAugmentation.centered — Functioncentered(P, bounds)Transform P so that is applied around the center of bounds instead of the origin
DataAugmentation.compose — Functioncompose(transforms...)Compose tranformations. Use |> as an alias.
Defaults to creating a Sequence of transformations, but smarter behavior can be implemented. For example, MapElem(f) |> MapElem(g) == MapElem(g ∘ f).
DataAugmentation.getbounds — Functiongetbounds(item)Return the spatial bounds of item. For a 2D-image (Image{2}) the bounds are the 4 corners of the bounding rectangle. In general, for an N-dimensional item, the bounds are a vector of the N^2 corners of the N-dimensional hypercube bounding the data.
DataAugmentation.getprojection — Functiongetprojection(tfm, bounds; randstate)Create a projection for an item with spatial bounds bounds. The projection should be a CoordinateTransformations.Transformation. See CoordinateTransformations.jl
DataAugmentation.getrandstate — Functiongetrandstate(transform)Generates random state for stochastic transformations. Calling apply(tfm, item) is equivalent to apply(tfm, item; randstate = getrandstate(tfm)). It defaults to nothing, so you it only needs to be implemented for stochastic Transforms.
Return random state of the transform
DataAugmentation.makebuffer — Functionmakebuffer(tfm, item)Create a buffer buf that can be used in a call to apply!(buf, tfm, item). Default to buffer = apply(tfm, item).
You only need to implement this if the default apply(tfm, item) isn't enough. See apply(tfm::Sequence, item) for an example of this.
DataAugmentation.offsetcropbounds — Functionoffsetcropbounds(sz, bounds, offsets)Calculate offset bounds for a crop of size sz.
For every dimension i where sz[i] < length(indices[i]), offsets the crop by offsets[i] times the difference between the two.
DataAugmentation.project — Functionproject(P, item, indices)Project item using projection P and crop to indices if given.
DataAugmentation.project! — Functionproject!(bufitem, P, item, indices)Project item using projection P and crop to indices if given. Store result in bufitem. Inplace version of project.
Default implementation falls back to project.
DataAugmentation.projectionbounds — Functionprojectionbounds(tfm, P, bounds, randstate)DataAugmentation.setdata — FunctionProvides a convenient way to create a copy of an item, replacing only the wrapped data. This relies on the wrapped data field being named data, though.
DataAugmentation.showitem! — Functionshowitem!(item)Visualize item. Should return an image.
DataAugmentation.testapply — Functiontestapply(tfm, item)
testapply(tfm, I)Test apply invariants of tfm on item or item type I.
- With a constant
randstateparameter,applyshould always return the same result.
DataAugmentation.testapply! — Functiontestapply!(tfm, Items)
testapply!(tfm, Item)
testapply!(tfm, item1, item2)Test apply! invariants.
- With a constant
randstateparameter,apply!should always return the same result. - Given a different item than was used to create the buffer, the buffer's data should be modified.
DataAugmentation.testitem — Functiontestitem(TItem)Create an instance of an item with type TItem. If it has spatial bounds, should return an instance with bounds with ranges (1:16, 1:16).
DataAugmentation.testprojective — Functiontestprojective(tfm)Test invariants of a ProjectiveTransform.
getprojectionis defined, and, given a constantrandstateparameter, always returns the same result.- It preserves the item type, i.e.
apply(tfm, ::I) -> I. - Applying it to multiple items with the same bounds results in the same bounds for all items.
DataAugmentation.threepointwarpaffine — Functionthreepointwarpaffine(srcps, dstps)Calculate an affine CoordinateTransformations.LinearMap from 3 source points to 3 destination points.
Adapted from CoordinateTransformations.jl#30.
DataAugmentation.transformbounds — Functiontransformbounds(bounds, P)Apply CoordinateTransformations.Transformation to bounds.