#ifdef HAVE_CONFIG_H #include "config.h" #include "config_unix.h" #include "config_win32.h" #endif #include #include #include #include #include #include "unit_common.h" #include "video_codec.h" #include "video_capture/testcard_common.h" using std::cerr; using std::list; using std::pair; using std::string; using std::to_string; using std::ostringstream; extern "C" bool codec_conversion_test_testcard_uyvy_to_i420(void); bool codec_conversion_test_testcard_uyvy_to_i420(void) { list> sizes = { {1, 2}, {2, 1}, { 16, 1}, {16, 16}, {127, 255} }; for (auto &i : sizes) { size_t size_x = i.first; size_t size_y = i.second; /// @todo Check also if chroma is horizontally interpolated in UV planes unsigned char uyvy_pattern[4] = { 'u', 'y', 'v', 'Y' }; size_t uyvy_buf_size = ((size_x + 1) & ~1) * 2 * size_y; unsigned char uyvy_buf[uyvy_buf_size]; for (size_t i = 0; i < size_y * 2 * ((size_x + 1) & ~1); ++i) { uyvy_buf[i] = uyvy_pattern[i % 4]; } auto *i420_buf = (unsigned char *) malloc(vc_get_datalen(size_x, size_y, I420)); testcard_convert_buffer(UYVY, I420, i420_buf, uyvy_buf, size_x, size_y); unsigned char *y_ptr = i420_buf; for (size_t i = 0; i < size_y; ++i) { for (size_t j = 0; j < size_x; ++j) { ostringstream oss; unsigned char expected = uyvy_pattern[((2 * j + 1) % 4)]; unsigned char actual = *y_ptr++; oss << size_x << "X" << size_y << ": [" << i << ", " << j << "]"; ASSERT_EQUAL_MESSAGE(oss.str(), expected, actual); } } // U unsigned char *u_ptr = i420_buf + size_x * size_y; for (size_t i = 0; i < (size_y + 1) / 2; ++i) { for (size_t j = 0; j < (size_x + 1) / 2; ++j) { ostringstream oss; unsigned char expected = 'u'; unsigned char actual = *u_ptr++; oss << "[" << i << ", " << j << "]"; ASSERT_EQUAL_MESSAGE(oss.str(), expected, actual); } } // V unsigned char *v_ptr = i420_buf + size_x * size_y + ((size_x + 1) / 2) * ((size_y + 1) / 2); for (size_t i = 0; i < (size_y + 1) / 2; ++i) { for (size_t j = 0; j < (size_x + 1) / 2; ++j) { ostringstream oss; unsigned char expected = 'v'; unsigned char actual = *v_ptr++; oss << "[" << i << ", " << j << "]"; ASSERT_EQUAL_MESSAGE(oss.str(), expected, actual); } } free(i420_buf); } return true; }