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

Side by Side Diff: webrtc/modules/audio_coding/neteq/neteq_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) 2011 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2011 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 335 matching lines...) Expand 10 before | Expand all | Expand 10 after
346 packet_->payload_length_bytes(), 346 packet_->payload_length_bytes(),
347 static_cast<uint32_t>( 347 static_cast<uint32_t>(
348 packet_->time_ms() * (output_sample_rate_ / 1000)))); 348 packet_->time_ms() * (output_sample_rate_ / 1000))));
349 } 349 }
350 // Get next packet. 350 // Get next packet.
351 packet_.reset(rtp_source_->NextPacket()); 351 packet_.reset(rtp_source_->NextPacket());
352 } 352 }
353 353
354 // Get audio from NetEq. 354 // Get audio from NetEq.
355 NetEqOutputType type; 355 NetEqOutputType type;
356 int num_channels; 356 size_t num_channels;
357 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, out_len, 357 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, out_len,
358 &num_channels, &type)); 358 &num_channels, &type));
359 ASSERT_TRUE((*out_len == kBlockSize8kHz) || 359 ASSERT_TRUE((*out_len == kBlockSize8kHz) ||
360 (*out_len == kBlockSize16kHz) || 360 (*out_len == kBlockSize16kHz) ||
361 (*out_len == kBlockSize32kHz)); 361 (*out_len == kBlockSize32kHz));
362 output_sample_rate_ = static_cast<int>(*out_len / 10 * 1000); 362 output_sample_rate_ = static_cast<int>(*out_len / 10 * 1000);
363 363
364 // Increase time. 364 // Increase time.
365 sim_clock_ += kTimeStepMs; 365 sim_clock_ += kTimeStepMs;
366 } 366 }
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after
493 rtp_info.header.payloadType = 94; // PCM16b WB codec. 493 rtp_info.header.payloadType = 94; // PCM16b WB codec.
494 rtp_info.header.markerBit = 0; 494 rtp_info.header.markerBit = 0;
495 ASSERT_EQ(0, neteq_->InsertPacket( 495 ASSERT_EQ(0, neteq_->InsertPacket(
496 rtp_info, 496 rtp_info,
497 reinterpret_cast<uint8_t*>(payload), 497 reinterpret_cast<uint8_t*>(payload),
498 kPayloadBytes, 0)); 498 kPayloadBytes, 0));
499 } 499 }
500 // Pull out all data. 500 // Pull out all data.
501 for (size_t i = 0; i < num_frames; ++i) { 501 for (size_t i = 0; i < num_frames; ++i) {
502 size_t out_len; 502 size_t out_len;
503 int num_channels; 503 size_t num_channels;
504 NetEqOutputType type; 504 NetEqOutputType type;
505 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len, 505 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len,
506 &num_channels, &type)); 506 &num_channels, &type));
507 ASSERT_EQ(kBlockSize16kHz, out_len); 507 ASSERT_EQ(kBlockSize16kHz, out_len);
508 } 508 }
509 509
510 std::vector<int> waiting_times; 510 std::vector<int> waiting_times;
511 neteq_->WaitingTimes(&waiting_times); 511 neteq_->WaitingTimes(&waiting_times);
512 EXPECT_EQ(num_frames, waiting_times.size()); 512 EXPECT_EQ(num_frames, waiting_times.size());
513 // Since all frames are dumped into NetEQ at once, but pulled out with 10 ms 513 // Since all frames are dumped into NetEQ at once, but pulled out with 10 ms
(...skipping 17 matching lines...) Expand all
531 rtp_info.header.sequenceNumber = i; 531 rtp_info.header.sequenceNumber = i;
532 rtp_info.header.timestamp = i * kSamples; 532 rtp_info.header.timestamp = i * kSamples;
533 rtp_info.header.ssrc = 0x1235; // Just an arbitrary SSRC. 533 rtp_info.header.ssrc = 0x1235; // Just an arbitrary SSRC.
534 rtp_info.header.payloadType = 94; // PCM16b WB codec. 534 rtp_info.header.payloadType = 94; // PCM16b WB codec.
535 rtp_info.header.markerBit = 0; 535 rtp_info.header.markerBit = 0;
536 ASSERT_EQ(0, neteq_->InsertPacket( 536 ASSERT_EQ(0, neteq_->InsertPacket(
537 rtp_info, 537 rtp_info,
538 reinterpret_cast<uint8_t*>(payload), 538 reinterpret_cast<uint8_t*>(payload),
539 kPayloadBytes, 0)); 539 kPayloadBytes, 0));
540 size_t out_len; 540 size_t out_len;
541 int num_channels; 541 size_t num_channels;
542 NetEqOutputType type; 542 NetEqOutputType type;
543 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len, 543 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len,
544 &num_channels, &type)); 544 &num_channels, &type));
545 ASSERT_EQ(kBlockSize16kHz, out_len); 545 ASSERT_EQ(kBlockSize16kHz, out_len);
546 } 546 }
547 547
548 neteq_->WaitingTimes(&waiting_times); 548 neteq_->WaitingTimes(&waiting_times);
549 EXPECT_EQ(100u, waiting_times.size()); 549 EXPECT_EQ(100u, waiting_times.size());
550 } 550 }
551 551
552 TEST_F(NetEqDecodingTest, TestAverageInterArrivalTimeNegative) { 552 TEST_F(NetEqDecodingTest, TestAverageInterArrivalTimeNegative) {
553 const int kNumFrames = 3000; // Needed for convergence. 553 const int kNumFrames = 3000; // Needed for convergence.
554 int frame_index = 0; 554 int frame_index = 0;
555 const size_t kSamples = 10 * 16; 555 const size_t kSamples = 10 * 16;
556 const size_t kPayloadBytes = kSamples * 2; 556 const size_t kPayloadBytes = kSamples * 2;
557 while (frame_index < kNumFrames) { 557 while (frame_index < kNumFrames) {
558 // Insert one packet each time, except every 10th time where we insert two 558 // Insert one packet each time, except every 10th time where we insert two
559 // packets at once. This will create a negative clock-drift of approx. 10%. 559 // packets at once. This will create a negative clock-drift of approx. 10%.
560 int num_packets = (frame_index % 10 == 0 ? 2 : 1); 560 int num_packets = (frame_index % 10 == 0 ? 2 : 1);
561 for (int n = 0; n < num_packets; ++n) { 561 for (int n = 0; n < num_packets; ++n) {
562 uint8_t payload[kPayloadBytes] = {0}; 562 uint8_t payload[kPayloadBytes] = {0};
563 WebRtcRTPHeader rtp_info; 563 WebRtcRTPHeader rtp_info;
564 PopulateRtpInfo(frame_index, frame_index * kSamples, &rtp_info); 564 PopulateRtpInfo(frame_index, frame_index * kSamples, &rtp_info);
565 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0)); 565 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0));
566 ++frame_index; 566 ++frame_index;
567 } 567 }
568 568
569 // Pull out data once. 569 // Pull out data once.
570 size_t out_len; 570 size_t out_len;
571 int num_channels; 571 size_t num_channels;
572 NetEqOutputType type; 572 NetEqOutputType type;
573 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len, 573 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len,
574 &num_channels, &type)); 574 &num_channels, &type));
575 ASSERT_EQ(kBlockSize16kHz, out_len); 575 ASSERT_EQ(kBlockSize16kHz, out_len);
576 } 576 }
577 577
578 NetEqNetworkStatistics network_stats; 578 NetEqNetworkStatistics network_stats;
579 ASSERT_EQ(0, neteq_->NetworkStatistics(&network_stats)); 579 ASSERT_EQ(0, neteq_->NetworkStatistics(&network_stats));
580 EXPECT_EQ(-103196, network_stats.clockdrift_ppm); 580 EXPECT_EQ(-103196, network_stats.clockdrift_ppm);
581 } 581 }
(...skipping 10 matching lines...) Expand all
592 for (int n = 0; n < num_packets; ++n) { 592 for (int n = 0; n < num_packets; ++n) {
593 uint8_t payload[kPayloadBytes] = {0}; 593 uint8_t payload[kPayloadBytes] = {0};
594 WebRtcRTPHeader rtp_info; 594 WebRtcRTPHeader rtp_info;
595 PopulateRtpInfo(frame_index, frame_index * kSamples, &rtp_info); 595 PopulateRtpInfo(frame_index, frame_index * kSamples, &rtp_info);
596 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0)); 596 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0));
597 ++frame_index; 597 ++frame_index;
598 } 598 }
599 599
600 // Pull out data once. 600 // Pull out data once.
601 size_t out_len; 601 size_t out_len;
602 int num_channels; 602 size_t num_channels;
603 NetEqOutputType type; 603 NetEqOutputType type;
604 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len, 604 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len,
605 &num_channels, &type)); 605 &num_channels, &type));
606 ASSERT_EQ(kBlockSize16kHz, out_len); 606 ASSERT_EQ(kBlockSize16kHz, out_len);
607 } 607 }
608 608
609 NetEqNetworkStatistics network_stats; 609 NetEqNetworkStatistics network_stats;
610 ASSERT_EQ(0, neteq_->NetworkStatistics(&network_stats)); 610 ASSERT_EQ(0, neteq_->NetworkStatistics(&network_stats));
611 EXPECT_EQ(110946, network_stats.clockdrift_ppm); 611 EXPECT_EQ(110946, network_stats.clockdrift_ppm);
612 } 612 }
613 613
614 void NetEqDecodingTest::LongCngWithClockDrift(double drift_factor, 614 void NetEqDecodingTest::LongCngWithClockDrift(double drift_factor,
615 double network_freeze_ms, 615 double network_freeze_ms,
616 bool pull_audio_during_freeze, 616 bool pull_audio_during_freeze,
617 int delay_tolerance_ms, 617 int delay_tolerance_ms,
618 int max_time_to_speech_ms) { 618 int max_time_to_speech_ms) {
619 uint16_t seq_no = 0; 619 uint16_t seq_no = 0;
620 uint32_t timestamp = 0; 620 uint32_t timestamp = 0;
621 const int kFrameSizeMs = 30; 621 const int kFrameSizeMs = 30;
622 const size_t kSamples = kFrameSizeMs * 16; 622 const size_t kSamples = kFrameSizeMs * 16;
623 const size_t kPayloadBytes = kSamples * 2; 623 const size_t kPayloadBytes = kSamples * 2;
624 double next_input_time_ms = 0.0; 624 double next_input_time_ms = 0.0;
625 double t_ms; 625 double t_ms;
626 size_t out_len; 626 size_t out_len;
627 int num_channels; 627 size_t num_channels;
628 NetEqOutputType type; 628 NetEqOutputType type;
629 629
630 // Insert speech for 5 seconds. 630 // Insert speech for 5 seconds.
631 const int kSpeechDurationMs = 5000; 631 const int kSpeechDurationMs = 5000;
632 for (t_ms = 0; t_ms < kSpeechDurationMs; t_ms += 10) { 632 for (t_ms = 0; t_ms < kSpeechDurationMs; t_ms += 10) {
633 // Each turn in this for loop is 10 ms. 633 // Each turn in this for loop is 10 ms.
634 while (next_input_time_ms <= t_ms) { 634 while (next_input_time_ms <= t_ms) {
635 // Insert one 30 ms speech frame. 635 // Insert one 30 ms speech frame.
636 uint8_t payload[kPayloadBytes] = {0}; 636 uint8_t payload[kPayloadBytes] = {0};
637 WebRtcRTPHeader rtp_info; 637 WebRtcRTPHeader rtp_info;
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after
847 WebRtcRTPHeader rtp_info; 847 WebRtcRTPHeader rtp_info;
848 PopulateRtpInfo(0, 0, &rtp_info); 848 PopulateRtpInfo(0, 0, &rtp_info);
849 rtp_info.header.payloadType = 103; // iSAC, but the payload is invalid. 849 rtp_info.header.payloadType = 103; // iSAC, but the payload is invalid.
850 EXPECT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0)); 850 EXPECT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0));
851 NetEqOutputType type; 851 NetEqOutputType type;
852 // Set all of |out_data_| to 1, and verify that it was set to 0 by the call 852 // Set all of |out_data_| to 1, and verify that it was set to 0 by the call
853 // to GetAudio. 853 // to GetAudio.
854 for (size_t i = 0; i < kMaxBlockSize; ++i) { 854 for (size_t i = 0; i < kMaxBlockSize; ++i) {
855 out_data_[i] = 1; 855 out_data_[i] = 1;
856 } 856 }
857 int num_channels; 857 size_t num_channels;
858 size_t samples_per_channel; 858 size_t samples_per_channel;
859 EXPECT_EQ(NetEq::kFail, 859 EXPECT_EQ(NetEq::kFail,
860 neteq_->GetAudio(kMaxBlockSize, out_data_, 860 neteq_->GetAudio(kMaxBlockSize, out_data_,
861 &samples_per_channel, &num_channels, &type)); 861 &samples_per_channel, &num_channels, &type));
862 // Verify that there is a decoder error to check. 862 // Verify that there is a decoder error to check.
863 EXPECT_EQ(NetEq::kDecoderErrorCode, neteq_->LastError()); 863 EXPECT_EQ(NetEq::kDecoderErrorCode, neteq_->LastError());
864 // Code 6730 is an iSAC error code. 864 // Code 6730 is an iSAC error code.
865 EXPECT_EQ(6730, neteq_->LastDecoderError()); 865 EXPECT_EQ(6730, neteq_->LastDecoderError());
866 // Verify that the first 160 samples are set to 0, and that the remaining 866 // Verify that the first 160 samples are set to 0, and that the remaining
867 // samples are left unmodified. 867 // samples are left unmodified.
(...skipping 12 matching lines...) Expand all
880 } 880 }
881 } 881 }
882 882
883 TEST_F(NetEqDecodingTest, GetAudioBeforeInsertPacket) { 883 TEST_F(NetEqDecodingTest, GetAudioBeforeInsertPacket) {
884 NetEqOutputType type; 884 NetEqOutputType type;
885 // Set all of |out_data_| to 1, and verify that it was set to 0 by the call 885 // Set all of |out_data_| to 1, and verify that it was set to 0 by the call
886 // to GetAudio. 886 // to GetAudio.
887 for (size_t i = 0; i < kMaxBlockSize; ++i) { 887 for (size_t i = 0; i < kMaxBlockSize; ++i) {
888 out_data_[i] = 1; 888 out_data_[i] = 1;
889 } 889 }
890 int num_channels; 890 size_t num_channels;
891 size_t samples_per_channel; 891 size_t samples_per_channel;
892 EXPECT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, 892 EXPECT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_,
893 &samples_per_channel, 893 &samples_per_channel,
894 &num_channels, &type)); 894 &num_channels, &type));
895 // Verify that the first block of samples is set to 0. 895 // Verify that the first block of samples is set to 0.
896 static const int kExpectedOutputLength = 896 static const int kExpectedOutputLength =
897 kInitSampleRateHz / 100; // 10 ms at initial sample rate. 897 kInitSampleRateHz / 100; // 10 ms at initial sample rate.
898 for (int i = 0; i < kExpectedOutputLength; ++i) { 898 for (int i = 0; i < kExpectedOutputLength; ++i) {
899 std::ostringstream ss; 899 std::ostringstream ss;
900 ss << "i = " << i; 900 ss << "i = " << i;
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
934 webrtc::test::ResourcePath("audio_coding/testfile32kHz", "pcm"), 934 webrtc::test::ResourcePath("audio_coding/testfile32kHz", "pcm"),
935 10 * sampling_rate_hz, // Max 10 seconds loop length. 935 10 * sampling_rate_hz, // Max 10 seconds loop length.
936 expected_samples_per_channel)); 936 expected_samples_per_channel));
937 937
938 // Payload of 10 ms of PCM16 32 kHz. 938 // Payload of 10 ms of PCM16 32 kHz.
939 uint8_t payload[kBlockSize32kHz * sizeof(int16_t)]; 939 uint8_t payload[kBlockSize32kHz * sizeof(int16_t)];
940 WebRtcRTPHeader rtp_info; 940 WebRtcRTPHeader rtp_info;
941 PopulateRtpInfo(0, 0, &rtp_info); 941 PopulateRtpInfo(0, 0, &rtp_info);
942 rtp_info.header.payloadType = payload_type; 942 rtp_info.header.payloadType = payload_type;
943 943
944 int number_channels = 0; 944 size_t number_channels = 0;
945 size_t samples_per_channel = 0; 945 size_t samples_per_channel = 0;
946 946
947 uint32_t receive_timestamp = 0; 947 uint32_t receive_timestamp = 0;
948 for (int n = 0; n < 10; ++n) { // Insert few packets and get audio. 948 for (int n = 0; n < 10; ++n) { // Insert few packets and get audio.
949 size_t enc_len_bytes = WebRtcPcm16b_Encode( 949 size_t enc_len_bytes = WebRtcPcm16b_Encode(
950 input.GetNextBlock(), expected_samples_per_channel, payload); 950 input.GetNextBlock(), expected_samples_per_channel, payload);
951 ASSERT_EQ(enc_len_bytes, expected_samples_per_channel * 2); 951 ASSERT_EQ(enc_len_bytes, expected_samples_per_channel * 2);
952 952
953 number_channels = 0; 953 number_channels = 0;
954 samples_per_channel = 0; 954 samples_per_channel = 0;
955 ASSERT_EQ(0, 955 ASSERT_EQ(0,
956 neteq_->InsertPacket(rtp_info, payload, enc_len_bytes, 956 neteq_->InsertPacket(rtp_info, payload, enc_len_bytes,
957 receive_timestamp)); 957 receive_timestamp));
958 ASSERT_EQ(0, 958 ASSERT_EQ(0,
959 neteq_->GetAudio(kBlockSize32kHz, 959 neteq_->GetAudio(kBlockSize32kHz,
960 output, 960 output,
961 &samples_per_channel, 961 &samples_per_channel,
962 &number_channels, 962 &number_channels,
963 &type)); 963 &type));
964 ASSERT_EQ(1, number_channels); 964 ASSERT_EQ(1u, number_channels);
965 ASSERT_EQ(expected_samples_per_channel, samples_per_channel); 965 ASSERT_EQ(expected_samples_per_channel, samples_per_channel);
966 ASSERT_EQ(kOutputNormal, type); 966 ASSERT_EQ(kOutputNormal, type);
967 967
968 // Next packet. 968 // Next packet.
969 rtp_info.header.timestamp += expected_samples_per_channel; 969 rtp_info.header.timestamp += expected_samples_per_channel;
970 rtp_info.header.sequenceNumber++; 970 rtp_info.header.sequenceNumber++;
971 receive_timestamp += expected_samples_per_channel; 971 receive_timestamp += expected_samples_per_channel;
972 } 972 }
973 973
974 number_channels = 0; 974 number_channels = 0;
975 samples_per_channel = 0; 975 samples_per_channel = 0;
976 976
977 // Get audio without inserting packets, expecting PLC and PLC-to-CNG. Pull 977 // Get audio without inserting packets, expecting PLC and PLC-to-CNG. Pull
978 // one frame without checking speech-type. This is the first frame pulled 978 // one frame without checking speech-type. This is the first frame pulled
979 // without inserting any packet, and might not be labeled as PLC. 979 // without inserting any packet, and might not be labeled as PLC.
980 ASSERT_EQ(0, 980 ASSERT_EQ(0,
981 neteq_->GetAudio(kBlockSize32kHz, 981 neteq_->GetAudio(kBlockSize32kHz,
982 output, 982 output,
983 &samples_per_channel, 983 &samples_per_channel,
984 &number_channels, 984 &number_channels,
985 &type)); 985 &type));
986 ASSERT_EQ(1, number_channels); 986 ASSERT_EQ(1u, number_channels);
987 ASSERT_EQ(expected_samples_per_channel, samples_per_channel); 987 ASSERT_EQ(expected_samples_per_channel, samples_per_channel);
988 988
989 // To be able to test the fading of background noise we need at lease to 989 // To be able to test the fading of background noise we need at lease to
990 // pull 611 frames. 990 // pull 611 frames.
991 const int kFadingThreshold = 611; 991 const int kFadingThreshold = 611;
992 992
993 // Test several CNG-to-PLC packet for the expected behavior. The number 20 993 // Test several CNG-to-PLC packet for the expected behavior. The number 20
994 // is arbitrary, but sufficiently large to test enough number of frames. 994 // is arbitrary, but sufficiently large to test enough number of frames.
995 const int kNumPlcToCngTestFrames = 20; 995 const int kNumPlcToCngTestFrames = 20;
996 bool plc_to_cng = false; 996 bool plc_to_cng = false;
997 for (int n = 0; n < kFadingThreshold + kNumPlcToCngTestFrames; ++n) { 997 for (int n = 0; n < kFadingThreshold + kNumPlcToCngTestFrames; ++n) {
998 number_channels = 0; 998 number_channels = 0;
999 samples_per_channel = 0; 999 samples_per_channel = 0;
1000 memset(output, 1, sizeof(output)); // Set to non-zero. 1000 memset(output, 1, sizeof(output)); // Set to non-zero.
1001 ASSERT_EQ(0, 1001 ASSERT_EQ(0,
1002 neteq_->GetAudio(kBlockSize32kHz, 1002 neteq_->GetAudio(kBlockSize32kHz,
1003 output, 1003 output,
1004 &samples_per_channel, 1004 &samples_per_channel,
1005 &number_channels, 1005 &number_channels,
1006 &type)); 1006 &type));
1007 ASSERT_EQ(1, number_channels); 1007 ASSERT_EQ(1u, number_channels);
1008 ASSERT_EQ(expected_samples_per_channel, samples_per_channel); 1008 ASSERT_EQ(expected_samples_per_channel, samples_per_channel);
1009 if (type == kOutputPLCtoCNG) { 1009 if (type == kOutputPLCtoCNG) {
1010 plc_to_cng = true; 1010 plc_to_cng = true;
1011 double sum_squared = 0; 1011 double sum_squared = 0;
1012 for (size_t k = 0; k < number_channels * samples_per_channel; ++k) 1012 for (size_t k = 0; k < number_channels * samples_per_channel; ++k)
1013 sum_squared += output[k] * output[k]; 1013 sum_squared += output[k] * output[k];
1014 TestCondition(sum_squared, n > kFadingThreshold); 1014 TestCondition(sum_squared, n > kFadingThreshold);
1015 } else { 1015 } else {
1016 EXPECT_EQ(kOutputPLC, type); 1016 EXPECT_EQ(kOutputPLC, type);
1017 } 1017 }
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after
1160 const size_t kPayloadBytes = kBlockSize16kHz * sizeof(int16_t); 1160 const size_t kPayloadBytes = kBlockSize16kHz * sizeof(int16_t);
1161 uint8_t payload[kPayloadBytes]; 1161 uint8_t payload[kPayloadBytes];
1162 int16_t decoded[kBlockSize16kHz]; 1162 int16_t decoded[kBlockSize16kHz];
1163 int algorithmic_frame_delay = algorithmic_delay_ms_ / 10 + 1; 1163 int algorithmic_frame_delay = algorithmic_delay_ms_ / 10 + 1;
1164 for (size_t n = 0; n < kPayloadBytes; ++n) { 1164 for (size_t n = 0; n < kPayloadBytes; ++n) {
1165 payload[n] = (rand() & 0xF0) + 1; // Non-zero random sequence. 1165 payload[n] = (rand() & 0xF0) + 1; // Non-zero random sequence.
1166 } 1166 }
1167 // Insert some packets which decode to noise. We are not interested in 1167 // Insert some packets which decode to noise. We are not interested in
1168 // actual decoded values. 1168 // actual decoded values.
1169 NetEqOutputType output_type; 1169 NetEqOutputType output_type;
1170 int num_channels; 1170 size_t num_channels;
1171 size_t samples_per_channel; 1171 size_t samples_per_channel;
1172 uint32_t receive_timestamp = 0; 1172 uint32_t receive_timestamp = 0;
1173 for (int n = 0; n < 100; ++n) { 1173 for (int n = 0; n < 100; ++n) {
1174 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 1174 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes,
1175 receive_timestamp)); 1175 receive_timestamp));
1176 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded, 1176 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded,
1177 &samples_per_channel, &num_channels, 1177 &samples_per_channel, &num_channels,
1178 &output_type)); 1178 &output_type));
1179 ASSERT_EQ(kBlockSize16kHz, samples_per_channel); 1179 ASSERT_EQ(kBlockSize16kHz, samples_per_channel);
1180 ASSERT_EQ(1, num_channels); 1180 ASSERT_EQ(1u, num_channels);
1181 1181
1182 rtp_info.header.sequenceNumber++; 1182 rtp_info.header.sequenceNumber++;
1183 rtp_info.header.timestamp += kBlockSize16kHz; 1183 rtp_info.header.timestamp += kBlockSize16kHz;
1184 receive_timestamp += kBlockSize16kHz; 1184 receive_timestamp += kBlockSize16kHz;
1185 } 1185 }
1186 const int kNumSyncPackets = 10; 1186 const int kNumSyncPackets = 10;
1187 1187
1188 // Make sure sufficient number of sync packets are inserted that we can 1188 // Make sure sufficient number of sync packets are inserted that we can
1189 // conduct a test. 1189 // conduct a test.
1190 ASSERT_GT(kNumSyncPackets, algorithmic_frame_delay); 1190 ASSERT_GT(kNumSyncPackets, algorithmic_frame_delay);
1191 // Insert sync-packets, the decoded sequence should be all-zero. 1191 // Insert sync-packets, the decoded sequence should be all-zero.
1192 for (int n = 0; n < kNumSyncPackets; ++n) { 1192 for (int n = 0; n < kNumSyncPackets; ++n) {
1193 ASSERT_EQ(0, neteq_->InsertSyncPacket(rtp_info, receive_timestamp)); 1193 ASSERT_EQ(0, neteq_->InsertSyncPacket(rtp_info, receive_timestamp));
1194 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded, 1194 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded,
1195 &samples_per_channel, &num_channels, 1195 &samples_per_channel, &num_channels,
1196 &output_type)); 1196 &output_type));
1197 ASSERT_EQ(kBlockSize16kHz, samples_per_channel); 1197 ASSERT_EQ(kBlockSize16kHz, samples_per_channel);
1198 ASSERT_EQ(1, num_channels); 1198 ASSERT_EQ(1u, num_channels);
1199 if (n > algorithmic_frame_delay) { 1199 if (n > algorithmic_frame_delay) {
1200 EXPECT_TRUE(IsAllZero(decoded, samples_per_channel * num_channels)); 1200 EXPECT_TRUE(IsAllZero(decoded, samples_per_channel * num_channels));
1201 } 1201 }
1202 rtp_info.header.sequenceNumber++; 1202 rtp_info.header.sequenceNumber++;
1203 rtp_info.header.timestamp += kBlockSize16kHz; 1203 rtp_info.header.timestamp += kBlockSize16kHz;
1204 receive_timestamp += kBlockSize16kHz; 1204 receive_timestamp += kBlockSize16kHz;
1205 } 1205 }
1206 1206
1207 // We insert regular packets, if sync packet are not correctly buffered then 1207 // We insert regular packets, if sync packet are not correctly buffered then
1208 // network statistics would show some packet loss. 1208 // network statistics would show some packet loss.
(...skipping 29 matching lines...) Expand all
1238 PopulateRtpInfo(0, 0, &rtp_info); 1238 PopulateRtpInfo(0, 0, &rtp_info);
1239 const size_t kPayloadBytes = kBlockSize16kHz * sizeof(int16_t); 1239 const size_t kPayloadBytes = kBlockSize16kHz * sizeof(int16_t);
1240 uint8_t payload[kPayloadBytes]; 1240 uint8_t payload[kPayloadBytes];
1241 int16_t decoded[kBlockSize16kHz]; 1241 int16_t decoded[kBlockSize16kHz];
1242 for (size_t n = 0; n < kPayloadBytes; ++n) { 1242 for (size_t n = 0; n < kPayloadBytes; ++n) {
1243 payload[n] = (rand() & 0xF0) + 1; // Non-zero random sequence. 1243 payload[n] = (rand() & 0xF0) + 1; // Non-zero random sequence.
1244 } 1244 }
1245 // Insert some packets which decode to noise. We are not interested in 1245 // Insert some packets which decode to noise. We are not interested in
1246 // actual decoded values. 1246 // actual decoded values.
1247 NetEqOutputType output_type; 1247 NetEqOutputType output_type;
1248 int num_channels; 1248 size_t num_channels;
1249 size_t samples_per_channel; 1249 size_t samples_per_channel;
1250 uint32_t receive_timestamp = 0; 1250 uint32_t receive_timestamp = 0;
1251 int algorithmic_frame_delay = algorithmic_delay_ms_ / 10 + 1; 1251 int algorithmic_frame_delay = algorithmic_delay_ms_ / 10 + 1;
1252 for (int n = 0; n < algorithmic_frame_delay; ++n) { 1252 for (int n = 0; n < algorithmic_frame_delay; ++n) {
1253 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 1253 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes,
1254 receive_timestamp)); 1254 receive_timestamp));
1255 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded, 1255 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded,
1256 &samples_per_channel, &num_channels, 1256 &samples_per_channel, &num_channels,
1257 &output_type)); 1257 &output_type));
1258 ASSERT_EQ(kBlockSize16kHz, samples_per_channel); 1258 ASSERT_EQ(kBlockSize16kHz, samples_per_channel);
1259 ASSERT_EQ(1, num_channels); 1259 ASSERT_EQ(1u, num_channels);
1260 rtp_info.header.sequenceNumber++; 1260 rtp_info.header.sequenceNumber++;
1261 rtp_info.header.timestamp += kBlockSize16kHz; 1261 rtp_info.header.timestamp += kBlockSize16kHz;
1262 receive_timestamp += kBlockSize16kHz; 1262 receive_timestamp += kBlockSize16kHz;
1263 } 1263 }
1264 const int kNumSyncPackets = 10; 1264 const int kNumSyncPackets = 10;
1265 1265
1266 WebRtcRTPHeader first_sync_packet_rtp_info; 1266 WebRtcRTPHeader first_sync_packet_rtp_info;
1267 memcpy(&first_sync_packet_rtp_info, &rtp_info, sizeof(rtp_info)); 1267 memcpy(&first_sync_packet_rtp_info, &rtp_info, sizeof(rtp_info));
1268 1268
1269 // Insert sync-packets, but no decoding. 1269 // Insert sync-packets, but no decoding.
(...skipping 19 matching lines...) Expand all
1289 rtp_info.header.timestamp += kBlockSize16kHz; 1289 rtp_info.header.timestamp += kBlockSize16kHz;
1290 receive_timestamp += kBlockSize16kHz; 1290 receive_timestamp += kBlockSize16kHz;
1291 } 1291 }
1292 1292
1293 // Decode. 1293 // Decode.
1294 for (int n = 0; n < kNumSyncPackets; ++n) { 1294 for (int n = 0; n < kNumSyncPackets; ++n) {
1295 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded, 1295 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded,
1296 &samples_per_channel, &num_channels, 1296 &samples_per_channel, &num_channels,
1297 &output_type)); 1297 &output_type));
1298 ASSERT_EQ(kBlockSize16kHz, samples_per_channel); 1298 ASSERT_EQ(kBlockSize16kHz, samples_per_channel);
1299 ASSERT_EQ(1, num_channels); 1299 ASSERT_EQ(1u, num_channels);
1300 EXPECT_TRUE(IsAllNonZero(decoded, samples_per_channel * num_channels)); 1300 EXPECT_TRUE(IsAllNonZero(decoded, samples_per_channel * num_channels));
1301 } 1301 }
1302 } 1302 }
1303 1303
1304 void NetEqDecodingTest::WrapTest(uint16_t start_seq_no, 1304 void NetEqDecodingTest::WrapTest(uint16_t start_seq_no,
1305 uint32_t start_timestamp, 1305 uint32_t start_timestamp,
1306 const std::set<uint16_t>& drop_seq_numbers, 1306 const std::set<uint16_t>& drop_seq_numbers,
1307 bool expect_seq_no_wrap, 1307 bool expect_seq_no_wrap,
1308 bool expect_timestamp_wrap) { 1308 bool expect_timestamp_wrap) {
1309 uint16_t seq_no = start_seq_no; 1309 uint16_t seq_no = start_seq_no;
1310 uint32_t timestamp = start_timestamp; 1310 uint32_t timestamp = start_timestamp;
1311 const int kBlocksPerFrame = 3; // Number of 10 ms blocks per frame. 1311 const int kBlocksPerFrame = 3; // Number of 10 ms blocks per frame.
1312 const int kFrameSizeMs = kBlocksPerFrame * kTimeStepMs; 1312 const int kFrameSizeMs = kBlocksPerFrame * kTimeStepMs;
1313 const int kSamples = kBlockSize16kHz * kBlocksPerFrame; 1313 const int kSamples = kBlockSize16kHz * kBlocksPerFrame;
1314 const size_t kPayloadBytes = kSamples * sizeof(int16_t); 1314 const size_t kPayloadBytes = kSamples * sizeof(int16_t);
1315 double next_input_time_ms = 0.0; 1315 double next_input_time_ms = 0.0;
1316 int16_t decoded[kBlockSize16kHz]; 1316 int16_t decoded[kBlockSize16kHz];
1317 int num_channels; 1317 size_t num_channels;
1318 size_t samples_per_channel; 1318 size_t samples_per_channel;
1319 NetEqOutputType output_type; 1319 NetEqOutputType output_type;
1320 uint32_t receive_timestamp = 0; 1320 uint32_t receive_timestamp = 0;
1321 1321
1322 // Insert speech for 2 seconds. 1322 // Insert speech for 2 seconds.
1323 const int kSpeechDurationMs = 2000; 1323 const int kSpeechDurationMs = 2000;
1324 int packets_inserted = 0; 1324 int packets_inserted = 0;
1325 uint16_t last_seq_no; 1325 uint16_t last_seq_no;
1326 uint32_t last_timestamp; 1326 uint32_t last_timestamp;
1327 bool timestamp_wrapped = false; 1327 bool timestamp_wrapped = false;
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
1361 next_input_time_ms += static_cast<double>(kFrameSizeMs); 1361 next_input_time_ms += static_cast<double>(kFrameSizeMs);
1362 1362
1363 seq_no_wrapped |= seq_no < last_seq_no; 1363 seq_no_wrapped |= seq_no < last_seq_no;
1364 timestamp_wrapped |= timestamp < last_timestamp; 1364 timestamp_wrapped |= timestamp < last_timestamp;
1365 } 1365 }
1366 // Pull out data once. 1366 // Pull out data once.
1367 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded, 1367 ASSERT_EQ(0, neteq_->GetAudio(kBlockSize16kHz, decoded,
1368 &samples_per_channel, &num_channels, 1368 &samples_per_channel, &num_channels,
1369 &output_type)); 1369 &output_type));
1370 ASSERT_EQ(kBlockSize16kHz, samples_per_channel); 1370 ASSERT_EQ(kBlockSize16kHz, samples_per_channel);
1371 ASSERT_EQ(1, num_channels); 1371 ASSERT_EQ(1u, num_channels);
1372 1372
1373 // Expect delay (in samples) to be less than 2 packets. 1373 // Expect delay (in samples) to be less than 2 packets.
1374 EXPECT_LE(timestamp - PlayoutTimestamp(), 1374 EXPECT_LE(timestamp - PlayoutTimestamp(),
1375 static_cast<uint32_t>(kSamples * 2)); 1375 static_cast<uint32_t>(kSamples * 2));
1376 } 1376 }
1377 // Make sure we have actually tested wrap-around. 1377 // Make sure we have actually tested wrap-around.
1378 ASSERT_EQ(expect_seq_no_wrap, seq_no_wrapped); 1378 ASSERT_EQ(expect_seq_no_wrap, seq_no_wrapped);
1379 ASSERT_EQ(expect_timestamp_wrap, timestamp_wrapped); 1379 ASSERT_EQ(expect_timestamp_wrap, timestamp_wrapped);
1380 } 1380 }
1381 1381
(...skipping 30 matching lines...) Expand all
1412 const int kFrameSizeMs = 10; 1412 const int kFrameSizeMs = 10;
1413 const int kSampleRateKhz = 16; 1413 const int kSampleRateKhz = 16;
1414 const int kSamples = kFrameSizeMs * kSampleRateKhz; 1414 const int kSamples = kFrameSizeMs * kSampleRateKhz;
1415 const size_t kPayloadBytes = kSamples * 2; 1415 const size_t kPayloadBytes = kSamples * 2;
1416 1416
1417 const int algorithmic_delay_samples = std::max( 1417 const int algorithmic_delay_samples = std::max(
1418 algorithmic_delay_ms_ * kSampleRateKhz, 5 * kSampleRateKhz / 8); 1418 algorithmic_delay_ms_ * kSampleRateKhz, 5 * kSampleRateKhz / 8);
1419 // Insert three speech packets. Three are needed to get the frame length 1419 // Insert three speech packets. Three are needed to get the frame length
1420 // correct. 1420 // correct.
1421 size_t out_len; 1421 size_t out_len;
1422 int num_channels; 1422 size_t num_channels;
1423 NetEqOutputType type; 1423 NetEqOutputType type;
1424 uint8_t payload[kPayloadBytes] = {0}; 1424 uint8_t payload[kPayloadBytes] = {0};
1425 WebRtcRTPHeader rtp_info; 1425 WebRtcRTPHeader rtp_info;
1426 for (int i = 0; i < 3; ++i) { 1426 for (int i = 0; i < 3; ++i) {
1427 PopulateRtpInfo(seq_no, timestamp, &rtp_info); 1427 PopulateRtpInfo(seq_no, timestamp, &rtp_info);
1428 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0)); 1428 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0));
1429 ++seq_no; 1429 ++seq_no;
1430 timestamp += kSamples; 1430 timestamp += kSamples;
1431 1431
1432 // Pull audio once. 1432 // Pull audio once.
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after
1509 WebRtcRTPHeader rtp_info; 1509 WebRtcRTPHeader rtp_info;
1510 1510
1511 PopulateCng(seq_no, timestamp, &rtp_info, payload, &payload_len); 1511 PopulateCng(seq_no, timestamp, &rtp_info, payload, &payload_len);
1512 ASSERT_EQ(NetEq::kOK, 1512 ASSERT_EQ(NetEq::kOK,
1513 neteq_->InsertPacket(rtp_info, payload, payload_len, 0)); 1513 neteq_->InsertPacket(rtp_info, payload, payload_len, 0));
1514 ++seq_no; 1514 ++seq_no;
1515 timestamp += kCngPeriodSamples; 1515 timestamp += kCngPeriodSamples;
1516 1516
1517 // Pull audio once and make sure CNG is played. 1517 // Pull audio once and make sure CNG is played.
1518 size_t out_len; 1518 size_t out_len;
1519 int num_channels; 1519 size_t num_channels;
1520 NetEqOutputType type; 1520 NetEqOutputType type;
1521 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len, 1521 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len,
1522 &num_channels, &type)); 1522 &num_channels, &type));
1523 ASSERT_EQ(kBlockSize16kHz, out_len); 1523 ASSERT_EQ(kBlockSize16kHz, out_len);
1524 EXPECT_EQ(kOutputCNG, type); 1524 EXPECT_EQ(kOutputCNG, type);
1525 1525
1526 // Insert some speech packets. 1526 // Insert some speech packets.
1527 for (int i = 0; i < 3; ++i) { 1527 for (int i = 0; i < 3; ++i) {
1528 PopulateRtpInfo(seq_no, timestamp, &rtp_info); 1528 PopulateRtpInfo(seq_no, timestamp, &rtp_info);
1529 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0)); 1529 ASSERT_EQ(0, neteq_->InsertPacket(rtp_info, payload, kPayloadBytes, 0));
1530 ++seq_no; 1530 ++seq_no;
1531 timestamp += kSamples; 1531 timestamp += kSamples;
1532 1532
1533 // Pull audio once. 1533 // Pull audio once.
1534 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len, 1534 ASSERT_EQ(0, neteq_->GetAudio(kMaxBlockSize, out_data_, &out_len,
1535 &num_channels, &type)); 1535 &num_channels, &type));
1536 ASSERT_EQ(kBlockSize16kHz, out_len); 1536 ASSERT_EQ(kBlockSize16kHz, out_len);
1537 } 1537 }
1538 // Verify speech output. 1538 // Verify speech output.
1539 EXPECT_EQ(kOutputNormal, type); 1539 EXPECT_EQ(kOutputNormal, type);
1540 } 1540 }
1541 1541
1542 } // namespace webrtc 1542 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698