Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(556)

Side by Side Diff: webrtc/modules/audio_coding/neteq/neteq_stereo_unittest.cc

Issue 1238083005: [NOT FOR REVIEW] Convert channel counts to size_t. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc@size_t
Patch Set: Checkpoint Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 10 matching lines...) Expand all
21 #include "webrtc/modules/audio_coding/neteq/tools/input_audio_file.h" 21 #include "webrtc/modules/audio_coding/neteq/tools/input_audio_file.h"
22 #include "webrtc/modules/audio_coding/neteq/tools/rtp_generator.h" 22 #include "webrtc/modules/audio_coding/neteq/tools/rtp_generator.h"
23 #include "webrtc/test/testsupport/fileutils.h" 23 #include "webrtc/test/testsupport/fileutils.h"
24 #include "webrtc/test/testsupport/gtest_disable.h" 24 #include "webrtc/test/testsupport/gtest_disable.h"
25 25
26 namespace webrtc { 26 namespace webrtc {
27 27
28 struct TestParameters { 28 struct TestParameters {
29 int frame_size; 29 int frame_size;
30 int sample_rate; 30 int sample_rate;
31 int num_channels; 31 size_t num_channels;
32 }; 32 };
33 33
34 // This is a parameterized test. The test parameters are supplied through a 34 // This is a parameterized test. The test parameters are supplied through a
35 // TestParameters struct, which is obtained through the GetParam() method. 35 // TestParameters struct, which is obtained through the GetParam() method.
36 // 36 //
37 // The objective of the test is to create a mono input signal and a 37 // The objective of the test is to create a mono input signal and a
38 // multi-channel input signal, where each channel is identical to the mono 38 // multi-channel input signal, where each channel is identical to the mono
39 // input channel. The two input signals are processed through their respective 39 // input channel. The two input signals are processed through their respective
40 // NetEq instances. After that, the output signals are compared. The expected 40 // NetEq instances. After that, the output signals are compared. The expected
41 // result is that each channel in the multi-channel output is identical to the 41 // result is that each channel in the multi-channel output is identical to the
(...skipping 116 matching lines...) Expand 10 before | Expand all | Expand 10 after
158 if (frame_size_samples_ * 2 * num_channels_ != multi_payload_size_bytes_) { 158 if (frame_size_samples_ * 2 * num_channels_ != multi_payload_size_bytes_) {
159 return -1; 159 return -1;
160 } 160 }
161 rtp_generator_.GetRtpHeader(kPayloadTypeMulti, frame_size_samples_, 161 rtp_generator_.GetRtpHeader(kPayloadTypeMulti, frame_size_samples_,
162 &rtp_header_); 162 &rtp_header_);
163 return next_send_time; 163 return next_send_time;
164 } 164 }
165 165
166 void VerifyOutput(size_t num_samples) { 166 void VerifyOutput(size_t num_samples) {
167 for (size_t i = 0; i < num_samples; ++i) { 167 for (size_t i = 0; i < num_samples; ++i) {
168 for (int j = 0; j < num_channels_; ++j) { 168 for (size_t j = 0; j < num_channels_; ++j) {
169 ASSERT_EQ(output_[i], output_multi_channel_[i * num_channels_ + j]) << 169 ASSERT_EQ(output_[i], output_multi_channel_[i * num_channels_ + j]) <<
170 "Diff in sample " << i << ", channel " << j << "."; 170 "Diff in sample " << i << ", channel " << j << ".";
171 } 171 }
172 } 172 }
173 } 173 }
174 174
175 virtual int GetArrivalTime(int send_time) { 175 virtual int GetArrivalTime(int send_time) {
176 int arrival_time = last_arrival_time_ + (send_time - last_send_time_); 176 int arrival_time = last_arrival_time_ + (send_time - last_send_time_);
177 last_send_time_ = send_time; 177 last_send_time_ = send_time;
178 last_arrival_time_ = arrival_time; 178 last_arrival_time_ = arrival_time;
(...skipping 28 matching lines...) Expand all
207 // Get next input packets (mono and multi-channel). 207 // Get next input packets (mono and multi-channel).
208 do { 208 do {
209 next_send_time = GetNewPackets(); 209 next_send_time = GetNewPackets();
210 ASSERT_NE(-1, next_send_time); 210 ASSERT_NE(-1, next_send_time);
211 next_arrival_time = GetArrivalTime(next_send_time); 211 next_arrival_time = GetArrivalTime(next_send_time);
212 } while (Lost()); // If lost, immediately read the next packet. 212 } while (Lost()); // If lost, immediately read the next packet.
213 } 213 }
214 NetEqOutputType output_type; 214 NetEqOutputType output_type;
215 // Get audio from mono instance. 215 // Get audio from mono instance.
216 size_t samples_per_channel; 216 size_t samples_per_channel;
217 int num_channels; 217 size_t num_channels;
218 EXPECT_EQ(NetEq::kOK, 218 EXPECT_EQ(NetEq::kOK,
219 neteq_mono_->GetAudio(kMaxBlockSize, output_, 219 neteq_mono_->GetAudio(kMaxBlockSize, output_,
220 &samples_per_channel, &num_channels, 220 &samples_per_channel, &num_channels,
221 &output_type)); 221 &output_type));
222 EXPECT_EQ(1, num_channels); 222 EXPECT_EQ(1u, num_channels);
223 EXPECT_EQ(output_size_samples_, samples_per_channel); 223 EXPECT_EQ(output_size_samples_, samples_per_channel);
224 // Get audio from multi-channel instance. 224 // Get audio from multi-channel instance.
225 ASSERT_EQ(NetEq::kOK, 225 ASSERT_EQ(NetEq::kOK,
226 neteq_->GetAudio(kMaxBlockSize * num_channels_, 226 neteq_->GetAudio(kMaxBlockSize * num_channels_,
227 output_multi_channel_, 227 output_multi_channel_,
228 &samples_per_channel, &num_channels, 228 &samples_per_channel, &num_channels,
229 &output_type)); 229 &output_type));
230 EXPECT_EQ(num_channels_, num_channels); 230 EXPECT_EQ(num_channels_, num_channels);
231 EXPECT_EQ(output_size_samples_, samples_per_channel); 231 EXPECT_EQ(output_size_samples_, samples_per_channel);
232 std::ostringstream ss; 232 std::ostringstream ss;
233 ss << "Lap number " << k << "."; 233 ss << "Lap number " << k << ".";
234 SCOPED_TRACE(ss.str()); // Print out the parameter values on failure. 234 SCOPED_TRACE(ss.str()); // Print out the parameter values on failure.
235 // Compare mono and multi-channel. 235 // Compare mono and multi-channel.
236 ASSERT_NO_FATAL_FAILURE(VerifyOutput(output_size_samples_)); 236 ASSERT_NO_FATAL_FAILURE(VerifyOutput(output_size_samples_));
237 237
238 time_now += kTimeStepMs; 238 time_now += kTimeStepMs;
239 } 239 }
240 } 240 }
241 241
242 const int num_channels_; 242 const size_t num_channels_;
243 const int sample_rate_hz_; 243 const int sample_rate_hz_;
244 const int samples_per_ms_; 244 const int samples_per_ms_;
245 const int frame_size_ms_; 245 const int frame_size_ms_;
246 const size_t frame_size_samples_; 246 const size_t frame_size_samples_;
247 const size_t output_size_samples_; 247 const size_t output_size_samples_;
248 NetEq* neteq_mono_; 248 NetEq* neteq_mono_;
249 NetEq* neteq_; 249 NetEq* neteq_;
250 test::RtpGenerator rtp_generator_mono_; 250 test::RtpGenerator rtp_generator_mono_;
251 test::RtpGenerator rtp_generator_; 251 test::RtpGenerator rtp_generator_;
252 int16_t* input_; 252 int16_t* input_;
(...skipping 160 matching lines...) Expand 10 before | Expand all | Expand 10 after
413 413
414 INSTANTIATE_TEST_CASE_P(MultiChannel, 414 INSTANTIATE_TEST_CASE_P(MultiChannel,
415 NetEqStereoTestDelays, 415 NetEqStereoTestDelays,
416 ::testing::ValuesIn(GetTestParameters())); 416 ::testing::ValuesIn(GetTestParameters()));
417 417
418 INSTANTIATE_TEST_CASE_P(MultiChannel, 418 INSTANTIATE_TEST_CASE_P(MultiChannel,
419 NetEqStereoTestLosses, 419 NetEqStereoTestLosses,
420 ::testing::ValuesIn(GetTestParameters())); 420 ::testing::ValuesIn(GetTestParameters()));
421 421
422 } // namespace webrtc 422 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/modules/audio_coding/neteq/neteq_impl_unittest.cc ('k') | webrtc/modules/audio_coding/neteq/neteq_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698