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

boofcv.alg.misc.PixelMath 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.alg.InputSanityCheck;
import boofcv.struct.image.*;

import javax.annotation.Generated;

/**
 * Functions which perform basic arithmetic (e.g. addition, subtraction, multiplication, or division) on a pixel by pixel basis.
 *
 * 

DO NOT MODIFY: Generated by boofcv.alg.misc.GeneratePixelMath.

* * @author Peter Abeles */ @Generated("boofcv.alg.misc.GeneratePixelMath") public class PixelMath { /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs(GrayS8 input , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs( InterleavedS8 input , InterleavedS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void abs( byte[] input , int inputStart , int inputStride , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)Math.abs(input[indexSrc]); } } } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs(GrayS16 input , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs( InterleavedS16 input , InterleavedS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void abs( short[] input , int inputStart , int inputStride , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)Math.abs(input[indexSrc]); } } } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs(GrayS32 input , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs( InterleavedS32 input , InterleavedS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void abs( int[] input , int inputStart , int inputStride , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = Math.abs(input[indexSrc]); } } } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs(GrayS64 input , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs( InterleavedS64 input , InterleavedS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void abs( long[] input , int inputStart , int inputStride , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = Math.abs(input[indexSrc]); } } } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs(GrayF32 input , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs( InterleavedF32 input , InterleavedF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void abs( float[] input , int inputStart , int inputStride , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = Math.abs(input[indexSrc]); } } } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs(GrayF64 input , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Sets each pixel in the output image to be the absolute value of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the absolute value image is written to. Modified. */ public static void abs( InterleavedF64 input , InterleavedF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; abs(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void abs( double[] input , int inputStart , int inputStride , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = Math.abs(input[indexSrc]); } } } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert(GrayS8 input , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert( InterleavedS8 input , InterleavedS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void invert( byte[] input , int inputStart , int inputStride , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)-input[indexSrc]; } } } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert(GrayS16 input , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert( InterleavedS16 input , InterleavedS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void invert( short[] input , int inputStart , int inputStride , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)-input[indexSrc]; } } } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert(GrayS32 input , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert( InterleavedS32 input , InterleavedS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void invert( int[] input , int inputStart , int inputStride , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = -input[indexSrc]; } } } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert(GrayS64 input , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert( InterleavedS64 input , InterleavedS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void invert( long[] input , int inputStart , int inputStride , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = -input[indexSrc]; } } } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert(GrayF32 input , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert( InterleavedF32 input , InterleavedF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void invert( float[] input , int inputStart , int inputStride , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = -input[indexSrc]; } } } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert(GrayF64 input , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } /** * Changes the sign of every pixel in the image: output[x,y] = -input[x,y] * * @param input The input image. Not modified. * @param output Where the inverted image is written to. Modified. */ public static void invert( InterleavedF64 input , InterleavedF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; invert(input.data,input.startIndex,input.stride, output.data,output.startIndex,output.stride, input.height,columns); } private static void invert( double[] input , int inputStart , int inputStride , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = -input[indexSrc]; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayU8 input , double value , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiplyU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedU8 input , double value , InterleavedU8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiplyU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiplyU_A( byte[] input , int inputStart , int inputStride , double value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)Math.round((input[indexSrc] & 0xFF) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS8 input , double value , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS8 input , double value , InterleavedS8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( byte[] input , int inputStart , int inputStride , double value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)Math.round((input[indexSrc] ) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayU16 input , double value , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiplyU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedU16 input , double value , InterleavedU16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiplyU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiplyU_A( short[] input , int inputStart , int inputStride , double value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)Math.round((input[indexSrc] & 0xFFFF) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS16 input , double value , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS16 input , double value , InterleavedS16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( short[] input , int inputStart , int inputStride , double value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)Math.round((input[indexSrc] ) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS32 input , double value , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS32 input , double value , InterleavedS32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( int[] input , int inputStart , int inputStride , double value , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (int)Math.round((input[indexSrc] ) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS64 input , double value , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS64 input , double value , InterleavedS64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( long[] input , int inputStart , int inputStride , double value , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (long)Math.round((input[indexSrc] ) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayF32 input , float value , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedF32 input , float value , InterleavedF32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( float[] input , int inputStart , int inputStride , float value , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayF64 input , double value , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedF64 input , double value , InterleavedF64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( double[] input , int inputStart , int inputStride , double value , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) * value); } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayU8 input , double value , int lower , int upper , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiplyU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedU8 input , double value , int lower , int upper , InterleavedU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiplyU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiplyU_A( byte[] input , int inputStart , int inputStride , double value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] & 0xFF) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS8 input , double value , int lower , int upper , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS8 input , double value , int lower , int upper , InterleavedS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( byte[] input , int inputStart , int inputStride , double value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] ) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayU16 input , double value , int lower , int upper , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiplyU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedU16 input , double value , int lower , int upper , InterleavedU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiplyU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiplyU_A( short[] input , int inputStart , int inputStride , double value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] & 0xFFFF) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS16 input , double value , int lower , int upper , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS16 input , double value , int lower , int upper , InterleavedS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( short[] input , int inputStart , int inputStride , double value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] ) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS32 input , double value , int lower , int upper , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS32 input , double value , int lower , int upper , InterleavedS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( int[] input , int inputStart , int inputStride , double value , int lower , int upper , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] ) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayS64 input , double value , long lower , long upper , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedS64 input , double value , long lower , long upper , InterleavedS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( long[] input , int inputStart , int inputStride , double value , long lower , long upper , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { long val = (long)Math.round((input[indexSrc] ) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayF32 input , float value , float lower , float upper , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedF32 input , float value , float lower , float upper , InterleavedF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( float[] input , int inputStart , int inputStride , float value , float lower , float upper , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { float val = ((input[indexSrc] ) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply(GrayF64 input , double value , double lower , double upper , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Multiply each element by a scalar value. Both input and output images can * be the same instance. * * @param input The input image. Not modified. * @param value What each element is multiplied by. * @param output The output image. Modified. */ public static void multiply( InterleavedF64 input , double value , double lower , double upper , InterleavedF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; multiply_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void multiply_A( double[] input , int inputStart , int inputStride , double value , double lower , double upper , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { double val = ((input[indexSrc] ) * value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayU8 input , double denominator , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divideU_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedU8 input , double denominator , InterleavedU8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divideU_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divideU_A( byte[] input , int inputStart , int inputStride , double denominator , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)Math.round((input[indexSrc] & 0xFF) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS8 input , double denominator , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS8 input , double denominator , InterleavedS8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( byte[] input , int inputStart , int inputStride , double denominator , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)Math.round((input[indexSrc] ) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayU16 input , double denominator , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divideU_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedU16 input , double denominator , InterleavedU16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divideU_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divideU_A( short[] input , int inputStart , int inputStride , double denominator , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)Math.round((input[indexSrc] & 0xFFFF) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS16 input , double denominator , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS16 input , double denominator , InterleavedS16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( short[] input , int inputStart , int inputStride , double denominator , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)Math.round((input[indexSrc] ) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS32 input , double denominator , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS32 input , double denominator , InterleavedS32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( int[] input , int inputStart , int inputStride , double denominator , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (int)Math.round((input[indexSrc] ) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS64 input , double denominator , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS64 input , double denominator , InterleavedS64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( long[] input , int inputStart , int inputStride , double denominator , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (long)Math.round((input[indexSrc] ) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayF32 input , float denominator , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedF32 input , float denominator , InterleavedF32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( float[] input , int inputStart , int inputStride , float denominator , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayF64 input , double denominator , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedF64 input , double denominator , InterleavedF64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( double[] input , int inputStart , int inputStride , double denominator , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) / denominator); } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayU8 input , double denominator , int lower , int upper , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divideU_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedU8 input , double denominator , int lower , int upper , InterleavedU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divideU_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divideU_A( byte[] input , int inputStart , int inputStride , double denominator , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] & 0xFF) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS8 input , double denominator , int lower , int upper , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS8 input , double denominator , int lower , int upper , InterleavedS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( byte[] input , int inputStart , int inputStride , double denominator , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] ) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayU16 input , double denominator , int lower , int upper , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divideU_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedU16 input , double denominator , int lower , int upper , InterleavedU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divideU_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divideU_A( short[] input , int inputStart , int inputStride , double denominator , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] & 0xFFFF) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS16 input , double denominator , int lower , int upper , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS16 input , double denominator , int lower , int upper , InterleavedS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( short[] input , int inputStart , int inputStride , double denominator , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] ) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS32 input , double denominator , int lower , int upper , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS32 input , double denominator , int lower , int upper , InterleavedS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( int[] input , int inputStart , int inputStride , double denominator , int lower , int upper , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (int)Math.round((input[indexSrc] ) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayS64 input , double denominator , long lower , long upper , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedS64 input , double denominator , long lower , long upper , InterleavedS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( long[] input , int inputStart , int inputStride , double denominator , long lower , long upper , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { long val = (long)Math.round((input[indexSrc] ) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayF32 input , float denominator , float lower , float upper , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedF32 input , float denominator , float lower , float upper , InterleavedF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( float[] input , int inputStart , int inputStride , float denominator , float lower , float upper , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { float val = ((input[indexSrc] ) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide(GrayF64 input , double denominator , double lower , double upper , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Divide each element by a scalar value. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param denominator What each element is divided by. * @param output The output image. Modified. */ public static void divide( InterleavedF64 input , double denominator , double lower , double upper , InterleavedF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; divide_A(input.data,input.startIndex,input.stride,denominator, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void divide_A( double[] input , int inputStart , int inputStride , double denominator , double lower , double upper , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { double val = ((input[indexSrc] ) / denominator); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayU8 input , int value , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedU8 input , int value , InterleavedU8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plusU_A( byte[] input , int inputStart , int inputStride , int value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)((input[indexSrc] & 0xFF) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS8 input , int value , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS8 input , int value , InterleavedS8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( byte[] input , int inputStart , int inputStride , int value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)((input[indexSrc] ) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayU16 input , int value , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedU16 input , int value , InterleavedU16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plusU_A( short[] input , int inputStart , int inputStride , int value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)((input[indexSrc] & 0xFFFF) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS16 input , int value , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS16 input , int value , InterleavedS16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( short[] input , int inputStart , int inputStride , int value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)((input[indexSrc] ) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS32 input , int value , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS32 input , int value , InterleavedS32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( int[] input , int inputStart , int inputStride , int value , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS64 input , long value , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS64 input , long value , InterleavedS64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( long[] input , int inputStart , int inputStride , long value , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayF32 input , float value , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedF32 input , float value , InterleavedF32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( float[] input , int inputStart , int inputStride , float value , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayF64 input , double value , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedF64 input , double value , InterleavedF64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( double[] input , int inputStart , int inputStride , double value , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) + value); } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayU8 input , int value , int lower , int upper , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedU8 input , int value , int lower , int upper , InterleavedU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plusU_A( byte[] input , int inputStart , int inputStride , int value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] & 0xFF) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS8 input , int value , int lower , int upper , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS8 input , int value , int lower , int upper , InterleavedS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( byte[] input , int inputStart , int inputStride , int value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] ) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayU16 input , int value , int lower , int upper , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedU16 input , int value , int lower , int upper , InterleavedU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plusU_A( short[] input , int inputStart , int inputStride , int value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] & 0xFFFF) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS16 input , int value , int lower , int upper , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS16 input , int value , int lower , int upper , InterleavedS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( short[] input , int inputStart , int inputStride , int value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] ) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS32 input , int value , int lower , int upper , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS32 input , int value , int lower , int upper , InterleavedS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( int[] input , int inputStart , int inputStride , int value , int lower , int upper , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] ) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayS64 input , long value , long lower , long upper , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedS64 input , long value , long lower , long upper , InterleavedS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( long[] input , int inputStart , int inputStride , long value , long lower , long upper , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { long val = ((input[indexSrc] ) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayF32 input , float value , float lower , float upper , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedF32 input , float value , float lower , float upper , InterleavedF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( float[] input , int inputStart , int inputStride , float value , float lower , float upper , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { float val = ((input[indexSrc] ) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus(GrayF64 input , double value , double lower , double upper , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Adds a scalar value to each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is added to each element. * @param output The output image. Modified. */ public static void plus( InterleavedF64 input , double value , double lower , double upper , InterleavedF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; plus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void plus_A( double[] input , int inputStart , int inputStride , double value , double lower , double upper , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { double val = ((input[indexSrc] ) + value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayU8 input , int value , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedU8 input , int value , InterleavedU8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_A( byte[] input , int inputStart , int inputStride , int value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)((input[indexSrc] & 0xFF) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS8 input , int value , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS8 input , int value , InterleavedS8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( byte[] input , int inputStart , int inputStride , int value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)((input[indexSrc] ) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayU16 input , int value , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedU16 input , int value , InterleavedU16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minusU_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_A( short[] input , int inputStart , int inputStride , int value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)((input[indexSrc] & 0xFFFF) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS16 input , int value , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS16 input , int value , InterleavedS16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( short[] input , int inputStart , int inputStride , int value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)((input[indexSrc] ) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS32 input , int value , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS32 input , int value , InterleavedS32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( int[] input , int inputStart , int inputStride , int value , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS64 input , long value , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS64 input , long value , InterleavedS64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( long[] input , int inputStart , int inputStride , long value , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayF32 input , float value , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedF32 input , float value , InterleavedF32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( float[] input , int inputStart , int inputStride , float value , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayF64 input , double value , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedF64 input , double value , InterleavedF64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( double[] input , int inputStart , int inputStride , double value , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = ((input[indexSrc] ) - value); } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayU8 input , int value , int lower , int upper , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedU8 input , int value , int lower , int upper , InterleavedU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_A( byte[] input , int inputStart , int inputStride , int value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] & 0xFF) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS8 input , int value , int lower , int upper , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS8 input , int value , int lower , int upper , InterleavedS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( byte[] input , int inputStart , int inputStride , int value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] ) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayU16 input , int value , int lower , int upper , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedU16 input , int value , int lower , int upper , InterleavedU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minusU_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_A( short[] input , int inputStart , int inputStride , int value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] & 0xFFFF) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS16 input , int value , int lower , int upper , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS16 input , int value , int lower , int upper , InterleavedS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( short[] input , int inputStart , int inputStride , int value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] ) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS32 input , int value , int lower , int upper , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS32 input , int value , int lower , int upper , InterleavedS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( int[] input , int inputStart , int inputStride , int value , int lower , int upper , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = ((input[indexSrc] ) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayS64 input , long value , long lower , long upper , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedS64 input , long value , long lower , long upper , InterleavedS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( long[] input , int inputStart , int inputStride , long value , long lower , long upper , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { long val = ((input[indexSrc] ) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayF32 input , float value , float lower , float upper , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedF32 input , float value , float lower , float upper , InterleavedF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( float[] input , int inputStart , int inputStride , float value , float lower , float upper , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { float val = ((input[indexSrc] ) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus(GrayF64 input , double value , double lower , double upper , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts a scalar value from each element. Both input and output images can be the same instance. * * @param input The input image. Not modified. * @param value What is subtracted from each element. * @param output The output image. Modified. */ public static void minus( InterleavedF64 input , double value , double lower , double upper , InterleavedF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_A(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_A( double[] input , int inputStart , int inputStride , double value , double lower , double upper , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { double val = ((input[indexSrc] ) - value); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayU8 input , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedU8 input , InterleavedU8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minusU_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_B( byte[] input , int inputStart , int inputStride , int value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)(value - (input[indexSrc] & 0xFF)); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayS8 input , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedS8 input , InterleavedS8 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( byte[] input , int inputStart , int inputStride , int value , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (byte)(value - (input[indexSrc] )); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayU16 input , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedU16 input , InterleavedU16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minusU_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_B( short[] input , int inputStart , int inputStride , int value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)(value - (input[indexSrc] & 0xFFFF)); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayS16 input , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedS16 input , InterleavedS16 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( short[] input , int inputStart , int inputStride , int value , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (short)(value - (input[indexSrc] )); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayS32 input , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedS32 input , InterleavedS32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( int[] input , int inputStart , int inputStride , int value , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (value - (input[indexSrc] )); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(long value , GrayS64 input , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( long value , InterleavedS64 input , InterleavedS64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( long[] input , int inputStart , int inputStride , long value , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (value - (input[indexSrc] )); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(float value , GrayF32 input , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( float value , InterleavedF32 input , InterleavedF32 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( float[] input , int inputStart , int inputStride , float value , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (value - (input[indexSrc] )); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(double value , GrayF64 input , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( double value , InterleavedF64 input , InterleavedF64 output ) { InputSanityCheck.checkSameShapeB(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( double[] input , int inputStart , int inputStride , double value , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { output[indexDst] = (value - (input[indexSrc] )); } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayU8 input , int lower , int upper , GrayU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedU8 input , int lower , int upper , InterleavedU8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minusU_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_B( byte[] input , int inputStart , int inputStride , int value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (value - (input[indexSrc] & 0xFF)); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayS8 input , int lower , int upper , GrayS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedS8 input , int lower , int upper , InterleavedS8 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( byte[] input , int inputStart , int inputStride , int value , int lower , int upper , byte[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (value - (input[indexSrc] )); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (byte)val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayU16 input , int lower , int upper , GrayU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minusU_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedU16 input , int lower , int upper , InterleavedU16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minusU_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minusU_B( short[] input , int inputStart , int inputStride , int value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (value - (input[indexSrc] & 0xFFFF)); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayS16 input , int lower , int upper , GrayS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedS16 input , int lower , int upper , InterleavedS16 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( short[] input , int inputStart , int inputStride , int value , int lower , int upper , short[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (value - (input[indexSrc] )); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = (short)val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(int value , GrayS32 input , int lower , int upper , GrayS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( int value , InterleavedS32 input , int lower , int upper , InterleavedS32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( int[] input , int inputStart , int inputStride , int value , int lower , int upper , int[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { int val = (value - (input[indexSrc] )); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(long value , GrayS64 input , long lower , long upper , GrayS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( long value , InterleavedS64 input , long lower , long upper , InterleavedS64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( long[] input , int inputStart , int inputStride , long value , long lower , long upper , long[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { long val = (value - (input[indexSrc] )); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(float value , GrayF32 input , float lower , float upper , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( float value , InterleavedF32 input , float lower , float upper , InterleavedF32 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( float[] input , int inputStart , int inputStride , float value , float lower , float upper , float[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { float val = (value - (input[indexSrc] )); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus(double value , GrayF64 input , double lower , double upper , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } /** * Subtracts each element's value from a scalar. Both input and output images can be the same instance. * * @param value Scalar value * @param input The input image. Not modified. * @param output The output image. Modified. */ public static void minus( double value , InterleavedF64 input , double lower , double upper , InterleavedF64 output ) { InputSanityCheck.checkSameShape(input,output); int columns = input.width*input.numBands; minus_B(input.data,input.startIndex,input.stride,value, lower, upper , output.data,output.startIndex,output.stride, input.height,columns); } private static void minus_B( double[] input , int inputStart , int inputStride , double value , double lower , double upper , double[] output , int outputStart , int outputStride , int rows , int cols ) { for( int y = 0; y < rows; y++ ) { int indexSrc = inputStart + y*inputStride; int indexDst = outputStart + y*outputStride; int end = indexSrc + cols; for( ; indexSrc < end; indexSrc++ , indexDst++) { double val = (value - (input[indexSrc] )); if( val < lower ) val = lower; if( val > upper ) val = upper; output[indexDst] = val; } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayU8 img , int min , int max ) { final int h = img.getHeight(); final int w = img.getWidth(); byte[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { int value = data[index]& 0xFF; if( value < min ) data[index] = (byte)min; else if( value > max ) data[index] = (byte)max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayU8 imgA , GrayU8 imgB , GrayU8 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = (byte)Math.abs((imgA.data[indexA] & 0xFF) - (imgB.data[indexB] & 0xFF)); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayU8 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayU8[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { int total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]& 0xFF; } output.data[indexOutput] = (byte)(total / bands.length); } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayS8 img , int min , int max ) { final int h = img.getHeight(); final int w = img.getWidth(); byte[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { int value = data[index]; if( value < min ) data[index] = (byte)min; else if( value > max ) data[index] = (byte)max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayS8 imgA , GrayS8 imgB , GrayS8 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = (byte)Math.abs((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayS8 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayS8[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { int total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]; } output.data[indexOutput] = (byte)(total / bands.length); } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayU16 img , int min , int max ) { final int h = img.getHeight(); final int w = img.getWidth(); short[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { int value = data[index]& 0xFFFF; if( value < min ) data[index] = (short)min; else if( value > max ) data[index] = (short)max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayU16 imgA , GrayU16 imgB , GrayU16 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = (short)Math.abs((imgA.data[indexA] & 0xFFFF) - (imgB.data[indexB] & 0xFFFF)); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayU16 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayU16[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { int total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]& 0xFFFF; } output.data[indexOutput] = (short)(total / bands.length); } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayS16 img , int min , int max ) { final int h = img.getHeight(); final int w = img.getWidth(); short[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { int value = data[index]; if( value < min ) data[index] = (short)min; else if( value > max ) data[index] = (short)max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayS16 imgA , GrayS16 imgB , GrayS16 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = (short)Math.abs((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayS16 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayS16[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { int total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]; } output.data[indexOutput] = (short)(total / bands.length); } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayS32 img , int min , int max ) { final int h = img.getHeight(); final int w = img.getWidth(); int[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { int value = data[index]; if( value < min ) data[index] = min; else if( value > max ) data[index] = max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayS32 imgA , GrayS32 imgB , GrayS32 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = (int)Math.abs((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayS32 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayS32[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { int total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]; } output.data[indexOutput] = (total / bands.length); } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayS64 img , long min , long max ) { final int h = img.getHeight(); final int w = img.getWidth(); long[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { long value = data[index]; if( value < min ) data[index] = min; else if( value > max ) data[index] = max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayS64 imgA , GrayS64 imgB , GrayS64 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = (long)Math.abs((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayS64 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayS64[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { long total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]; } output.data[indexOutput] = (total / bands.length); } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayF32 img , float min , float max ) { final int h = img.getHeight(); final int w = img.getWidth(); float[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { float value = data[index]; if( value < min ) data[index] = min; else if( value > max ) data[index] = max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayF32 imgA , GrayF32 imgB , GrayF32 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = Math.abs((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayF32 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayF32[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { float total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]; } output.data[indexOutput] = (total / bands.length); } } } /** * Bounds image pixels to be between these two values * * @param img Image * @param min minimum value. * @param max maximum value. */ public static void boundImage(GrayF64 img , double min , double max ) { final int h = img.getHeight(); final int w = img.getWidth(); double[] data = img.data; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); int indexEnd = index+w; // for(int x = 0; x < w; x++ ) { for (; index < indexEnd; index++) { double value = data[index]; if( value < min ) data[index] = min; else if( value > max ) data[index] = max; } } } /** *

* Computes the absolute value of the difference between each pixel in the two images.
* d(x,y) = |img1(x,y) - img2(x,y)| *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param diff Absolute value of difference image. Modified. */ public static void diffAbs(GrayF64 imgA , GrayF64 imgB , GrayF64 diff ) { InputSanityCheck.checkSameShape(imgA,imgB,diff); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexDiff = diff.getStartIndex() + y * diff.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexDiff++ ) { diff.data[indexDiff] = Math.abs((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** * Computes the average for each pixel across all bands in the {@link Planar} image. * * @param input Planar image * @param output Gray scale image containing average pixel values */ public static void averageBand(Planar input , GrayF64 output ) { final int h = input.getHeight(); final int w = input.getWidth(); GrayF64[] bands = input.bands; for (int y = 0; y < h; y++) { int indexInput = input.getStartIndex() + y * input.getStride(); int indexOutput = output.getStartIndex() + y * output.getStride(); int indexEnd = indexInput+w; // for(int x = 0; x < w; x++ ) { for (; indexInput < indexEnd; indexInput++, indexOutput++ ) { double total = 0; for( int i = 0; i < bands.length; i++ ) { total += bands[i].data[ indexInput ]; } output.data[indexOutput] = (total / bands.length); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayU8 imgA , GrayU8 imgB , GrayU16 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (short)((imgA.data[indexA] & 0xFF) + (imgB.data[indexB] & 0xFF)); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayU8 imgA , GrayU8 imgB , GrayI16 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (short)((imgA.data[indexA] & 0xFF) - (imgB.data[indexB] & 0xFF)); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayS8 imgA , GrayS8 imgB , GrayS16 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (short)((imgA.data[indexA] ) + (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayS8 imgA , GrayS8 imgB , GrayS16 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (short)((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayU16 imgA , GrayU16 imgB , GrayS32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (int)((imgA.data[indexA] & 0xFFFF) + (imgB.data[indexB] & 0xFFFF)); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayU16 imgA , GrayU16 imgB , GrayS32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (int)((imgA.data[indexA] & 0xFFFF) - (imgB.data[indexB] & 0xFFFF)); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayS16 imgA , GrayS16 imgB , GrayS32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (int)((imgA.data[indexA] ) + (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayS16 imgA , GrayS16 imgB , GrayS32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (int)((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayS32 imgA , GrayS32 imgB , GrayS32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (int)((imgA.data[indexA] ) + (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayS32 imgA , GrayS32 imgB , GrayS32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (int)((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayS64 imgA , GrayS64 imgB , GrayS64 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (long)((imgA.data[indexA] ) + (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayS64 imgA , GrayS64 imgB , GrayS64 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = (long)((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayF32 imgA , GrayF32 imgB , GrayF32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) + (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayF32 imgA , GrayF32 imgB , GrayF32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise multiplication
* output(x,y) = imgA(x,y) * imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void multiply(GrayF32 imgA , GrayF32 imgB , GrayF32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) * (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise division
* output(x,y) = imgA(x,y) / imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void divide(GrayF32 imgA , GrayF32 imgB , GrayF32 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) / (imgB.data[indexB] )); } } } /** * Sets each pixel in the output image to log( 1 + input(x,y)) of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the log image is written to. Modified. */ public static void log(GrayF32 input , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); for( int y = 0; y < input.height; y++ ) { int indexSrc = input.startIndex + y* input.stride; int indexDst = output.startIndex + y* output.stride; int end = indexSrc + input.width; for( ; indexSrc < end; indexSrc++ , indexDst++) { output.data[indexDst] = (float)Math.log(1 + input.data[indexSrc]); } } } /** * Raises each pixel in the input image to the power of two. Both the input and output image can be the * same instance. * * @param input The input image. Not modified. * @param output Where the pow2 image is written to. Modified. */ public static void pow2(GrayF32 input , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); for( int y = 0; y < input.height; y++ ) { int indexSrc = input.startIndex + y* input.stride; int indexDst = output.startIndex + y* output.stride; int end = indexSrc + input.width; for( ; indexSrc < end; indexSrc++ , indexDst++) { float v = input.data[indexSrc]; output.data[indexDst] = v*v; } } } /** * Computes the square root of each pixel in the input image. Both the input and output image can be the * same instance. * * @param input The input image. Not modified. * @param output Where the sqrt() image is written to. Modified. */ public static void sqrt(GrayF32 input , GrayF32 output ) { InputSanityCheck.checkSameShape(input,output); for( int y = 0; y < input.height; y++ ) { int indexSrc = input.startIndex + y* input.stride; int indexDst = output.startIndex + y* output.stride; int end = indexSrc + input.width; for( ; indexSrc < end; indexSrc++ , indexDst++) { output.data[indexDst] = (float)Math.sqrt(input.data[indexSrc]); } } } /** *

* Performs pixel-wise addition
* output(x,y) = imgA(x,y) + imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void add(GrayF64 imgA , GrayF64 imgB , GrayF64 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) + (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise subtraction.
* output(x,y) = imgA(x,y) - imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void subtract(GrayF64 imgA , GrayF64 imgB , GrayF64 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) - (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise multiplication
* output(x,y) = imgA(x,y) * imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void multiply(GrayF64 imgA , GrayF64 imgB , GrayF64 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) * (imgB.data[indexB] )); } } } /** *

* Performs pixel-wise division
* output(x,y) = imgA(x,y) / imgB(x,y) *

* @param imgA Input image. Not modified. * @param imgB Input image. Not modified. * @param output Output image. Modified. */ public static void divide(GrayF64 imgA , GrayF64 imgB , GrayF64 output ) { InputSanityCheck.checkSameShape(imgA,imgB,output); final int h = imgA.getHeight(); final int w = imgA.getWidth(); for (int y = 0; y < h; y++) { int indexA = imgA.getStartIndex() + y * imgA.getStride(); int indexB = imgB.getStartIndex() + y * imgB.getStride(); int indexOut = output.getStartIndex() + y * output.getStride(); int indexEnd = indexA+w; // for(int x = 0; x < w; x++ ) { for (; indexA < indexEnd; indexA++, indexB++, indexOut++ ) { output.data[indexOut] = ((imgA.data[indexA] ) / (imgB.data[indexB] )); } } } /** * Sets each pixel in the output image to log( 1 + input(x,y)) of the input image. * Both the input and output image can be the same instance. * * @param input The input image. Not modified. * @param output Where the log image is written to. Modified. */ public static void log(GrayF64 input , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); for( int y = 0; y < input.height; y++ ) { int indexSrc = input.startIndex + y* input.stride; int indexDst = output.startIndex + y* output.stride; int end = indexSrc + input.width; for( ; indexSrc < end; indexSrc++ , indexDst++) { output.data[indexDst] = Math.log(1 + input.data[indexSrc]); } } } /** * Raises each pixel in the input image to the power of two. Both the input and output image can be the * same instance. * * @param input The input image. Not modified. * @param output Where the pow2 image is written to. Modified. */ public static void pow2(GrayF64 input , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); for( int y = 0; y < input.height; y++ ) { int indexSrc = input.startIndex + y* input.stride; int indexDst = output.startIndex + y* output.stride; int end = indexSrc + input.width; for( ; indexSrc < end; indexSrc++ , indexDst++) { double v = input.data[indexSrc]; output.data[indexDst] = v*v; } } } /** * Computes the square root of each pixel in the input image. Both the input and output image can be the * same instance. * * @param input The input image. Not modified. * @param output Where the sqrt() image is written to. Modified. */ public static void sqrt(GrayF64 input , GrayF64 output ) { InputSanityCheck.checkSameShape(input,output); for( int y = 0; y < input.height; y++ ) { int indexSrc = input.startIndex + y* input.stride; int indexDst = output.startIndex + y* output.stride; int end = indexSrc + input.width; for( ; indexSrc < end; indexSrc++ , indexDst++) { output.data[indexDst] = Math.sqrt(input.data[indexSrc]); } } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy