/* Copyright 2019 The TensorFlow Authors. All Rights Reserved.
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 org.tensorflow.lite.support.image.ops;
import static com.google.common.truth.Truth.assertThat;
import android.graphics.Bitmap;
import android.graphics.PointF;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.tensorflow.lite.DataType;
import org.tensorflow.lite.support.image.ImageProcessor;
import org.tensorflow.lite.support.image.TensorImage;
/** Instrumented unit test for {@link Rot90Op}. */
@RunWith(AndroidJUnit4.class)
public class Rot90OpInstrumentedTest {
private Bitmap exampleBitmap;
private TensorImage input;
private static final int EXAMPLE_WIDTH = 10;
private static final int EXAMPLE_HEIGHT = 15;
@Before
public void setUp() {
exampleBitmap = createExampleBitmap();
input = new TensorImage(DataType.UINT8);
input.load(exampleBitmap);
}
@Test
public void testRot90() {
ImageProcessor processor = new ImageProcessor.Builder().add(new Rot90Op()).build();
TensorImage output = processor.process(input);
Bitmap outputBitmap = output.getBitmap();
assertThat(outputBitmap.getWidth()).isEqualTo(EXAMPLE_HEIGHT);
assertThat(outputBitmap.getHeight()).isEqualTo(EXAMPLE_WIDTH);
for (int i = 0; i < exampleBitmap.getWidth(); i++) {
for (int j = 0; j < exampleBitmap.getHeight(); j++) {
assertThat(exampleBitmap.getPixel(i, j))
.isEqualTo(outputBitmap.getPixel(j, EXAMPLE_WIDTH - 1 - i));
}
}
}
@Test
public void testRot90Twice() {
ImageProcessor processor = new ImageProcessor.Builder().add(new Rot90Op(2)).build();
TensorImage output = processor.process(input);
Bitmap outputBitmap = output.getBitmap();
assertThat(outputBitmap.getWidth()).isEqualTo(EXAMPLE_WIDTH);
assertThat(outputBitmap.getHeight()).isEqualTo(EXAMPLE_HEIGHT);
for (int i = 0; i < exampleBitmap.getWidth(); i++) {
for (int j = 0; j < exampleBitmap.getHeight(); j++) {
assertThat(exampleBitmap.getPixel(i, j))
.isEqualTo(outputBitmap.getPixel(EXAMPLE_WIDTH - 1 - i, EXAMPLE_HEIGHT - 1 - j));
}
}
}
@Test
public void inverseTransformCorrectlyWhenRotated() {
Rot90Op op = new Rot90Op(3);
PointF original = op.inverseTransform(new PointF(20, 10), 200, 100);
assertThat(original.x).isEqualTo(10);
assertThat(original.y).isEqualTo(180);
PointF outside = op.inverseTransform(new PointF(-10, 110), 200, 100);
assertThat(outside.x).isEqualTo(110);
assertThat(outside.y).isEqualTo(210);
}
private static Bitmap createExampleBitmap() {
int[] colors = new int[EXAMPLE_WIDTH * EXAMPLE_HEIGHT];
for (int i = 0; i < EXAMPLE_WIDTH * EXAMPLE_HEIGHT; i++) {
colors[i] = (i << 16) | ((i + 1) << 8) | (i + 2);
}
return Bitmap.createBitmap(colors, EXAMPLE_WIDTH, EXAMPLE_HEIGHT, Bitmap.Config.ARGB_8888);
}
}