Index: webrtc/common_video/libyuv/scaler_unittest.cc |
diff --git a/webrtc/common_video/libyuv/scaler_unittest.cc b/webrtc/common_video/libyuv/scaler_unittest.cc |
deleted file mode 100644 |
index 29a0a7403d676b34c12e0d68f3bb20b5eba0869a..0000000000000000000000000000000000000000 |
--- a/webrtc/common_video/libyuv/scaler_unittest.cc |
+++ /dev/null |
@@ -1,399 +0,0 @@ |
-/* |
- * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
- * |
- * Use of this source code is governed by a BSD-style license |
- * that can be found in the LICENSE file in the root of the source |
- * tree. An additional intellectual property rights grant can be found |
- * in the file PATENTS. All contributing project authors may |
- * be found in the AUTHORS file in the root of the source tree. |
- */ |
- |
-#include <math.h> |
-#include <string.h> |
- |
-#include <memory> |
- |
-#include "testing/gtest/include/gtest/gtest.h" |
-#include "webrtc/base/timeutils.h" |
-#include "webrtc/common_video/libyuv/include/scaler.h" |
-#include "webrtc/test/testsupport/fileutils.h" |
- |
-namespace webrtc { |
- |
-class TestScaler : public ::testing::Test { |
- protected: |
- TestScaler(); |
- virtual void SetUp(); |
- virtual void TearDown(); |
- |
- void ScaleSequence(ScaleMethod method, |
- FILE* source_file, std::string out_name, |
- int src_width, int src_height, |
- int dst_width, int dst_height); |
- // Computes the sequence average PSNR between an input sequence in |
- // |input_file| and an output sequence with filename |out_name|. |width| and |
- // |height| are the frame sizes of both sequences. |
- double ComputeAvgSequencePSNR(FILE* input_file, std::string out_name, |
- int width, int height); |
- |
- Scaler test_scaler_; |
- FILE* source_file_; |
- VideoFrame test_frame_; |
- const int width_; |
- const int half_width_; |
- const int height_; |
- const int half_height_; |
- const int size_y_; |
- const int size_uv_; |
- const size_t frame_length_; |
-}; |
- |
-TestScaler::TestScaler() |
- : source_file_(NULL), |
- width_(352), |
- half_width_(width_ / 2), |
- height_(288), |
- half_height_(height_ / 2), |
- size_y_(width_ * height_), |
- size_uv_(half_width_ * half_height_), |
- frame_length_(CalcBufferSize(kI420, width_, height_)) { |
-} |
- |
-void TestScaler::SetUp() { |
- const std::string input_file_name = |
- webrtc::test::ResourcePath("foreman_cif", "yuv"); |
- source_file_ = fopen(input_file_name.c_str(), "rb"); |
- ASSERT_TRUE(source_file_ != NULL) << "Cannot read file: "<< |
- input_file_name << "\n"; |
- test_frame_.CreateEmptyFrame(width_, height_, |
- width_, half_width_, half_width_); |
-} |
- |
-void TestScaler::TearDown() { |
- if (source_file_ != NULL) { |
- ASSERT_EQ(0, fclose(source_file_)); |
- } |
- source_file_ = NULL; |
-} |
- |
-TEST_F(TestScaler, ScaleWithoutSettingValues) { |
- EXPECT_EQ(-2, test_scaler_.Scale(test_frame_, &test_frame_)); |
-} |
- |
-TEST_F(TestScaler, ScaleBadInitialValues) { |
- EXPECT_EQ(-1, test_scaler_.Set(0, 288, 352, 288, kI420, kI420, kScalePoint)); |
- EXPECT_EQ(-1, test_scaler_.Set(704, 0, 352, 288, kI420, kI420, kScaleBox)); |
- EXPECT_EQ(-1, test_scaler_.Set(704, 576, 352, 0, kI420, kI420, |
- kScaleBilinear)); |
- EXPECT_EQ(-1, test_scaler_.Set(704, 576, 0, 288, kI420, kI420, kScalePoint)); |
-} |
- |
-TEST_F(TestScaler, ScaleSendingNullSourcePointer) { |
- VideoFrame null_src_frame; |
- EXPECT_EQ(-1, test_scaler_.Scale(null_src_frame, &test_frame_)); |
-} |
- |
-TEST_F(TestScaler, ScaleSendingBufferTooSmall) { |
- // Sending a buffer which is too small (should reallocate and update size) |
- EXPECT_EQ(0, test_scaler_.Set(width_, height_, |
- half_width_, half_height_, |
- kI420, kI420, |
- kScalePoint)); |
- VideoFrame test_frame2; |
- std::unique_ptr<uint8_t[]> orig_buffer(new uint8_t[frame_length_]); |
- EXPECT_GT(fread(orig_buffer.get(), 1, frame_length_, source_file_), 0U); |
- test_frame_.CreateFrame(orig_buffer.get(), |
- orig_buffer.get() + size_y_, |
- orig_buffer.get() + size_y_ + size_uv_, |
- width_, height_, |
- width_, half_width_, half_width_, |
- kVideoRotation_0); |
- EXPECT_EQ(0, test_scaler_.Scale(test_frame_, &test_frame2)); |
- EXPECT_GT(width_ * height_, test_frame2.allocated_size(kYPlane)); |
- EXPECT_GT(size_uv_, test_frame2.allocated_size(kUPlane)); |
- EXPECT_GT(size_uv_, test_frame2.allocated_size(kVPlane)); |
- EXPECT_EQ(half_width_, test_frame2.width()); |
- EXPECT_EQ(half_height_, test_frame2.height()); |
-} |
- |
-// TODO(mikhal): Converge the test into one function that accepts the method. |
-#if defined(WEBRTC_ANDROID) |
-#define MAYBE_PointScaleTest DISABLED_PointScaleTest |
-#else |
-#define MAYBE_PointScaleTest PointScaleTest |
-#endif |
-TEST_F(TestScaler, MAYBE_PointScaleTest) { |
- double avg_psnr; |
- FILE* source_file2; |
- ScaleMethod method = kScalePoint; |
- std::string out_name = webrtc::test::OutputPath() + |
- "LibYuvTest_PointScale_176_144.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- half_width_, half_height_); |
- // Upsample back up and check PSNR. |
- source_file2 = fopen(out_name.c_str(), "rb"); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_PointScale_352_288_" |
- "upfrom_176_144.yuv"; |
- ScaleSequence(method, |
- source_file2, out_name, |
- 176, 144, |
- 352, 288); |
- avg_psnr = ComputeAvgSequencePSNR(source_file_, out_name, width_, height_); |
- printf("PSNR for scaling from: %d %d, down/up to: %d %d, and back to " |
- "original size: %f \n", width_, height_, 176, 144, avg_psnr); |
- // Average PSNR for lower bound in assert is ~0.1dB lower than the actual |
- // average PSNR under same conditions. |
- ASSERT_GT(avg_psnr, 27.9); |
- ASSERT_EQ(0, fclose(source_file2)); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_PointScale_320_240.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 320, 240); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_PointScale_704_576.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- width_ * 2, height_ * 2); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_PointScale_300_200.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 300, 200); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_PointScale_400_300.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 400, 300); |
- // Down-sample to odd size frame and scale back up. |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_PointScale_282_231.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 282, 231); |
- source_file2 = fopen(out_name.c_str(), "rb"); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_PointScale_352_288_" |
- "upfrom_282_231.yuv"; |
- ScaleSequence(method, |
- source_file2, out_name, |
- 282, 231, |
- 352, 288); |
- avg_psnr = ComputeAvgSequencePSNR(source_file_, out_name, width_, height_); |
- printf("PSNR for scaling from: %d %d, down/up to: %d %d, and back to " |
- "original size: %f \n", width_, height_, 282, 231, avg_psnr); |
- // Average PSNR for lower bound in assert is ~0.1dB lower than the actual |
- // average PSNR under same conditions. |
- ASSERT_GT(avg_psnr, 25.8); |
- ASSERT_EQ(0, fclose(source_file2)); |
-} |
- |
-#if defined(WEBRTC_ANDROID) |
-#define MAYBE_BilinearScaleTest DISABLED_BiLinearScaleTest |
-#else |
-#define MAYBE_BilinearScaleTest BiLinearScaleTest |
-#endif |
-TEST_F(TestScaler, MAYBE_BiLinearScaleTest) { |
- double avg_psnr; |
- FILE* source_file2; |
- ScaleMethod method = kScaleBilinear; |
- std::string out_name = webrtc::test::OutputPath() + |
- "LibYuvTest_BilinearScale_176_144.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- width_ / 2, height_ / 2); |
- // Up-sample back up and check PSNR. |
- source_file2 = fopen(out_name.c_str(), "rb"); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_BilinearScale_352_288_" |
- "upfrom_176_144.yuv"; |
- ScaleSequence(method, |
- source_file2, out_name, |
- 176, 144, |
- 352, 288); |
- avg_psnr = ComputeAvgSequencePSNR(source_file_, out_name, width_, height_); |
- printf("PSNR for scaling from: %d %d, down/up to: %d %d, and back to " |
- "original size: %f \n", width_, height_, 176, 144, avg_psnr); |
- // Average PSNR for lower bound in assert is ~0.1dB lower than the actual |
- // average PSNR under same conditions. |
- ASSERT_GT(avg_psnr, 27.5); |
- ComputeAvgSequencePSNR(source_file_, out_name, width_, height_); |
- ASSERT_EQ(0, fclose(source_file2)); |
- out_name = webrtc::test::OutputPath() + |
- "LibYuvTest_BilinearScale_320_240.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 320, 240); |
- out_name = webrtc::test::OutputPath() + |
- "LibYuvTest_BilinearScale_704_576.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- width_ * 2, height_ * 2); |
- out_name = webrtc::test::OutputPath() + |
- "LibYuvTest_BilinearScale_300_200.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 300, 200); |
- out_name = webrtc::test::OutputPath() + |
- "LibYuvTest_BilinearScale_400_300.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 400, 300); |
-} |
- |
-#if defined(WEBRTC_ANDROID) |
-#define MAYBE_BoxScaleTest DISABLED_BoxScaleTest |
-#else |
-#define MAYBE_BoxScaleTest BoxScaleTest |
-#endif |
-TEST_F(TestScaler, MAYBE_BoxScaleTest) { |
- double avg_psnr; |
- FILE* source_file2; |
- ScaleMethod method = kScaleBox; |
- std::string out_name = webrtc::test::OutputPath() + |
- "LibYuvTest_BoxScale_176_144.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- width_ / 2, height_ / 2); |
- // Up-sample back up and check PSNR. |
- source_file2 = fopen(out_name.c_str(), "rb"); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_BoxScale_352_288_" |
- "upfrom_176_144.yuv"; |
- ScaleSequence(method, |
- source_file2, out_name, |
- 176, 144, |
- 352, 288); |
- avg_psnr = ComputeAvgSequencePSNR(source_file_, out_name, width_, height_); |
- printf("PSNR for scaling from: %d %d, down/up to: %d %d, and back to " |
- "original size: %f \n", width_, height_, 176, 144, avg_psnr); |
- // Average PSNR for lower bound in assert is ~0.1dB lower than the actual |
- // average PSNR under same conditions. |
- ASSERT_GT(avg_psnr, 27.5); |
- ASSERT_EQ(0, fclose(source_file2)); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_BoxScale_320_240.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 320, 240); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_BoxScale_704_576.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- width_ * 2, height_ * 2); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_BoxScale_300_200.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 300, 200); |
- out_name = webrtc::test::OutputPath() + "LibYuvTest_BoxScale_400_300.yuv"; |
- ScaleSequence(method, |
- source_file_, out_name, |
- width_, height_, |
- 400, 300); |
-} |
- |
-double TestScaler::ComputeAvgSequencePSNR(FILE* input_file, |
- std::string out_name, |
- int width, int height) { |
- FILE* output_file; |
- output_file = fopen(out_name.c_str(), "rb"); |
- assert(output_file != NULL); |
- rewind(input_file); |
- rewind(output_file); |
- |
- size_t required_size = CalcBufferSize(kI420, width, height); |
- uint8_t* input_buffer = new uint8_t[required_size]; |
- uint8_t* output_buffer = new uint8_t[required_size]; |
- |
- int frame_count = 0; |
- double avg_psnr = 0; |
- VideoFrame in_frame, out_frame; |
- const int half_width = (width + 1) / 2; |
- in_frame.CreateEmptyFrame(width, height, width, half_width, half_width); |
- out_frame.CreateEmptyFrame(width, height, width, half_width, half_width); |
- while (feof(input_file) == 0) { |
- if (fread(input_buffer, 1, required_size, input_file) != required_size) { |
- break; |
- } |
- if (fread(output_buffer, 1, required_size, output_file) != required_size) { |
- break; |
- } |
- frame_count++; |
- EXPECT_EQ(0, ConvertToI420(kI420, input_buffer, 0, 0, width, height, |
- required_size, kVideoRotation_0, &in_frame)); |
- EXPECT_EQ(0, ConvertToI420(kI420, output_buffer, 0, 0, width, height, |
- required_size, kVideoRotation_0, &out_frame)); |
- double psnr = I420PSNR(&in_frame, &out_frame); |
- avg_psnr += psnr; |
- } |
- avg_psnr = avg_psnr / frame_count; |
- assert(0 == fclose(output_file)); |
- delete [] input_buffer; |
- delete [] output_buffer; |
- return avg_psnr; |
-} |
- |
-// TODO(mikhal): Move part to a separate scale test. |
-void TestScaler::ScaleSequence(ScaleMethod method, |
- FILE* source_file, std::string out_name, |
- int src_width, int src_height, |
- int dst_width, int dst_height) { |
- FILE* output_file; |
- EXPECT_EQ(0, test_scaler_.Set(src_width, src_height, |
- dst_width, dst_height, |
- kI420, kI420, method)); |
- |
- output_file = fopen(out_name.c_str(), "wb"); |
- ASSERT_TRUE(output_file != NULL); |
- |
- rewind(source_file); |
- |
- VideoFrame input_frame; |
- VideoFrame output_frame; |
- int64_t start_clock, total_clock; |
- total_clock = 0; |
- int frame_count = 0; |
- size_t src_required_size = CalcBufferSize(kI420, src_width, src_height); |
- std::unique_ptr<uint8_t[]> frame_buffer(new uint8_t[src_required_size]); |
- int size_y = src_width * src_height; |
- int size_uv = ((src_width + 1) / 2) * ((src_height + 1) / 2); |
- |
- // Running through entire sequence. |
- while (feof(source_file) == 0) { |
- if (fread(frame_buffer.get(), 1, src_required_size, source_file) != |
- src_required_size) |
- break; |
- |
- input_frame.CreateFrame(frame_buffer.get(), |
- frame_buffer.get() + size_y, |
- frame_buffer.get() + size_y + size_uv, |
- src_width, src_height, |
- src_width, (src_width + 1) / 2, |
- (src_width + 1) / 2, |
- kVideoRotation_0); |
- |
- start_clock = rtc::TimeMillis(); |
- EXPECT_EQ(0, test_scaler_.Scale(input_frame, &output_frame)); |
- total_clock += rtc::TimeMillis() - start_clock; |
- if (PrintVideoFrame(output_frame, output_file) < 0) { |
- return; |
- } |
- frame_count++; |
- } |
- |
- if (frame_count) { |
- printf("Scaling[%d %d] => [%d %d]: ", |
- src_width, src_height, dst_width, dst_height); |
- printf("Average time per frame[ms]: %.2lf\n", |
- (static_cast<double>(total_clock) / frame_count)); |
- } |
- ASSERT_EQ(0, fclose(output_file)); |
-} |
- |
-} // namespace webrtc |