// Copyright 2019 Google LLC // // This source code is licensed under the BSD-style license found in the // LICENSE file in the root directory of this source tree. #include #include "resize-bilinear-operator-tester.h" TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_upscale_y) { for (size_t input_height = 1; input_height <= 3; input_height++) { for (size_t output_height = input_height + 1; output_height < 15; output_height *= 3) { ResizeBilinearOperatorTester() .input_size(input_height, 1) .output_size(output_height, 1) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_upscale_x) { for (size_t input_width = 1; input_width <= 3; input_width++) { for (size_t output_width = input_width + 1; output_width < 15; output_width *= 3) { ResizeBilinearOperatorTester() .input_size(1, input_width) .output_size(1, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_upscale) { for (size_t output_height = 3; output_height <= 5; output_height += 2) { for (size_t output_width = 3; output_width <= 5; output_width += 2) { ResizeBilinearOperatorTester() .input_size(2, 2) .output_size(output_height, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_downscale_y) { for (size_t output_height = 1; output_height <= 3; output_height++) { for (size_t input_height = output_height + 1; input_height < 15; input_height *= 3) { ResizeBilinearOperatorTester() .input_size(input_height, 1) .output_size(output_height, 1) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_downscale_x) { for (size_t output_width = 1; output_width <= 3; output_width++) { for (size_t input_width = output_width + 1; input_width < 15; input_width *= 3) { ResizeBilinearOperatorTester() .input_size(1, input_width) .output_size(1, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_downscale) { for (size_t input_height = 3; input_height <= 5; input_height += 2) { for (size_t input_width = 3; input_width <= 5; input_width += 2) { ResizeBilinearOperatorTester() .input_size(input_height, input_width) .output_size(2, 2) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_identical_size) { for (size_t height = 1; height < 10; height *= 3) { for (size_t width = 1; width < 10; width *= 3) { ResizeBilinearOperatorTester() .input_size(height, width) .output_size(height, width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_varying_channels) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_with_input_stride) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .input_pixel_stride(23) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_with_output_stride) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .output_pixel_stride(29) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_centers_varying_batch_size) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t batch_size = 2; batch_size <= 3; batch_size++) { ResizeBilinearOperatorTester() .batch_size(batch_size) .input_size(output_size, output_size) .output_size(output_size, output_size) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_upscale_y) { for (size_t input_height = 1; input_height <= 3; input_height++) { for (size_t output_height = input_height + 1; output_height < 15; output_height *= 3) { ResizeBilinearOperatorTester() .align_corners(true) .input_size(input_height, 1) .output_size(output_height, 1) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_upscale_x) { for (size_t input_width = 1; input_width <= 3; input_width++) { for (size_t output_width = input_width + 1; output_width < 15; output_width *= 3) { ResizeBilinearOperatorTester() .align_corners(true) .input_size(1, input_width) .output_size(1, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_upscale) { for (size_t output_height = 3; output_height <= 5; output_height += 2) { for (size_t output_width = 3; output_width <= 5; output_width += 2) { ResizeBilinearOperatorTester() .align_corners(true) .input_size(2, 2) .output_size(output_height, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_downscale_y) { for (size_t output_height = 2; output_height <= 3; output_height++) { for (size_t input_height = output_height + 1; input_height < 15; input_height *= 3) { ResizeBilinearOperatorTester() .input_size(input_height, 1) .output_size(output_height, 1) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_downscale_x) { for (size_t output_width = 2; output_width <= 3; output_width++) { for (size_t input_width = output_width + 1; input_width < 15; input_width *= 3) { ResizeBilinearOperatorTester() .input_size(1, input_width) .output_size(1, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_downscale) { for (size_t input_height = 3; input_height <= 5; input_height += 2) { for (size_t input_width = 3; input_width <= 5; input_width += 2) { ResizeBilinearOperatorTester() .input_size(input_height, input_width) .output_size(2, 2) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_identical_size) { for (size_t height = 1; height < 10; height *= 3) { for (size_t width = 1; width < 10; width *= 3) { ResizeBilinearOperatorTester() .align_corners(true) .input_size(height, width) .output_size(height, width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_varying_channels) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .align_corners(true) .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_with_input_stride) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .align_corners(true) .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .input_pixel_stride(23) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_with_output_stride) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .align_corners(true) .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .output_pixel_stride(29) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, aligned_corners_varying_batch_size) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t batch_size = 2; batch_size <= 3; batch_size++) { ResizeBilinearOperatorTester() .align_corners(true) .batch_size(batch_size) .input_size(output_size, output_size) .output_size(output_size, output_size) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_upscale_y) { for (size_t input_height = 1; input_height <= 3; input_height++) { for (size_t output_height = input_height + 1; output_height < 15; output_height *= 3) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(input_height, 1) .output_size(output_height, 1) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_upscale_x) { for (size_t input_width = 1; input_width <= 3; input_width++) { for (size_t output_width = input_width + 1; output_width < 15; output_width *= 3) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(1, input_width) .output_size(1, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_upscale) { for (size_t output_height = 3; output_height <= 5; output_height += 2) { for (size_t output_width = 3; output_width <= 5; output_width += 2) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(2, 2) .output_size(output_height, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_downscale_y) { for (size_t output_height = 1; output_height <= 3; output_height++) { for (size_t input_height = output_height + 1; input_height < 15; input_height *= 3) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(input_height, 1) .output_size(output_height, 1) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_downscale_x) { for (size_t output_width = 1; output_width <= 3; output_width++) { for (size_t input_width = output_width + 1; input_width < 15; input_width *= 3) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(1, input_width) .output_size(1, output_width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_downscale) { for (size_t input_height = 3; input_height <= 5; input_height += 2) { for (size_t input_width = 3; input_width <= 5; input_width += 2) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(input_height, input_width) .output_size(2, 2) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_identical_size) { for (size_t height = 1; height < 10; height *= 3) { for (size_t width = 1; width < 10; width *= 3) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(height, width) .output_size(height, width) .channels(17) .iterations(3) .TestNHWCxF32(); } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_varying_channels) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_with_input_stride) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .input_pixel_stride(23) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_with_output_stride) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t channels = 15; channels <= 19; channels++) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .input_size(output_size, output_size) .output_size(output_size, output_size) .channels(channels) .output_pixel_stride(29) .iterations(3) .TestNHWCxF32(); } } } } TEST(RESIZE_BILINEAR_NHWC_F32, tf_mode_aligned_centers_varying_batch_size) { for (size_t input_size = 2; input_size <= 6; input_size += 2) { for (size_t output_size = 2; output_size <= 6; output_size += 2) { for (size_t batch_size = 2; batch_size <= 3; batch_size++) { ResizeBilinearOperatorTester() .tf_legacy_mode(true) .batch_size(batch_size) .input_size(output_size, output_size) .output_size(output_size, output_size) .iterations(3) .TestNHWCxF32(); } } } }