/** * Fills the whole image with the specified value * * @param input An image. * @param value The value that the image is being filled with. */ public static void fill(InterleavedI8 input, int value) { for (int y = 0; y < input.height; y++) { int index = input.getStartIndex() + y * input.getStride(); int end = index + input.width*input.numBands; Arrays.fill(input.data,index,end, (byte)value); } }
/** * Fills one band in the image with the specified value * * @param input An image. * @param band Which band is to be filled with the specified value * @param value The value that the image is being filled with. */ public static void fillBand(InterleavedI8 input, int band , int value) { final int numBands = input.numBands; for (int y = 0; y < input.height; y++) { int index = input.getStartIndex() + y * input.getStride() + band; int end = index + input.width*numBands - band; for (; index < end; index += numBands ) { input.data[index] = (byte)value; } } }
/** * Fills each band in the image with the specified values * * @param input An image. * @param values Array which contains the values each band is to be filled with. */ public static void fill(InterleavedI8 input, int[] values) { final int numBands = input.numBands; for (int y = 0; y < input.height; y++) { for( int band = 0; band < numBands; band++ ) { int index = input.getStartIndex() + y * input.getStride() + band; int end = index + input.width*numBands - band; int value = values[band]; for (; index < end; index += numBands ) { input.data[index] = (byte)value; } } } }
/** * Sets each value in the image to a value drawn from an uniform distribution that has a range of min ≤ X < max. * * @param img Image which is to be filled. Modified, * @param rand Random number generator * @param min Minimum value of the distribution, inclusive * @param max Maximum value of the distribution, exclusive */ public static void fillUniform(InterleavedI8 img, Random rand , int min , int max) { int range = max-min; byte[] data = img.data; for (int y = 0; y < img.height; y++) { int index = img.getStartIndex() + y * img.getStride(); int end = index + img.width*img.numBands; for (; index < end; index++) { data[index] = (byte)(rand.nextInt(range)+min); } } }
/** * Sets each value in the image to a value drawn from a Gaussian distribution. A user * specified lower and upper bound is provided to ensure that the values are within a legal * range. A drawn value outside the allowed range will be set to the closest bound. * * @param input Input image. Modified. * @param rand Random number generator * @param mean Distribution's mean. * @param sigma Distribution's standard deviation. * @param lowerBound Lower bound of value clip * @param upperBound Upper bound of value clip */ public static void fillGaussian(InterleavedI8 input, Random rand , double mean , double sigma , int lowerBound , int upperBound ) { byte[] data = input.data; int length = input.width*input.numBands; for (int y = 0; y < input.height; y++) { int index = input.getStartIndex() + y * input.getStride(); int indexEnd = index+length; while( index < indexEnd ) { int value = (int)(rand.nextGaussian()*sigma+mean); if( value < lowerBound ) value = lowerBound; if( value > upperBound ) value = upperBound; data[index++] = (byte)value; } } }
/** * Fills the whole image with the specified pixel value * * @param img An image. * @param value The value that the image is being filled with. */ public static void fill(InterleavedI8 img, byte... value) { if (value.length != img.numBands) throw new IllegalArgumentException("Unexpected number of bands"); 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(); for (int x = 0; x < w; x++) { for (int k = 0; k < img.numBands; k++) data[index++] = value[k]; } } }
/** * Fills the whole image with random values * * @param img An image. * @param rand The value that the image is being filled with. */ public static void randomize(InterleavedI8 img, Random rand) { final int h = img.getHeight(); final int w = img.getWidth(); byte[] data = img.data; int range = Byte.MAX_VALUE - Byte.MIN_VALUE; for (int y = 0; y < h; y++) { int index = img.getStartIndex() + y * img.getStride(); for (int x = 0; x < w; x++) { for (int k = 0; k < img.numBands; k++) data[index++] = (byte) (rand.nextInt(range) + Byte.MIN_VALUE); } } } }
/** * Extracts a single band from a multi-band image * * @param input Multi-band image * @param band which bad is to be extracted * @param output The single band image */ public static void extractBand( InterleavedI8 input, int band , GrayI8 output) { final int numBands = input.numBands; for (int y = 0; y < input.height; y++) { int indexIn = input.getStartIndex() + y * input.getStride() + band; int indexOut = output.getStartIndex() + y * output.getStride(); int end = indexOut + output.width; for (; indexOut < end; indexIn += numBands , indexOut++ ) { output.data[indexOut] = input.data[indexIn]; } } }
/** * Inserts a single band into a multi-band image overwriting the original band * * @param input Single band image * @param band Which band the image is to be inserted into * @param output The multi-band image which the input image is to be inserted into */ public static void insertBand( GrayI8 input, int band , InterleavedI8 output) { final int numBands = output.numBands; for (int y = 0; y < input.height; y++) { int indexIn = input.getStartIndex() + y * input.getStride(); int indexOut = output.getStartIndex() + y * output.getStride() + band; int end = indexOut + output.width*numBands - band; for (; indexOut < end; indexOut += numBands , indexIn++ ) { output.data[indexOut] = input.data[indexIn]; } } }