Adding more codecs to the AcmSenderBitExactness
New tests include iSAC-swb, PCM16b (8, 16, 32 kHz; mono and stereo), PCM A/u (mono and stereo), iLBC, G.722 (mono and stereo), and Opus. Also adding checks on number of output channels. BUG=3521 R=kwiberg@webrtc.org Review URL: https://webrtc-codereview.appspot.com/15319004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@7016 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
		| @@ -33,11 +33,6 @@ bool ModifyAndUseThisCodec(CodecInst* codec_param) { | ||||
|   if (STR_CASE_CMP(codec_param->plname, "telephone-event") == 0) | ||||
|     return false;  // Skip DTFM. | ||||
|  | ||||
|   if (STR_CASE_CMP(codec_param->plname, "opus") == 0) | ||||
|     codec_param->channels = 1;  // Always register Opus as mono. | ||||
|   else if (codec_param->channels > 1) | ||||
|     return false;  // Skip all non-mono codecs. | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| @@ -107,12 +102,14 @@ bool RemapPltypeAndUseThisCodec(const char* plname, | ||||
|  | ||||
| AcmReceiveTest::AcmReceiveTest(PacketSource* packet_source, | ||||
|                                AudioSink* audio_sink, | ||||
|                                int output_freq_hz) | ||||
|                                int output_freq_hz, | ||||
|                                NumOutputChannels exptected_output_channels) | ||||
|     : clock_(0), | ||||
|       acm_(webrtc::AudioCodingModule::Create(0, &clock_)), | ||||
|       packet_source_(packet_source), | ||||
|       audio_sink_(audio_sink), | ||||
|       output_freq_hz_(output_freq_hz) { | ||||
|       output_freq_hz_(output_freq_hz), | ||||
|       exptected_output_channels_(exptected_output_channels) { | ||||
| } | ||||
|  | ||||
| void AcmReceiveTest::RegisterDefaultCodecs() { | ||||
| @@ -155,7 +152,15 @@ void AcmReceiveTest::Run() { | ||||
|       EXPECT_EQ(output_freq_hz_, output_frame.sample_rate_hz_); | ||||
|       const int samples_per_block = output_freq_hz_ * 10 / 1000; | ||||
|       EXPECT_EQ(samples_per_block, output_frame.samples_per_channel_); | ||||
|       EXPECT_EQ(1, output_frame.num_channels_); | ||||
|       if (exptected_output_channels_ != kArbitraryChannels) { | ||||
|         if (output_frame.speech_type_ == webrtc::AudioFrame::kPLC) { | ||||
|           // Don't check number of channels for PLC output, since each test run | ||||
|           // usually starts with a short period of mono PLC before decoding the | ||||
|           // first packet. | ||||
|         } else { | ||||
|           EXPECT_EQ(exptected_output_channels_, output_frame.num_channels_); | ||||
|         } | ||||
|       } | ||||
|       ASSERT_TRUE(audio_sink_->WriteAudioFrame(output_frame)); | ||||
|       clock_.AdvanceTimeMilliseconds(10); | ||||
|     } | ||||
|   | ||||
| @@ -25,9 +25,17 @@ class PacketSource; | ||||
|  | ||||
| class AcmReceiveTest { | ||||
|  public: | ||||
|   AcmReceiveTest(PacketSource* packet_source, | ||||
|   enum NumOutputChannels { | ||||
|     kArbitraryChannels = 0, | ||||
|     kMonoOutput = 1, | ||||
|     kStereoOutput = 2 | ||||
|   }; | ||||
|  | ||||
|   AcmReceiveTest( | ||||
|       PacketSource* packet_source, | ||||
|       AudioSink* audio_sink, | ||||
|                  int output_freq_hz); | ||||
|       int output_freq_hz, | ||||
|       NumOutputChannels exptected_output_channels); | ||||
|   virtual ~AcmReceiveTest() {} | ||||
|  | ||||
|   // Registers the codecs with default parameters from ACM. | ||||
| @@ -46,6 +54,7 @@ class AcmReceiveTest { | ||||
|   PacketSource* packet_source_; | ||||
|   AudioSink* audio_sink_; | ||||
|   const int output_freq_hz_; | ||||
|   NumOutputChannels exptected_output_channels_; | ||||
|  | ||||
|   DISALLOW_COPY_AND_ASSIGN(AcmReceiveTest); | ||||
| }; | ||||
|   | ||||
| @@ -55,7 +55,6 @@ bool AcmSendTest::RegisterCodec(const char* payload_name, | ||||
|   codec_.pltype = payload_type; | ||||
|   codec_.pacsize = frame_size_samples; | ||||
|   codec_registered_ = (acm_->RegisterSendCodec(codec_) == 0); | ||||
|   assert(channels == 1);  // TODO(henrik.lundin) Add multi-channel support. | ||||
|   input_frame_.num_channels_ = channels; | ||||
|   assert(input_block_size_samples_ * input_frame_.num_channels_ <= | ||||
|          AudioFrame::kMaxDataSizeSamples); | ||||
| @@ -74,6 +73,12 @@ Packet* AcmSendTest::NextPacket() { | ||||
|   while (clock_.TimeInMilliseconds() < test_duration_ms_) { | ||||
|     clock_.AdvanceTimeMilliseconds(kBlockSizeMs); | ||||
|     CHECK(audio_source_->Read(input_block_size_samples_, input_frame_.data_)); | ||||
|     if (input_frame_.num_channels_ > 1) { | ||||
|       InputAudioFile::DuplicateInterleaved(input_frame_.data_, | ||||
|                                            input_block_size_samples_, | ||||
|                                            input_frame_.num_channels_, | ||||
|                                            input_frame_.data_); | ||||
|     } | ||||
|     CHECK_EQ(0, acm_->Add10MsData(input_frame_)); | ||||
|     input_frame_.timestamp_ += input_block_size_samples_; | ||||
|     int32_t encoded_bytes = acm_->Process(); | ||||
|   | ||||
| @@ -556,7 +556,8 @@ class AcmReceiverBitExactness : public ::testing::Test { | ||||
|     test::OutputAudioFile output_file(output_file_name); | ||||
|     test::AudioSinkFork output(&checksum, &output_file); | ||||
|  | ||||
|     test::AcmReceiveTest test(packet_source.get(), &output, output_freq_hz); | ||||
|     test::AcmReceiveTest test(packet_source.get(), &output, output_freq_hz, | ||||
|                               test::AcmReceiveTest::kArbitraryChannels); | ||||
|     ASSERT_NO_FATAL_FAILURE(test.RegisterNetEqTestCodecs()); | ||||
|     test.Run(); | ||||
|  | ||||
| @@ -652,7 +653,8 @@ class AcmSenderBitExactness : public ::testing::Test, | ||||
|   // before calling this method. | ||||
|   void Run(const std::string& audio_checksum_ref, | ||||
|            const std::string& payload_checksum_ref, | ||||
|            int expected_packets) { | ||||
|            int expected_packets, | ||||
|            test::AcmReceiveTest::NumOutputChannels expected_channels) { | ||||
|     // Set up the receiver used to decode the packets and verify the decoded | ||||
|     // output. | ||||
|     test::AudioChecksum audio_checksum; | ||||
| @@ -668,7 +670,8 @@ class AcmSenderBitExactness : public ::testing::Test, | ||||
|     // Have the output audio sent both to file and to the checksum calculator. | ||||
|     test::AudioSinkFork output(&audio_checksum, &output_file); | ||||
|     const int kOutputFreqHz = 8000; | ||||
|     test::AcmReceiveTest receive_test(this, &output, kOutputFreqHz); | ||||
|     test::AcmReceiveTest receive_test( | ||||
|         this, &output, kOutputFreqHz, expected_channels); | ||||
|     ASSERT_NO_FATAL_FAILURE(receive_test.RegisterDefaultCodecs()); | ||||
|  | ||||
|     // This is where the actual test is executed. | ||||
| @@ -760,7 +763,8 @@ TEST_F(AcmSenderBitExactness, IsacWb30ms) { | ||||
|           "d42cb5195463da26c8129bbfe73a22e6", | ||||
|           "83de248aea9c3c2bd680b6952401b4ca", | ||||
|           "3c79f16f34218271f3dca4e2b1dfe1bb"), | ||||
|       33); | ||||
|       33, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, IsacWb60ms) { | ||||
| @@ -773,7 +777,158 @@ TEST_F(AcmSenderBitExactness, IsacWb60ms) { | ||||
|           "ebe04a819d3a9d83a83a17f271e1139a", | ||||
|           "97aeef98553b5a4b5a68f8b716e8eaf0", | ||||
|           "9e0a0ab743ad987b55b8e14802769c56"), | ||||
|       16); | ||||
|       16, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, DISABLED_ON_ANDROID(IsacSwb30ms)) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("ISAC", 32000, 1, 104, 960, 960)); | ||||
|   Run(AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "98d960600eb4ddb3fcbe11f5057ddfd7", | ||||
|           "", | ||||
|           "2f6dfe142f735f1d96f6bd86d2526f42"), | ||||
|       AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "cc9d2d86a71d6f99f97680a5c27e2762", | ||||
|           "", | ||||
|           "7b214fc3a5e33d68bf30e77969371f31"), | ||||
|       33, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcm16_8000khz_10ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("L16", 8000, 1, 107, 80, 80)); | ||||
|   Run("de4a98e1406f8b798d99cd0704e862e2", | ||||
|       "c1edd36339ce0326cc4550041ad719a0", | ||||
|       100, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcm16_16000khz_10ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("L16", 16000, 1, 108, 160, 160)); | ||||
|   Run("ae646d7b68384a1269cc080dd4501916", | ||||
|       "ad786526383178b08d80d6eee06e9bad", | ||||
|       100, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcm16_32000khz_10ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("L16", 32000, 1, 109, 320, 320)); | ||||
|   Run("7fe325e8fbaf755e3c5df0b11a4774fb", | ||||
|       "5ef82ea885e922263606c6fdbc49f651", | ||||
|       100, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcm16_stereo_8000khz_10ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("L16", 8000, 2, 111, 80, 80)); | ||||
|   Run("fb263b74e7ac3de915474d77e4744ceb", | ||||
|       "62ce5adb0d4965d0a52ec98ae7f98974", | ||||
|       100, | ||||
|       test::AcmReceiveTest::kStereoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcm16_stereo_16000khz_10ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("L16", 16000, 2, 112, 160, 160)); | ||||
|   Run("d09e9239553649d7ac93e19d304281fd", | ||||
|       "41ca8edac4b8c71cd54fd9f25ec14870", | ||||
|       100, | ||||
|       test::AcmReceiveTest::kStereoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcm16_stereo_32000khz_10ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("L16", 32000, 2, 113, 320, 320)); | ||||
|   Run("5f025d4f390982cc26b3d92fe02e3044", | ||||
|       "50e58502fb04421bf5b857dda4c96879", | ||||
|       100, | ||||
|       test::AcmReceiveTest::kStereoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcmu_20ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("PCMU", 8000, 1, 0, 160, 160)); | ||||
|   Run("81a9d4c0bb72e9becc43aef124c981e9", | ||||
|       "8f9b8750bd80fe26b6cbf6659b89f0f9", | ||||
|       50, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcma_20ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("PCMA", 8000, 1, 8, 160, 160)); | ||||
|   Run("39611f798969053925a49dc06d08de29", | ||||
|       "6ad745e55aa48981bfc790d0eeef2dd1", | ||||
|       50, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcmu_stereo_20ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("PCMU", 8000, 2, 110, 160, 160)); | ||||
|   Run("437bec032fdc5cbaa0d5175430af7b18", | ||||
|       "60b6f25e8d1e74cb679cfe756dd9bca5", | ||||
|       50, | ||||
|       test::AcmReceiveTest::kStereoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Pcma_stereo_20ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("PCMA", 8000, 2, 118, 160, 160)); | ||||
|   Run("a5c6d83c5b7cedbeff734238220a4b0c", | ||||
|       "92b282c83efd20e7eeef52ba40842cf7", | ||||
|       50, | ||||
|       test::AcmReceiveTest::kStereoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, DISABLED_ON_ANDROID(Ilbc_30ms)) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("ILBC", 8000, 1, 102, 240, 240)); | ||||
|   Run(AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "7b6ec10910debd9af08011d3ed5249f7", | ||||
|           "android_audio", | ||||
|           "7b6ec10910debd9af08011d3ed5249f7"), | ||||
|       AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "cfae2e9f6aba96e145f2bcdd5050ce78", | ||||
|           "android_payload", | ||||
|           "cfae2e9f6aba96e145f2bcdd5050ce78"), | ||||
|       33, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, DISABLED_ON_ANDROID(G722_20ms)) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("G722", 16000, 1, 9, 320, 160)); | ||||
|   Run(AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "7d759436f2533582950d148b5161a36c", | ||||
|           "android_audio", | ||||
|           "7d759436f2533582950d148b5161a36c"), | ||||
|       AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "fc68a87e1380614e658087cb35d5ca10", | ||||
|           "android_payload", | ||||
|           "fc68a87e1380614e658087cb35d5ca10"), | ||||
|       50, | ||||
|       test::AcmReceiveTest::kMonoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, DISABLED_ON_ANDROID(G722_stereo_20ms)) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("G722", 16000, 2, 119, 320, 160)); | ||||
|   Run(AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "7190ee718ab3d80eca181e5f7140c210", | ||||
|           "android_audio", | ||||
|           "7190ee718ab3d80eca181e5f7140c210"), | ||||
|       AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "66516152eeaa1e650ad94ff85f668dac", | ||||
|           "android_payload", | ||||
|           "66516152eeaa1e650ad94ff85f668dac"), | ||||
|       50, | ||||
|       test::AcmReceiveTest::kStereoOutput); | ||||
| } | ||||
|  | ||||
| TEST_F(AcmSenderBitExactness, Opus_stereo_20ms) { | ||||
|   ASSERT_NO_FATAL_FAILURE(SetUpTest("opus", 48000, 2, 120, 960, 960)); | ||||
|   Run(AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "855041f2490b887302bce9d544731849", | ||||
|           "1e1a0fce893fef2d66886a7f09e2ebce", | ||||
|           "855041f2490b887302bce9d544731849"), | ||||
|       AcmReceiverBitExactness::PlatformChecksum( | ||||
|           "d781cce1ab986b618d0da87226cdde30", | ||||
|           "1a1fe04dd12e755949987c8d729fb3e0", | ||||
|           "d781cce1ab986b618d0da87226cdde30"), | ||||
|       50, | ||||
|       test::AcmReceiveTest::kStereoOutput); | ||||
| } | ||||
|  | ||||
| }  // namespace webrtc | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 henrik.lundin@webrtc.org
					henrik.lundin@webrtc.org