boofcv.alg.misc.GImageMiscOps Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ip Show documentation
Show all versions of ip Show documentation
BoofCV is an open source Java library for real-time computer vision and robotics applications.
/*
* Copyright (c) 2011-2016, Peter Abeles. All Rights Reserved.
*
* This file is part of BoofCV (http://boofcv.org).
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package boofcv.alg.misc;
import boofcv.misc.BoofMiscOps;
import boofcv.struct.image.*;
import java.util.Random;
/**
* Generalized version of {@link ImageMiscOps}. Type checking is performed at runtime instead of at compile type.
*
* @author Peter Abeles
*/
public class GImageMiscOps {
/**
* Copies a rectangular region from one image into another.
* output[dstX:(dstX+width) , dstY:(dstY+height-1)] = input[srcX:(srcX+width) , srcY:(srcY+height-1)]
*
* @param srcX x-coordinate of corner in input image
* @param srcY y-coordinate of corner in input image
* @param dstX x-coordinate of corner in output image
* @param dstY y-coordinate of corner in output image
* @param width Width of region to be copied
* @param height Height of region to be copied
* @param input Input image
* @param output output image
*/
public static void copy( int srcX , int srcY , int dstX , int dstY , int width , int height ,
ImageBase input , ImageBase output ) {
if( input instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.copy(srcX, srcY, dstX, dstY, width, height, (GrayI8) input, (GrayI8) output);
} else if( GrayI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.copy(srcX, srcY, dstX, dstY, width, height, (GrayI16) input, (GrayI16) output);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.copy(srcX, srcY, dstX, dstY, width, height, (GrayS32) input, (GrayS32) output);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.copy(srcX, srcY, dstX, dstY, width, height, (GrayS64) input, (GrayS64) output);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.copy(srcX, srcY, dstX, dstY, width, height, (GrayF32) input, (GrayF32) output);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.copy(srcX, srcY, dstX, dstY, width, height, (GrayF64) input, (GrayF64) output);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar mi = (Planar)input;
Planar mo = (Planar)output;
for( int i = 0; i < mi.getNumBands(); i++ )
copy(srcX,srcY,dstX,dstY,width,height,mi.getBand(i),mo.getBand(i));
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Computes the mean of the absolute value of the difference between the two images.
*
* @param input Input image. Not modified.
* @param value fill value
*/
public static void fill( ImageBase input , double value ) {
if( input instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((GrayI8) input, (int) value);
} else if( GrayI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((GrayI16) input, (int) value);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.fill((GrayS32) input, (int) value);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.fill((GrayS64) input, (long) value);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.fill((GrayF32) input, (float) value);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.fill((GrayF64) input, value);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof ImageInterleaved ) {
if( InterleavedI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((InterleavedI8)input,(int)value);
} else if( InterleavedI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((InterleavedI16)input,(int)value);
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedS32)input,(int)value);
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedS64)input,(long)value);
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedF32)input,(float)value);
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedF64)input,value);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar)input;
for( int i = 0; i < m.getNumBands(); i++ )
fill(m.getBand(i),value);
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Computes the mean of the absolute value of the difference between the two images.
*
* @param input Input image. Not modified.
* @param values Array which contains the values each band is to be filled with.
*/
public static void fill( ImageBase input , double[] values ) {
if( input instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((GrayI8) input, (int) values[0]);
} else if( GrayI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((GrayI16) input, (int) values[0]);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.fill((GrayS32) input, (int) values[0]);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.fill((GrayS64) input, (long) values[0]);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.fill((GrayF32) input, (float) values[0]);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.fill((GrayF64) input, values[0]);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof ImageInterleaved ) {
if( InterleavedI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((InterleavedI8)input, BoofMiscOps.convertArray(values,(int[])null));
} else if( InterleavedI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fill((InterleavedI16)input, BoofMiscOps.convertArray(values,(int[])null));
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedS32)input,BoofMiscOps.convertArray(values,(int[])null));
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedS64)input,BoofMiscOps.convertArray(values,(long[])null) );
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedF32)input,BoofMiscOps.convertArray(values,(float[])null));
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.fill((InterleavedF64)input,values);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar)input;
for( int i = 0; i < m.getNumBands(); i++ )
fill(m.getBand(i),values[i]);
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Computes the mean of the absolute value of the difference between the two images.
*
* @param input An image.
* @param band Which band is to be filled with the specified value
* @param value The value that the image is being filled with.
*/
public static void fillBand( ImageMultiBand input , int band , double value ) {
if( input instanceof ImageInterleaved ) {
if( InterleavedI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillBand((InterleavedI8) input, band, (int) value);
} else if( InterleavedI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillBand((InterleavedI16) input, band, (int) value);
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.fillBand((InterleavedS32) input, band, (int) value);
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.fillBand((InterleavedS64) input, band, (long) value);
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.fillBand((InterleavedF32) input, band, (float) value);
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.fillBand((InterleavedF64) input, band, value);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar)input;
fill(m.getBand(band),value);
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Computes the mean of the absolute value of the difference between the two images.
*
* @param input Single band image
* @param band Which band the image is to be inserted into
* @param output The multi-band image which the input image is to be inserted into
*/
public static void insertBand(ImageGray input , int band , ImageMultiBand output ) {
if( output instanceof ImageInterleaved ) {
if( InterleavedI8.class.isAssignableFrom(output.getClass()) ) {
ImageMiscOps.insertBand((GrayI8) input, band, (InterleavedI8) output);
} else if( InterleavedI16.class.isAssignableFrom(output.getClass()) ) {
ImageMiscOps.insertBand((GrayI16) input, band, (InterleavedI16) output);
} else if( InterleavedS32.class == output.getClass() ) {
ImageMiscOps.insertBand((GrayS32) input, band, (InterleavedS32) output);
} else if( InterleavedS64.class == output.getClass() ) {
ImageMiscOps.insertBand((GrayS64) input, band, (InterleavedS64) output);
} else if( InterleavedF32.class == output.getClass() ) {
ImageMiscOps.insertBand((GrayF32) input, band, (InterleavedF32) output);
} else if( InterleavedF64.class == output.getClass() ) {
ImageMiscOps.insertBand((GrayF64) input, band, (InterleavedF64) output);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( output instanceof Planar) {
Planar m = (Planar)output;
m.getBand(band).setTo(input);
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Fills the outside border with the specified value
*
* @param input An image.
* @param value The value that the image is being filled with.
* @param radius Border width.
*/
public static void fillBorder( ImageBase input , double value , int radius ) {
if( input instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillBorder((GrayI8) input, (int) value, radius);
} else if( GrayI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillBorder((GrayI16) input, (int) value, radius);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.fillBorder((GrayS32) input, (int) value, radius);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.fillBorder((GrayS64) input, (long) value, radius);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.fillBorder((GrayF32) input, (float) value, radius);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.fillBorder((GrayF64) input, value, radius);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar)input;
for( int i = 0; i < m.getNumBands(); i++ )
fillBorder(m.getBand(i), value, radius);
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Draws a filled rectangle that is aligned along the image axis inside the image.
*
* @param input Image the rectangle is drawn in. Modified
* @param value Value of the rectangle
* @param x0 Top left x-coordinate
* @param y0 Top left y-coordinate
* @param width Rectangle width
* @param height Rectangle height
*/
public static void fillRectangle( ImageBase input , double value, int x0, int y0, int width, int height ) {
if( input instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillRectangle((GrayI8) input, (int) value, x0, y0, width, height);
} else if( GrayI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillRectangle((GrayI16) input, (int) value, x0, y0, width, height);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.fillRectangle((GrayS32) input, (int) value, x0, y0, width, height);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.fillRectangle((GrayS64) input, (long) value, x0, y0, width, height);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.fillRectangle((GrayF32) input, (float) value, x0, y0, width, height);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.fillRectangle((GrayF64) input, value, x0, y0, width, height);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar) input;
for (int i = 0; i < m.getNumBands(); i++)
fillRectangle(m.getBand(i), value, x0, y0, width, height);
} else if( input instanceof ImageInterleaved ) {
if( InterleavedI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillRectangle((InterleavedI8) input, (byte) value, x0, y0, width, height);
} else if( InterleavedI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillRectangle((InterleavedI16) input, (short) value, x0, y0, width, height);
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.fillRectangle((InterleavedS32) input, (int) value, x0, y0, width, height);
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.fillRectangle((InterleavedS64) input, (long) value, x0, y0, width, height);
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.fillRectangle((InterleavedF32) input, (float) value, x0, y0, width, height);
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.fillRectangle((InterleavedF64) input, value, x0, y0, width, height);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Sets each value in the image to a value drawn from a Gaussian distribution. A user
* specified lower and upper bound is provided to ensure that the values are within a legal
* range. A drawn value outside the allowed range will be set to the closest bound.
*
* @param input Input image. Modified.
* @param rand Random number generator
* @param mean Distribution's mean.
* @param sigma Distribution's standard deviation.
* @param lowerBound Lower bound of value clip
* @param upperBound Upper bound of value clip
*/
public static void fillGaussian( ImageBase input , Random rand , double mean , double sigma , double lowerBound , double upperBound ) {
if( input instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillGaussian((GrayI8) input, rand, mean, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillGaussian((GrayI16) input, rand, mean, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.fillGaussian((GrayS32) input, rand, mean, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.fillGaussian((GrayS64) input, rand, mean, sigma, (long) lowerBound, (long) upperBound);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.fillGaussian((GrayF32) input, rand, mean, sigma, (float) lowerBound, (float) upperBound);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.fillGaussian((GrayF64) input, rand, mean, sigma, lowerBound, upperBound);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar) input;
for (int i = 0; i < m.getNumBands(); i++)
fillGaussian(input, rand, mean, sigma, lowerBound, upperBound);
} else if( input instanceof ImageInterleaved ) {
if( InterleavedI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillGaussian((InterleavedI8) input, rand, mean, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillGaussian((InterleavedI16) input, rand, mean, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.fillGaussian((InterleavedS32) input, rand, mean, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.fillGaussian((InterleavedS64) input, rand, mean, sigma, (long) lowerBound, (long) upperBound);
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.fillGaussian((InterleavedF32) input, rand, mean, sigma, (float) lowerBound, (float) upperBound);
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.fillGaussian((InterleavedF64) input, rand, mean, sigma, lowerBound, upperBound);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Sets each value in the image to a value drawn from an uniform distribution that has a range of min ≤ X < max.
*
* @param input Image which is to be filled. Modified,
* @param rand Random number generator
* @param min Minimum value of the distribution. Inclusive.
* @param max Maximum value of the distribution. Inclusive.
*/
public static void fillUniform( ImageBase input , Random rand , double min , double max ) {
if( input instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillUniform((GrayI8) input, rand, (int) min, ((int) max) - 1);
} else if( GrayI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillUniform((GrayI16) input, rand, (int) min, ((int) max) - 1);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.fillUniform((GrayS32) input, rand, (int) min, ((int) max) - 1);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.fillUniform((GrayS64) input, rand, (long) min, ((long) max) - 1);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.fillUniform((GrayF32) input, rand, (float) min, (float) max);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.fillUniform((GrayF64) input, rand, min, max);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof ImageInterleaved ) {
if( InterleavedI8.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillUniform((InterleavedI8)input,rand, (int) min, ((int)max)-1);
} else if( InterleavedI16.class.isAssignableFrom(input.getClass()) ) {
ImageMiscOps.fillUniform((InterleavedI16)input,rand, (int) min, ((int)max)-1);
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.fillUniform((InterleavedS32)input,rand, (int) min, ((int)max)-1);
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.fillUniform((InterleavedS64)input,rand, (long) min, ((long)max)-1);
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.fillUniform((InterleavedF32)input,rand, (float)min, (float) max);
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.fillUniform((InterleavedF64)input,rand, min, max);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar)input;
for( int i = 0; i < m.getNumBands(); i++ )
fillUniform(m.getBand(i), rand , min, max);
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Adds Gaussian/normal i.i.d noise to each pixel in the image. If a value exceeds the specified
* it will be set to the closest bound.
*
* @param input Input image. Modified.
* @param rand Random number generator.
* @param sigma Distributions standard deviation.
* @param lowerBound Allowed lower bound
* @param upperBound Allowed upper bound
*/
public static void addGaussian( ImageBase input, Random rand , double sigma ,
double lowerBound , double upperBound )
{
if( input instanceof ImageGray) {
if( GrayU8.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayU8) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayS8.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayS8) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayU16.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayU16) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayS16.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayS16) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayS32) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayS64) input, rand, sigma, (long) lowerBound, (long) upperBound);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayF32) input, rand, sigma, (float) lowerBound, (float) upperBound);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.addGaussian((GrayF64) input, rand, sigma, lowerBound, upperBound);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar) input;
for (int i = 0; i < m.getNumBands(); i++)
addGaussian(m.getBand(i), rand, sigma, lowerBound, upperBound);
} else if( input instanceof ImageInterleaved ) {
if( InterleavedU8.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedU8) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedS8.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedS8) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedU16.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedU16) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedS16.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedS16) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedS32) input, rand, sigma, (int) lowerBound, (int) upperBound);
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedS64) input, rand, sigma, (long) lowerBound, (long) upperBound);
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedF32) input, rand, sigma, (float) lowerBound, (float) upperBound);
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.addGaussian((InterleavedF64) input, rand, sigma, lowerBound, upperBound);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Adds uniform i.i.d noise to each pixel in the image. Noise range is min ≤ X < max.
*/
public static void addUniform( ImageBase input, Random rand , double min , double max ) {
if( input instanceof ImageGray) {
if( GrayU8.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayU8) input, rand, (int) min, (int) max);
} else if( GrayS8.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayS8) input, rand, (int) min, (int) max);
} else if( GrayU16.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayU16) input, rand, (int) min, (int) max);
} else if( GrayS16.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayS16) input, rand, (int) min, (int) max);
} else if( GrayS32.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayS32) input, rand, (int) min, (int) max);
} else if( GrayS64.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayS64) input, rand, (long) min, (long) max);
} else if( GrayF32.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayF32) input, rand, (float) min, (float) max);
} else if( GrayF64.class == input.getClass() ) {
ImageMiscOps.addUniform((GrayF64) input, rand, min, max);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else if( input instanceof Planar) {
Planar m = (Planar) input;
for (int i = 0; i < m.getNumBands(); i++)
addUniform(m.getBand(i), rand, min, max);
} else if( input instanceof ImageInterleaved ) {
if( InterleavedU8.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedU8) input, rand, (int) min, (int) max);
} else if( InterleavedS8.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedS8) input, rand, (int) min, (int) max);
} else if( InterleavedU16.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedU16) input, rand, (int) min, (int) max);
} else if( InterleavedS16.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedS16) input, rand, (int) min, (int) max);
} else if( InterleavedS32.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedS32) input, rand, (int) min, (int) max);
} else if( InterleavedS64.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedS64) input, rand, (long) min, (long) max);
} else if( InterleavedF32.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedF32) input, rand, (float) min, (float) max);
} else if( InterleavedF64.class == input.getClass() ) {
ImageMiscOps.addUniform((InterleavedF64) input, rand, min, max);
} else {
throw new IllegalArgumentException("Unknown image Type: "+input.getClass().getSimpleName());
}
} else {
throw new IllegalArgumentException("Unknown image type: " + input.getClass().getSimpleName());
}
}
/**
* Flips the image from top to bottom
*/
public static void flipVertical( ImageBase img ) {
if( img instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipVertical((GrayI8) img);
} else if( GrayI16.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipVertical((GrayI16) img);
} else if ( GrayS32.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipVertical((GrayS32) img);
} else if ( GrayS64.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipVertical((GrayS64) img);
} else if (GrayF32.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipVertical((GrayF32) img);
} else if (GrayF64.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipVertical((GrayF64) img);
} else if (GrayS64.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipVertical((GrayS64) img);
} else {
throw new IllegalArgumentException("Unknown or incompatible image type: " + img.getClass().getSimpleName());
}
} else if( img instanceof Planar) {
Planar m = (Planar)img;
for( int i = 0; i < m.getNumBands(); i++ )
flipVertical(m.getBand(i));
} else {
throw new IllegalArgumentException("Unknown image type: " + img.getClass().getSimpleName());
}
}
/**
* Flips the image from left to right
*/
public static void flipHorizontal( ImageBase img ) {
if( img instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipHorizontal((GrayI8) img);
} else if( GrayI16.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipHorizontal((GrayI16) img);
} else if ( GrayS32.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipHorizontal((GrayS32) img);
} else if ( GrayS64.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipHorizontal((GrayS64) img);
} else if (GrayF32.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipHorizontal((GrayF32) img);
} else if (GrayF64.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipHorizontal((GrayF64) img);
} else if (GrayS64.class.isAssignableFrom(img.getClass()) ) {
ImageMiscOps.flipHorizontal((GrayS64) img);
} else {
throw new IllegalArgumentException("Unknown or incompatible image type: " + img.getClass().getSimpleName());
}
} else if( img instanceof Planar) {
Planar m = (Planar)img;
for( int i = 0; i < m.getNumBands(); i++ )
flipHorizontal(m.getBand(i));
} else {
throw new IllegalArgumentException("Unknown image type: " + img.getClass().getSimpleName());
}
}
/**
* In-place 90 degree image rotation in the clockwise direction. Only works on
* square images.
*/
public static void rotateCW( ImageBase image ) {
if( image instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCW((GrayI8) image);
} else if( GrayI16.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCW((GrayI16) image);
} else if ( GrayS32.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCW((GrayS32) image);
} else if ( GrayS64.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCW((GrayS64) image);
} else if (GrayF32.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCW((GrayF32) image);
} else if (GrayF64.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCW((GrayF64) image);
} else if (GrayS64.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCW((GrayS64) image);
} else {
throw new IllegalArgumentException("Unknown or incompatible image type: " + image.getClass().getSimpleName());
}
} else if( image instanceof Planar) {
Planar a = (Planar)image;
for( int i = 0; i < a.getNumBands(); i++ )
rotateCW(a.getBand(i));
} else {
throw new IllegalArgumentException("Unknown image type: " + image.getClass().getSimpleName());
}
}
/**
* Rotates the image 90 degrees in the clockwise direction.
*/
public static void rotateCW( ImageBase imageA , ImageBase imageB ) {
if( imageA instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCW((GrayI8) imageA, (GrayI8) imageB);
} else if( GrayI16.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCW((GrayI16) imageA, (GrayI16) imageB);
} else if ( GrayS32.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCW((GrayS32) imageA, (GrayS32) imageB);
} else if ( GrayS64.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCW((GrayS64) imageA, (GrayS64) imageB);
} else if (GrayF32.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCW((GrayF32) imageA, (GrayF32) imageB);
} else if (GrayF64.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCW((GrayF64) imageA, (GrayF64) imageB);
} else if (GrayS64.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCW((GrayS64) imageA, (GrayS64) imageB);
} else {
throw new IllegalArgumentException("Unknown or incompatible image type: " + imageA.getClass().getSimpleName());
}
} else if( imageA instanceof Planar) {
Planar a = (Planar)imageA;
Planar b = (Planar)imageB;
for( int i = 0; i < a.getNumBands(); i++ )
rotateCW(a.getBand(i), b.getBand(i));
} else {
throw new IllegalArgumentException("Unknown image type: " + imageA.getClass().getSimpleName());
}
}
/**
* In-place 90 degree image rotation in the counter-clockwise direction. Only works on
* square images.
*/
public static void rotateCCW( ImageBase image ) {
if( image instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCCW((GrayI8) image);
} else if( GrayI16.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCCW((GrayI16) image);
} else if ( GrayS32.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCCW((GrayS32) image);
} else if ( GrayS64.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCCW((GrayS64) image);
} else if (GrayF32.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCCW((GrayF32) image);
} else if (GrayF64.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCCW((GrayF64) image);
} else if (GrayS64.class.isAssignableFrom(image.getClass()) ) {
ImageMiscOps.rotateCCW((GrayS64) image);
} else {
throw new IllegalArgumentException("Unknown or incompatible image type: " + image.getClass().getSimpleName());
}
} else if( image instanceof Planar) {
Planar a = (Planar)image;
for( int i = 0; i < a.getNumBands(); i++ )
rotateCCW(a.getBand(i));
} else {
throw new IllegalArgumentException("Unknown image type: " + image.getClass().getSimpleName());
}
}
/**
* Rotates the image 90 degrees in the counter-clockwise direction.
*/
public static void rotateCCW( ImageBase imageA , ImageBase imageB ) {
if( imageA instanceof ImageGray) {
if( GrayI8.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCCW((GrayI8) imageA, (GrayI8) imageB);
} else if( GrayI16.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCCW((GrayI16) imageA, (GrayI16) imageB);
} else if ( GrayS32.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCCW((GrayS32) imageA, (GrayS32) imageB);
} else if ( GrayS64.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCCW((GrayS64) imageA, (GrayS64) imageB);
} else if (GrayF32.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCCW((GrayF32) imageA, (GrayF32) imageB);
} else if (GrayF64.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCCW((GrayF64) imageA, (GrayF64) imageB);
} else if (GrayS64.class.isAssignableFrom(imageA.getClass()) ) {
ImageMiscOps.rotateCCW((GrayS64) imageA,(GrayS64) imageB);
} else {
throw new IllegalArgumentException("Unknown or incompatible image type: " + imageA.getClass().getSimpleName());
}
} else if( imageA instanceof Planar) {
Planar a = (Planar)imageA;
Planar b = (Planar)imageB;
for( int i = 0; i < a.getNumBands(); i++ )
rotateCCW(a.getBand(i), b.getBand(i));
} else {
throw new IllegalArgumentException("Unknown image type: " + imageA.getClass().getSimpleName());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy