blob: d1987b2583a37a5bb48a09af4b9bc0d6dad29823 [file] [log] [blame]
# Copyright 2023 The Android Open Source Project
#
# 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.
"""Tests for opencv_processing_utils."""
import math
import os
import unittest
import cv2
import opencv_processing_utils
class Cv2ImageProcessingUtilsTests(unittest.TestCase):
"""Unit tests for this module."""
def test_get_angle_identify_rotated_chessboard_angle(self):
"""Unit test to check extracted angles from images."""
# Array of the image files and angles containing rotated chessboards.
test_cases = [
('', 0),
('_15_ccw', -15),
('_30_ccw', -30),
('_45_ccw', -45),
('_60_ccw', -60),
('_75_ccw', -75),
]
test_fails = ''
# For each rotated image pair (normal, wide), check angle against expected.
for suffix, angle in test_cases:
# Define image paths.
normal_img_path = os.path.join(
opencv_processing_utils.TEST_IMG_DIR,
f'rotated_chessboards/normal{suffix}.jpg')
wide_img_path = os.path.join(
opencv_processing_utils.TEST_IMG_DIR,
f'rotated_chessboards/wide{suffix}.jpg')
# Load and color-convert images.
normal_img = cv2.cvtColor(cv2.imread(normal_img_path), cv2.COLOR_BGR2GRAY)
wide_img = cv2.cvtColor(cv2.imread(wide_img_path), cv2.COLOR_BGR2GRAY)
# Assert angle as expected.
normal = opencv_processing_utils.get_angle(normal_img)
wide = opencv_processing_utils.get_angle(wide_img)
valid_angles = (angle, angle+90) # try both angle & +90 due to squares
e_msg = (f'\n Rotation angle test failed: {angle}, extracted normal: '
f'{normal:.2f}, wide: {wide:.2f}, valid_angles: {valid_angles}')
matched_angles = False
for a in valid_angles:
if (math.isclose(normal, a,
abs_tol=opencv_processing_utils.ANGLE_CHECK_TOL) and
math.isclose(wide, a,
abs_tol=opencv_processing_utils.ANGLE_CHECK_TOL)):
matched_angles = True
if not matched_angles:
test_fails += e_msg
self.assertEqual(len(test_fails), 0, test_fails)
def test_calc_chart_scaling(self):
"""Unit test to check chart scaling rules."""
# Wide (61-90deg FoV) in 22cm rig
self.assertEqual(opencv_processing_utils.calc_chart_scaling(22, 80), 0.67)
# TELE (41-60deg FoV) in 55cm rig
self.assertEqual(opencv_processing_utils.calc_chart_scaling(55, 40), 0.5)
# No scaling rule is found for input FoV, default is used
self.assertIsNone(opencv_processing_utils.calc_chart_scaling(50, 115))
# No scaling rule is found for input distance, default is used
self.assertIsNone(opencv_processing_utils.calc_chart_scaling(200, 65))
if __name__ == '__main__':
unittest.main()