All Downloads are FREE. Search and download functionalities are using the official Maven repository.

boofcv.alg.misc.GImageMiscOps Maven / Gradle / Ivy

Go to download

BoofCV is an open source Java library for real-time computer vision and robotics applications.

There is a newer version: 0.26
Show newest version
/*
 * 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