blob: 2002068d66f163bb502c789fdeed0d6b40126c62 [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
tina.legrand@webrtc.orgdf697752012-02-08 10:22:21 +00002 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
niklase@google.com470e71d2011-07-07 08:21:25 +00003 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#include "modules/audio_coding/test/TestStereo.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000012
pbos@webrtc.org12dc1a32013-08-05 16:22:53 +000013#include <assert.h>
14
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +000015#include <string>
kjellander@webrtc.org5490c712011-12-21 13:34:18 +000016
Karl Wiberg5817d3d2018-04-06 10:06:42 +020017#include "api/audio_codecs/builtin_audio_decoder_factory.h"
Mirko Bonadei71207422017-09-15 13:58:09 +020018#include "common_types.h" // NOLINT(build/include)
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020019#include "modules/audio_coding/codecs/audio_format_conversion.h"
20#include "modules/audio_coding/include/audio_coding_module_typedefs.h"
21#include "modules/audio_coding/test/utility.h"
22#include "test/gtest.h"
23#include "test/testsupport/fileutils.h"
Mirko Bonadei71207422017-09-15 13:58:09 +020024#include "typedefs.h" // NOLINT(build/include)
niklase@google.com470e71d2011-07-07 08:21:25 +000025
tina.legrand@webrtc.org554ae1a2011-12-16 10:09:04 +000026namespace webrtc {
niklase@google.com470e71d2011-07-07 08:21:25 +000027
28// Class for simulating packet handling
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000029TestPackStereo::TestPackStereo()
30 : receiver_acm_(NULL),
31 seq_no_(0),
32 timestamp_diff_(0),
33 last_in_timestamp_(0),
34 total_bytes_(0),
35 payload_size_(0),
36 codec_mode_(kNotSet),
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000037 lost_packet_(false) {
38}
niklase@google.com470e71d2011-07-07 08:21:25 +000039
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000040TestPackStereo::~TestPackStereo() {
41}
niklase@google.com470e71d2011-07-07 08:21:25 +000042
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000043void TestPackStereo::RegisterReceiverACM(AudioCodingModule* acm) {
44 receiver_acm_ = acm;
45 return;
46}
niklase@google.com470e71d2011-07-07 08:21:25 +000047
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000048int32_t TestPackStereo::SendData(const FrameType frame_type,
49 const uint8_t payload_type,
50 const uint32_t timestamp,
51 const uint8_t* payload_data,
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +000052 const size_t payload_size,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000053 const RTPFragmentationHeader* fragmentation) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000054 WebRtcRTPHeader rtp_info;
pbos@webrtc.org0946a562013-04-09 00:28:06 +000055 int32_t status = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +000056
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000057 rtp_info.header.markerBit = false;
58 rtp_info.header.ssrc = 0;
59 rtp_info.header.sequenceNumber = seq_no_++;
60 rtp_info.header.payloadType = payload_type;
61 rtp_info.header.timestamp = timestamp;
pbos22993e12015-10-19 02:39:06 -070062 if (frame_type == kEmptyFrame) {
tina.legrand@webrtc.org16b6b902012-04-12 11:02:38 +000063 // Skip this frame
64 return 0;
65 }
niklase@google.com470e71d2011-07-07 08:21:25 +000066
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000067 if (lost_packet_ == false) {
68 if (frame_type != kAudioFrameCN) {
69 rtp_info.type.Audio.isCNG = false;
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +000070 rtp_info.type.Audio.channel = static_cast<int>(codec_mode_);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +000071 } else {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000072 rtp_info.type.Audio.isCNG = true;
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +000073 rtp_info.type.Audio.channel = static_cast<int>(kMono);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +000074 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000075 status = receiver_acm_->IncomingPacket(payload_data, payload_size,
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +000076 rtp_info);
niklase@google.com470e71d2011-07-07 08:21:25 +000077
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000078 if (frame_type != kAudioFrameCN) {
henrike@webrtc.org6ac22e62014-08-11 21:06:30 +000079 payload_size_ = static_cast<int>(payload_size);
niklase@google.com470e71d2011-07-07 08:21:25 +000080 } else {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000081 payload_size_ = -1;
niklase@google.com470e71d2011-07-07 08:21:25 +000082 }
tina.legrand@webrtc.org16b6b902012-04-12 11:02:38 +000083
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000084 timestamp_diff_ = timestamp - last_in_timestamp_;
85 last_in_timestamp_ = timestamp;
86 total_bytes_ += payload_size;
tina.legrand@webrtc.org16b6b902012-04-12 11:02:38 +000087 }
88 return status;
niklase@google.com470e71d2011-07-07 08:21:25 +000089}
90
pbos@webrtc.org0946a562013-04-09 00:28:06 +000091uint16_t TestPackStereo::payload_size() {
henrike@webrtc.org6ac22e62014-08-11 21:06:30 +000092 return static_cast<uint16_t>(payload_size_);
niklase@google.com470e71d2011-07-07 08:21:25 +000093}
94
pbos@webrtc.org0946a562013-04-09 00:28:06 +000095uint32_t TestPackStereo::timestamp_diff() {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000096 return timestamp_diff_;
niklase@google.com470e71d2011-07-07 08:21:25 +000097}
98
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +000099void TestPackStereo::reset_payload_size() {
100 payload_size_ = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000101}
102
tina.legrand@webrtc.org16b6b902012-04-12 11:02:38 +0000103void TestPackStereo::set_codec_mode(enum StereoMonoMode mode) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000104 codec_mode_ = mode;
tina.legrand@webrtc.org16b6b902012-04-12 11:02:38 +0000105}
106
107void TestPackStereo::set_lost_packet(bool lost) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000108 lost_packet_ = lost;
niklase@google.com470e71d2011-07-07 08:21:25 +0000109}
110
henrik.lundin@webrtc.orgadaf8092014-04-17 08:29:10 +0000111TestStereo::TestStereo(int test_mode)
Karl Wiberg5817d3d2018-04-06 10:06:42 +0200112 : acm_a_(AudioCodingModule::Create(
113 AudioCodingModule::Config(CreateBuiltinAudioDecoderFactory()))),
114 acm_b_(AudioCodingModule::Create(
115 AudioCodingModule::Config(CreateBuiltinAudioDecoderFactory()))),
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000116 channel_a2b_(NULL),
117 test_cntr_(0),
118 pack_size_samp_(0),
119 pack_size_bytes_(0),
Karl Wibergeb254b42017-11-01 15:08:12 +0100120 counter_(0),
121 g722_pltype_(0),
122 l16_8khz_pltype_(-1),
123 l16_16khz_pltype_(-1),
124 l16_32khz_pltype_(-1)
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +0000125#ifdef PCMA_AND_PCMU
Karl Wiberg5817d3d2018-04-06 10:06:42 +0200126 ,
127 pcma_pltype_(-1),
128 pcmu_pltype_(-1)
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +0000129#endif
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +0000130#ifdef WEBRTC_CODEC_OPUS
Karl Wiberg5817d3d2018-04-06 10:06:42 +0200131 ,
132 opus_pltype_(-1)
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +0000133#endif
Karl Wibergeb254b42017-11-01 15:08:12 +0100134{
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000135 // test_mode = 0 for silent test (auto test)
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000136 test_mode_ = test_mode;
niklase@google.com470e71d2011-07-07 08:21:25 +0000137}
138
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000139TestStereo::~TestStereo() {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000140 if (channel_a2b_ != NULL) {
141 delete channel_a2b_;
142 channel_a2b_ = NULL;
143 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000144}
145
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000146void TestStereo::Perform() {
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000147 uint16_t frequency_hz;
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000148 int audio_channels;
149 int codec_channels;
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000150 bool dtx;
151 bool vad;
152 ACMVADMode vad_mode;
niklase@google.com470e71d2011-07-07 08:21:25 +0000153
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000154 // Open both mono and stereo test files in 32 kHz.
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000155 const std::string file_name_stereo = webrtc::test::ResourcePath(
156 "audio_coding/teststereo32kHz", "pcm");
157 const std::string file_name_mono = webrtc::test::ResourcePath(
158 "audio_coding/testfile32kHz", "pcm");
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000159 frequency_hz = 32000;
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000160 in_file_stereo_ = new PCMFile();
161 in_file_mono_ = new PCMFile();
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000162 in_file_stereo_->Open(file_name_stereo, frequency_hz, "rb");
163 in_file_stereo_->ReadStereo(true);
164 in_file_mono_->Open(file_name_mono, frequency_hz, "rb");
165 in_file_mono_->ReadStereo(false);
166
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000167 // Create and initialize two ACMs, one for each side of a one-to-one call.
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000168 ASSERT_TRUE((acm_a_.get() != NULL) && (acm_b_.get() != NULL));
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000169 EXPECT_EQ(0, acm_a_->InitializeReceiver());
170 EXPECT_EQ(0, acm_b_->InitializeReceiver());
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000171
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000172 // Register all available codes as receiving codecs.
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000173 uint8_t num_encoders = acm_a_->NumberOfCodecs();
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000174 CodecInst my_codec_param;
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000175 for (uint8_t n = 0; n < num_encoders; n++) {
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000176 EXPECT_EQ(0, acm_b_->Codec(n, &my_codec_param));
kwibergda2bf4e2016-10-24 13:47:09 -0700177 EXPECT_EQ(true, acm_b_->RegisterReceiveCodec(
178 my_codec_param.pltype, CodecInstToSdp(my_codec_param)));
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000179 }
180
181 // Test that unregister all receive codecs works.
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000182 for (uint8_t n = 0; n < num_encoders; n++) {
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000183 EXPECT_EQ(0, acm_b_->Codec(n, &my_codec_param));
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000184 EXPECT_EQ(0, acm_b_->UnregisterReceiveCodec(my_codec_param.pltype));
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000185 }
tina.legrand@webrtc.orgae1c4542012-03-12 08:41:30 +0000186
tina.legrand@webrtc.org45175852012-06-01 09:27:35 +0000187 // Register all available codes as receiving codecs once more.
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000188 for (uint8_t n = 0; n < num_encoders; n++) {
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000189 EXPECT_EQ(0, acm_b_->Codec(n, &my_codec_param));
kwibergda2bf4e2016-10-24 13:47:09 -0700190 EXPECT_EQ(true, acm_b_->RegisterReceiveCodec(
191 my_codec_param.pltype, CodecInstToSdp(my_codec_param)));
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000192 }
tina.legrand@webrtc.orgae1c4542012-03-12 08:41:30 +0000193
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000194 // Create and connect the channel.
195 channel_a2b_ = new TestPackStereo;
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000196 EXPECT_EQ(0, acm_a_->RegisterTransportCallback(channel_a2b_));
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000197 channel_a2b_->RegisterReceiverACM(acm_b_.get());
tina.legrand@webrtc.orgdf697752012-02-08 10:22:21 +0000198
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000199 // Start with setting VAD/DTX, before we know we will send stereo.
200 // Continue with setting a stereo codec as send codec and verify that
201 // VAD/DTX gets turned off.
202 EXPECT_EQ(0, acm_a_->SetVAD(true, true, VADNormal));
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000203 EXPECT_EQ(0, acm_a_->VAD(&dtx, &vad, &vad_mode));
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000204 EXPECT_TRUE(dtx);
205 EXPECT_TRUE(vad);
206 char codec_pcma_temp[] = "PCMA";
207 RegisterSendCodec('A', codec_pcma_temp, 8000, 64000, 80, 2, pcma_pltype_);
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000208 EXPECT_EQ(0, acm_a_->VAD(&dtx, &vad, &vad_mode));
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000209 EXPECT_FALSE(dtx);
210 EXPECT_FALSE(vad);
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000211 if (test_mode_ != 0) {
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000212 printf("\n");
213 }
214
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000215 //
216 // Test Stereo-To-Stereo for all codecs.
217 //
218 audio_channels = 2;
219 codec_channels = 2;
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000220
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000221 // All codecs are tested for all allowed sampling frequencies, rates and
222 // packet sizes.
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000223 if (test_mode_ != 0) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000224 printf("===========================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000225 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000226 printf("Test type: Stereo-to-stereo\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000227 }
228 channel_a2b_->set_codec_mode(kStereo);
229 test_cntr_++;
230 OpenOutFile(test_cntr_);
231 char codec_g722[] = "G722";
232 RegisterSendCodec('A', codec_g722, 16000, 64000, 160, codec_channels,
233 g722_pltype_);
234 Run(channel_a2b_, audio_channels, codec_channels);
235 RegisterSendCodec('A', codec_g722, 16000, 64000, 320, codec_channels,
236 g722_pltype_);
237 Run(channel_a2b_, audio_channels, codec_channels);
238 RegisterSendCodec('A', codec_g722, 16000, 64000, 480, codec_channels,
239 g722_pltype_);
240 Run(channel_a2b_, audio_channels, codec_channels);
241 RegisterSendCodec('A', codec_g722, 16000, 64000, 640, codec_channels,
242 g722_pltype_);
243 Run(channel_a2b_, audio_channels, codec_channels);
244 RegisterSendCodec('A', codec_g722, 16000, 64000, 800, codec_channels,
245 g722_pltype_);
246 Run(channel_a2b_, audio_channels, codec_channels);
247 RegisterSendCodec('A', codec_g722, 16000, 64000, 960, codec_channels,
248 g722_pltype_);
249 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000250 out_file_.Close();
Karl Wibergeb254b42017-11-01 15:08:12 +0100251
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000252 if (test_mode_ != 0) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000253 printf("===========================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000254 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000255 printf("Test type: Stereo-to-stereo\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000256 }
257 channel_a2b_->set_codec_mode(kStereo);
258 test_cntr_++;
259 OpenOutFile(test_cntr_);
260 char codec_l16[] = "L16";
261 RegisterSendCodec('A', codec_l16, 8000, 128000, 80, codec_channels,
262 l16_8khz_pltype_);
263 Run(channel_a2b_, audio_channels, codec_channels);
264 RegisterSendCodec('A', codec_l16, 8000, 128000, 160, codec_channels,
265 l16_8khz_pltype_);
266 Run(channel_a2b_, audio_channels, codec_channels);
267 RegisterSendCodec('A', codec_l16, 8000, 128000, 240, codec_channels,
268 l16_8khz_pltype_);
269 Run(channel_a2b_, audio_channels, codec_channels);
270 RegisterSendCodec('A', codec_l16, 8000, 128000, 320, codec_channels,
271 l16_8khz_pltype_);
272 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000273 out_file_.Close();
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000274
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000275 if (test_mode_ != 0) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000276 printf("===========================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000277 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000278 printf("Test type: Stereo-to-stereo\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000279 }
280 test_cntr_++;
281 OpenOutFile(test_cntr_);
282 RegisterSendCodec('A', codec_l16, 16000, 256000, 160, codec_channels,
283 l16_16khz_pltype_);
284 Run(channel_a2b_, audio_channels, codec_channels);
285 RegisterSendCodec('A', codec_l16, 16000, 256000, 320, codec_channels,
286 l16_16khz_pltype_);
287 Run(channel_a2b_, audio_channels, codec_channels);
288 RegisterSendCodec('A', codec_l16, 16000, 256000, 480, codec_channels,
289 l16_16khz_pltype_);
290 Run(channel_a2b_, audio_channels, codec_channels);
291 RegisterSendCodec('A', codec_l16, 16000, 256000, 640, codec_channels,
292 l16_16khz_pltype_);
293 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000294 out_file_.Close();
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000295
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000296 if (test_mode_ != 0) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000297 printf("===========================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000298 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000299 printf("Test type: Stereo-to-stereo\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000300 }
301 test_cntr_++;
302 OpenOutFile(test_cntr_);
303 RegisterSendCodec('A', codec_l16, 32000, 512000, 320, codec_channels,
304 l16_32khz_pltype_);
305 Run(channel_a2b_, audio_channels, codec_channels);
306 RegisterSendCodec('A', codec_l16, 32000, 512000, 640, codec_channels,
307 l16_32khz_pltype_);
308 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000309 out_file_.Close();
niklase@google.com470e71d2011-07-07 08:21:25 +0000310#ifdef PCMA_AND_PCMU
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000311 if (test_mode_ != 0) {
312 printf("===========================================================\n");
313 printf("Test number: %d\n", test_cntr_ + 1);
314 printf("Test type: Stereo-to-stereo\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000315 }
316 channel_a2b_->set_codec_mode(kStereo);
317 audio_channels = 2;
318 codec_channels = 2;
319 test_cntr_++;
320 OpenOutFile(test_cntr_);
321 char codec_pcma[] = "PCMA";
322 RegisterSendCodec('A', codec_pcma, 8000, 64000, 80, codec_channels,
323 pcma_pltype_);
324 Run(channel_a2b_, audio_channels, codec_channels);
325 RegisterSendCodec('A', codec_pcma, 8000, 64000, 160, codec_channels,
326 pcma_pltype_);
327 Run(channel_a2b_, audio_channels, codec_channels);
328 RegisterSendCodec('A', codec_pcma, 8000, 64000, 240, codec_channels,
329 pcma_pltype_);
330 Run(channel_a2b_, audio_channels, codec_channels);
331 RegisterSendCodec('A', codec_pcma, 8000, 64000, 320, codec_channels,
332 pcma_pltype_);
333 Run(channel_a2b_, audio_channels, codec_channels);
334 RegisterSendCodec('A', codec_pcma, 8000, 64000, 400, codec_channels,
335 pcma_pltype_);
336 Run(channel_a2b_, audio_channels, codec_channels);
337 RegisterSendCodec('A', codec_pcma, 8000, 64000, 480, codec_channels,
338 pcma_pltype_);
339 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000340
341 // Test that VAD/DTX cannot be turned on while sending stereo.
342 EXPECT_EQ(-1, acm_a_->SetVAD(true, true, VADNormal));
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000343 EXPECT_EQ(0, acm_a_->VAD(&dtx, &vad, &vad_mode));
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000344 EXPECT_FALSE(dtx);
345 EXPECT_FALSE(vad);
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000346 EXPECT_EQ(0, acm_a_->SetVAD(false, false, VADNormal));
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000347 EXPECT_EQ(0, acm_a_->VAD(&dtx, &vad, &vad_mode));
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000348 EXPECT_FALSE(dtx);
349 EXPECT_FALSE(vad);
350
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000351 out_file_.Close();
352 if (test_mode_ != 0) {
353 printf("===========================================================\n");
354 printf("Test number: %d\n", test_cntr_ + 1);
355 printf("Test type: Stereo-to-stereo\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000356 }
357 test_cntr_++;
358 OpenOutFile(test_cntr_);
359 char codec_pcmu[] = "PCMU";
360 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 80, codec_channels,
361 pcmu_pltype_);
362 Run(channel_a2b_, audio_channels, codec_channels);
363 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 160, codec_channels,
364 pcmu_pltype_);
365 Run(channel_a2b_, audio_channels, codec_channels);
366 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 240, codec_channels,
367 pcmu_pltype_);
368 Run(channel_a2b_, audio_channels, codec_channels);
369 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 320, codec_channels,
370 pcmu_pltype_);
371 Run(channel_a2b_, audio_channels, codec_channels);
372 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 400, codec_channels,
373 pcmu_pltype_);
374 Run(channel_a2b_, audio_channels, codec_channels);
375 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 480, codec_channels,
376 pcmu_pltype_);
377 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000378 out_file_.Close();
niklase@google.com470e71d2011-07-07 08:21:25 +0000379#endif
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000380#ifdef WEBRTC_CODEC_OPUS
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000381 if (test_mode_ != 0) {
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000382 printf("===========================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000383 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000384 printf("Test type: Stereo-to-stereo\n");
385 }
386 channel_a2b_->set_codec_mode(kStereo);
387 audio_channels = 2;
388 codec_channels = 2;
389 test_cntr_++;
390 OpenOutFile(test_cntr_);
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000391
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000392 char codec_opus[] = "opus";
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000393 // Run Opus with 10 ms frame size.
394 RegisterSendCodec('A', codec_opus, 48000, 64000, 480, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000395 opus_pltype_);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000396 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000397 // Run Opus with 20 ms frame size.
398 RegisterSendCodec('A', codec_opus, 48000, 64000, 480*2, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000399 opus_pltype_);
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000400 Run(channel_a2b_, audio_channels, codec_channels);
401 // Run Opus with 40 ms frame size.
402 RegisterSendCodec('A', codec_opus, 48000, 64000, 480*4, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000403 opus_pltype_);
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000404 Run(channel_a2b_, audio_channels, codec_channels);
405 // Run Opus with 60 ms frame size.
406 RegisterSendCodec('A', codec_opus, 48000, 64000, 480*6, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000407 opus_pltype_);
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000408 Run(channel_a2b_, audio_channels, codec_channels);
409 // Run Opus with 20 ms frame size and different bitrates.
410 RegisterSendCodec('A', codec_opus, 48000, 40000, 960, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000411 opus_pltype_);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000412 Run(channel_a2b_, audio_channels, codec_channels);
413 RegisterSendCodec('A', codec_opus, 48000, 510000, 960, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000414 opus_pltype_);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000415 Run(channel_a2b_, audio_channels, codec_channels);
416 out_file_.Close();
417#endif
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000418 //
419 // Test Mono-To-Stereo for all codecs.
420 //
421 audio_channels = 1;
422 codec_channels = 2;
niklase@google.com470e71d2011-07-07 08:21:25 +0000423
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000424 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000425 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000426 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000427 printf("Test type: Mono-to-stereo\n");
428 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000429 test_cntr_++;
430 channel_a2b_->set_codec_mode(kStereo);
431 OpenOutFile(test_cntr_);
432 RegisterSendCodec('A', codec_g722, 16000, 64000, 160, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000433 g722_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000434 Run(channel_a2b_, audio_channels, codec_channels);
435 out_file_.Close();
Karl Wibergeb254b42017-11-01 15:08:12 +0100436
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000437 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000438 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000439 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000440 printf("Test type: Mono-to-stereo\n");
441 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000442 test_cntr_++;
443 channel_a2b_->set_codec_mode(kStereo);
444 OpenOutFile(test_cntr_);
445 RegisterSendCodec('A', codec_l16, 8000, 128000, 80, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000446 l16_8khz_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000447 Run(channel_a2b_, audio_channels, codec_channels);
448 out_file_.Close();
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000449 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000450 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000451 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000452 printf("Test type: Mono-to-stereo\n");
453 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000454 test_cntr_++;
455 OpenOutFile(test_cntr_);
456 RegisterSendCodec('A', codec_l16, 16000, 256000, 160, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000457 l16_16khz_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000458 Run(channel_a2b_, audio_channels, codec_channels);
459 out_file_.Close();
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000460 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000461 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000462 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000463 printf("Test type: Mono-to-stereo\n");
464 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000465 test_cntr_++;
466 OpenOutFile(test_cntr_);
467 RegisterSendCodec('A', codec_l16, 32000, 512000, 320, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000468 l16_32khz_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000469 Run(channel_a2b_, audio_channels, codec_channels);
470 out_file_.Close();
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000471#ifdef PCMA_AND_PCMU
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000472 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000473 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000474 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000475 printf("Test type: Mono-to-stereo\n");
476 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000477 test_cntr_++;
478 channel_a2b_->set_codec_mode(kStereo);
479 OpenOutFile(test_cntr_);
480 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 80, codec_channels,
tina.legrand@webrtc.orgae1c4542012-03-12 08:41:30 +0000481 pcmu_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000482 Run(channel_a2b_, audio_channels, codec_channels);
483 RegisterSendCodec('A', codec_pcma, 8000, 64000, 80, codec_channels,
tina.legrand@webrtc.orgae1c4542012-03-12 08:41:30 +0000484 pcma_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000485 Run(channel_a2b_, audio_channels, codec_channels);
486 out_file_.Close();
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000487#endif
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000488#ifdef WEBRTC_CODEC_OPUS
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000489 if (test_mode_ != 0) {
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000490 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000491 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000492 printf("Test type: Mono-to-stereo\n");
493 }
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000494
495 // Keep encode and decode in stereo.
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000496 test_cntr_++;
497 channel_a2b_->set_codec_mode(kStereo);
498 OpenOutFile(test_cntr_);
499 RegisterSendCodec('A', codec_opus, 48000, 64000, 960, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000500 opus_pltype_);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000501 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000502
503 // Encode in mono, decode in stereo mode.
504 RegisterSendCodec('A', codec_opus, 48000, 64000, 960, 1, opus_pltype_);
505 Run(channel_a2b_, audio_channels, codec_channels);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000506 out_file_.Close();
507#endif
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000508
509 //
510 // Test Stereo-To-Mono for all codecs.
511 //
512 audio_channels = 2;
513 codec_channels = 1;
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000514 channel_a2b_->set_codec_mode(kMono);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000515
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000516 // Run stereo audio and mono codec.
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000517 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000518 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000519 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000520 printf("Test type: Stereo-to-mono\n");
521 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000522 test_cntr_++;
523 OpenOutFile(test_cntr_);
524 RegisterSendCodec('A', codec_g722, 16000, 64000, 160, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000525 g722_pltype_);
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000526
527 // Make sure it is possible to set VAD/CNG, now that we are sending mono
528 // again.
529 EXPECT_EQ(0, acm_a_->SetVAD(true, true, VADNormal));
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000530 EXPECT_EQ(0, acm_a_->VAD(&dtx, &vad, &vad_mode));
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000531 EXPECT_TRUE(dtx);
532 EXPECT_TRUE(vad);
533 EXPECT_EQ(0, acm_a_->SetVAD(false, false, VADNormal));
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000534 Run(channel_a2b_, audio_channels, codec_channels);
535 out_file_.Close();
Karl Wibergeb254b42017-11-01 15:08:12 +0100536
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000537 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000538 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000539 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000540 printf("Test type: Stereo-to-mono\n");
541 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000542 test_cntr_++;
543 OpenOutFile(test_cntr_);
544 RegisterSendCodec('A', codec_l16, 8000, 128000, 80, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000545 l16_8khz_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000546 Run(channel_a2b_, audio_channels, codec_channels);
547 out_file_.Close();
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000548 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000549 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000550 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000551 printf("Test type: Stereo-to-mono\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000552 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000553 test_cntr_++;
554 OpenOutFile(test_cntr_);
555 RegisterSendCodec('A', codec_l16, 16000, 256000, 160, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000556 l16_16khz_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000557 Run(channel_a2b_, audio_channels, codec_channels);
558 out_file_.Close();
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000559 if (test_mode_ != 0) {
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000560 printf("==============================================================\n");
561 printf("Test number: %d\n", test_cntr_ + 1);
562 printf("Test type: Stereo-to-mono\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000563 }
564 test_cntr_++;
565 OpenOutFile(test_cntr_);
566 RegisterSendCodec('A', codec_l16, 32000, 512000, 320, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000567 l16_32khz_pltype_);
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000568 Run(channel_a2b_, audio_channels, codec_channels);
569 out_file_.Close();
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000570#ifdef PCMA_AND_PCMU
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000571 if (test_mode_ != 0) {
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000572 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000573 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.orgdf697752012-02-08 10:22:21 +0000574 printf("Test type: Stereo-to-mono\n");
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000575 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000576 test_cntr_++;
577 OpenOutFile(test_cntr_);
578 RegisterSendCodec('A', codec_pcmu, 8000, 64000, 80, codec_channels,
tina.legrand@webrtc.orgae1c4542012-03-12 08:41:30 +0000579 pcmu_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000580 Run(channel_a2b_, audio_channels, codec_channels);
581 RegisterSendCodec('A', codec_pcma, 8000, 64000, 80, codec_channels,
tina.legrand@webrtc.orgae1c4542012-03-12 08:41:30 +0000582 pcma_pltype_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000583 Run(channel_a2b_, audio_channels, codec_channels);
584 out_file_.Close();
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000585#endif
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000586#ifdef WEBRTC_CODEC_OPUS
tina.legrand@webrtc.org46d90dc2013-02-01 14:20:06 +0000587 if (test_mode_ != 0) {
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000588 printf("===============================================================\n");
tina.legrand@webrtc.orga092cbf2013-02-14 09:28:10 +0000589 printf("Test number: %d\n", test_cntr_ + 1);
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000590 printf("Test type: Stereo-to-mono\n");
591 }
592 test_cntr_++;
593 OpenOutFile(test_cntr_);
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000594 // Encode and decode in mono.
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000595 RegisterSendCodec('A', codec_opus, 48000, 32000, 960, codec_channels,
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000596 opus_pltype_);
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000597 CodecInst opus_codec_param;
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000598 for (uint8_t n = 0; n < num_encoders; n++) {
tina.legrand@webrtc.org7a7a0082013-02-21 10:27:48 +0000599 EXPECT_EQ(0, acm_b_->Codec(n, &opus_codec_param));
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000600 if (!strcmp(opus_codec_param.plname, "opus")) {
601 opus_codec_param.channels = 1;
kwibergda2bf4e2016-10-24 13:47:09 -0700602 EXPECT_EQ(true,
603 acm_b_->RegisterReceiveCodec(opus_codec_param.pltype,
604 CodecInstToSdp(opus_codec_param)));
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000605 break;
606 }
607 }
608 Run(channel_a2b_, audio_channels, codec_channels);
609
610 // Encode in stereo, decode in mono.
611 RegisterSendCodec('A', codec_opus, 48000, 32000, 960, 2, opus_pltype_);
612 Run(channel_a2b_, audio_channels, codec_channels);
613
614 out_file_.Close();
615
616 // Test switching between decoding mono and stereo for Opus.
617
618 // Decode in mono.
619 test_cntr_++;
620 OpenOutFile(test_cntr_);
621 if (test_mode_ != 0) {
622 // Print out codec and settings
623 printf("Test number: %d\nCodec: Opus Freq: 48000 Rate :32000 PackSize: 960"
624 " Decode: mono\n", test_cntr_);
625 }
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000626 Run(channel_a2b_, audio_channels, codec_channels);
627 out_file_.Close();
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000628 // Decode in stereo.
629 test_cntr_++;
630 OpenOutFile(test_cntr_);
631 if (test_mode_ != 0) {
632 // Print out codec and settings
633 printf("Test number: %d\nCodec: Opus Freq: 48000 Rate :32000 PackSize: 960"
634 " Decode: stereo\n", test_cntr_);
635 }
636 opus_codec_param.channels = 2;
kwibergda2bf4e2016-10-24 13:47:09 -0700637 EXPECT_EQ(true,
638 acm_b_->RegisterReceiveCodec(opus_codec_param.pltype,
639 CodecInstToSdp(opus_codec_param)));
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000640 Run(channel_a2b_, audio_channels, 2);
641 out_file_.Close();
642 // Decode in mono.
643 test_cntr_++;
644 OpenOutFile(test_cntr_);
645 if (test_mode_ != 0) {
646 // Print out codec and settings
647 printf("Test number: %d\nCodec: Opus Freq: 48000 Rate :32000 PackSize: 960"
648 " Decode: mono\n", test_cntr_);
649 }
650 opus_codec_param.channels = 1;
kwibergda2bf4e2016-10-24 13:47:09 -0700651 EXPECT_EQ(true,
652 acm_b_->RegisterReceiveCodec(opus_codec_param.pltype,
653 CodecInstToSdp(opus_codec_param)));
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000654 Run(channel_a2b_, audio_channels, codec_channels);
655 out_file_.Close();
656
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000657#endif
tina.legrand@webrtc.org6b6ff552012-01-11 10:12:54 +0000658
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000659 // Print out which codecs were tested, and which were not, in the run.
660 if (test_mode_ != 0) {
661 printf("\nThe following codecs was INCLUDED in the test:\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000662 printf(" G.722\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000663 printf(" PCM16\n");
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000664 printf(" G.711\n");
tina.legrand@webrtc.orgc4590582012-11-28 12:23:29 +0000665#ifdef WEBRTC_CODEC_OPUS
666 printf(" Opus\n");
667#endif
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000668 printf("\nTo complete the test, listen to the %d number of output "
669 "files.\n",
670 test_cntr_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000671 }
672
673 // Delete the file pointers.
674 delete in_file_stereo_;
675 delete in_file_mono_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000676}
677
678// Register Codec to use in the test
679//
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000680// Input: side - which ACM to use, 'A' or 'B'
681// codec_name - name to use when register the codec
682// sampling_freq_hz - sampling frequency in Herz
683// rate - bitrate in bytes
684// pack_size - packet size in samples
685// channels - number of channels; 1 for mono, 2 for stereo
686// payload_type - payload type for the codec
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000687void TestStereo::RegisterSendCodec(char side, char* codec_name,
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000688 int32_t sampling_freq_hz, int rate,
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000689 int pack_size, int channels,
690 int payload_type) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000691 if (test_mode_ != 0) {
692 // Print out codec and settings
tina.legrand@webrtc.orgba468042012-08-17 10:38:28 +0000693 printf("Codec: %s Freq: %d Rate: %d PackSize: %d\n", codec_name,
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000694 sampling_freq_hz, rate, pack_size);
695 }
696
697 // Store packet size in samples, used to validate the received packet
698 pack_size_samp_ = pack_size;
699
700 // Store the expected packet size in bytes, used to validate the received
701 // packet. Add 0.875 to always round up to a whole byte.
pbos@webrtc.orgd8ca7232014-12-10 11:49:13 +0000702 pack_size_bytes_ = (uint16_t)(static_cast<float>(pack_size * rate) /
703 static_cast<float>(sampling_freq_hz * 8) +
704 0.875);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000705
706 // Set pointer to the ACM where to register the codec
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000707 AudioCodingModule* my_acm = NULL;
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000708 switch (side) {
709 case 'A': {
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000710 my_acm = acm_a_.get();
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000711 break;
niklase@google.com470e71d2011-07-07 08:21:25 +0000712 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000713 case 'B': {
andrew@webrtc.org89df0922013-09-12 01:27:43 +0000714 my_acm = acm_b_.get();
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000715 break;
tina.legrand@webrtc.org16b6b902012-04-12 11:02:38 +0000716 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000717 default:
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000718 break;
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000719 }
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000720 ASSERT_TRUE(my_acm != NULL);
niklase@google.com470e71d2011-07-07 08:21:25 +0000721
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000722 CodecInst my_codec_param;
723 // Get all codec parameters before registering
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000724 EXPECT_GT(AudioCodingModule::Codec(codec_name, &my_codec_param,
725 sampling_freq_hz, channels), -1);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000726 my_codec_param.rate = rate;
727 my_codec_param.pacsize = pack_size;
tina.legrand@webrtc.orgee92b662013-08-27 07:33:51 +0000728 EXPECT_EQ(0, my_acm->RegisterSendCodec(my_codec_param));
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000729
730 send_codec_name_ = codec_name;
niklase@google.com470e71d2011-07-07 08:21:25 +0000731}
732
tina.legrand@webrtc.org16b6b902012-04-12 11:02:38 +0000733void TestStereo::Run(TestPackStereo* channel, int in_channels, int out_channels,
734 int percent_loss) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000735 AudioFrame audio_frame;
niklase@google.com470e71d2011-07-07 08:21:25 +0000736
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000737 int32_t out_freq_hz_b = out_file_.SamplingFrequency();
738 uint16_t rec_size;
739 uint32_t time_stamp_diff;
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000740 channel->reset_payload_size();
741 int error_count = 0;
tina.legrand@webrtc.org65d61c32014-06-05 13:42:51 +0000742 int variable_bytes = 0;
743 int variable_packets = 0;
Henrik Lundin4d682082015-12-10 16:24:39 +0100744 // Set test length to 500 ms (50 blocks of 10 ms each).
745 in_file_mono_->SetNum10MsBlocksToRead(50);
746 in_file_stereo_->SetNum10MsBlocksToRead(50);
747 // Fast-forward 1 second (100 blocks) since the files start with silence.
748 in_file_stereo_->FastForward(100);
749 in_file_mono_->FastForward(100);
niklase@google.com470e71d2011-07-07 08:21:25 +0000750
andresp@webrtc.orgd0b436a2014-01-13 13:15:59 +0000751 while (1) {
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000752 // Simulate packet loss by setting |packet_loss_| to "true" in
753 // |percent_loss| percent of the loops.
754 if (percent_loss > 0) {
755 if (counter_ == floor((100 / percent_loss) + 0.5)) {
756 counter_ = 0;
757 channel->set_lost_packet(true);
758 } else {
759 channel->set_lost_packet(false);
760 }
761 counter_++;
niklase@google.com470e71d2011-07-07 08:21:25 +0000762 }
763
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000764 // Add 10 msec to ACM
765 if (in_channels == 1) {
766 if (in_file_mono_->EndOfFile()) {
767 break;
768 }
769 in_file_mono_->Read10MsData(audio_frame);
770 } else {
771 if (in_file_stereo_->EndOfFile()) {
772 break;
773 }
774 in_file_stereo_->Read10MsData(audio_frame);
775 }
henrik.lundin@webrtc.orgf56c1622015-03-02 12:29:30 +0000776 EXPECT_GE(acm_a_->Add10MsData(audio_frame), 0);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000777
tina.legrand@webrtc.org65d61c32014-06-05 13:42:51 +0000778 // Verify that the received packet size matches the settings.
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000779 rec_size = channel->payload_size();
780 if ((0 < rec_size) & (rec_size < 65535)) {
tina.legrand@webrtc.org65d61c32014-06-05 13:42:51 +0000781 if (strcmp(send_codec_name_, "opus") == 0) {
782 // Opus is a variable rate codec, hence calculate the average packet
783 // size, and later make sure the average is in the right range.
784 variable_bytes += rec_size;
785 variable_packets++;
786 } else {
787 // For fixed rate codecs, check that packet size is correct.
tina.legrand@webrtc.org0ad3c1a2012-11-07 08:07:29 +0000788 if ((rec_size != pack_size_bytes_ * out_channels)
789 && (pack_size_bytes_ < 65535)) {
790 error_count++;
791 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000792 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000793 // Verify that the timestamp is updated with expected length
794 time_stamp_diff = channel->timestamp_diff();
795 if ((counter_ > 10) && (time_stamp_diff != pack_size_samp_)) {
796 error_count++;
797 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000798 }
799
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000800 // Run received side of ACM
henrik.lundind4ccb002016-05-17 12:21:55 -0700801 bool muted;
802 EXPECT_EQ(0, acm_b_->PlayoutData10Ms(out_freq_hz_b, &audio_frame, &muted));
803 ASSERT_FALSE(muted);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000804
805 // Write output speech to file
806 out_file_.Write10MsData(
yujo36b1a5f2017-06-12 12:45:32 -0700807 audio_frame.data(),
andrew@webrtc.org63a50982012-05-02 23:56:37 +0000808 audio_frame.samples_per_channel_ * audio_frame.num_channels_);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000809 }
810
tina.legrand@webrtc.org3ddc9742012-06-27 09:25:50 +0000811 EXPECT_EQ(0, error_count);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000812
tina.legrand@webrtc.org65d61c32014-06-05 13:42:51 +0000813 // Check that packet size is in the right range for variable rate codecs,
814 // such as Opus.
815 if (variable_packets > 0) {
816 variable_bytes /= variable_packets;
Henrik Lundin4d682082015-12-10 16:24:39 +0100817 EXPECT_NEAR(variable_bytes, pack_size_bytes_, 18);
tina.legrand@webrtc.org65d61c32014-06-05 13:42:51 +0000818 }
819
andresp@webrtc.orgd0b436a2014-01-13 13:15:59 +0000820 if (in_file_mono_->EndOfFile()) {
821 in_file_mono_->Rewind();
822 }
823 if (in_file_stereo_->EndOfFile()) {
824 in_file_stereo_->Rewind();
825 }
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000826 // Reset in case we ended with a lost packet
827 channel->set_lost_packet(false);
niklase@google.com470e71d2011-07-07 08:21:25 +0000828}
829
pbos@webrtc.org0946a562013-04-09 00:28:06 +0000830void TestStereo::OpenOutFile(int16_t test_number) {
tina.legrand@webrtc.orgba468042012-08-17 10:38:28 +0000831 std::string file_name;
832 std::stringstream file_stream;
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +0000833 file_stream << webrtc::test::OutputPath() << "teststereo_out_" << test_number
834 << ".pcm";
tina.legrand@webrtc.orgba468042012-08-17 10:38:28 +0000835 file_name = file_stream.str();
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000836 out_file_.Open(file_name, 32000, "wb");
niklase@google.com470e71d2011-07-07 08:21:25 +0000837}
838
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000839void TestStereo::DisplaySendReceiveCodec() {
kwiberg1fd4a4a2015-11-03 11:20:50 -0800840 auto send_codec = acm_a_->SendCodec();
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000841 if (test_mode_ != 0) {
kwiberg1fd4a4a2015-11-03 11:20:50 -0800842 ASSERT_TRUE(send_codec);
843 printf("%s -> ", send_codec->plname);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000844 }
kwiberg1fd4a4a2015-11-03 11:20:50 -0800845 CodecInst receive_codec;
846 acm_b_->ReceiveCodec(&receive_codec);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000847 if (test_mode_ != 0) {
kwiberg1fd4a4a2015-11-03 11:20:50 -0800848 printf("%s\n", receive_codec.plname);
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000849 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000850}
851
tina.legrand@webrtc.orga6ecd1e2012-04-26 07:54:30 +0000852} // namespace webrtc