OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2017 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 15 matching lines...) Expand all Loading... | |
26 // - A is the first speaking, B is the second one, | 26 // - A is the first speaking, B is the second one, |
27 // - each character after the speaker's letter indicates a time unit (e.g., 100 | 27 // - each character after the speaker's letter indicates a time unit (e.g., 100 |
28 // ms), | 28 // ms), |
29 // - "*" indicates speaking, "." listening, | 29 // - "*" indicates speaking, "." listening, |
30 // - numbers indicate the turn index in std::vector<Turn>. | 30 // - numbers indicate the turn index in std::vector<Turn>. |
31 // | 31 // |
32 // Note that the same speaker can appear in multiple lines in order to depict | 32 // Note that the same speaker can appear in multiple lines in order to depict |
33 // cases in which there are wrong offsets leading to self cross-talk (which is | 33 // cases in which there are wrong offsets leading to self cross-talk (which is |
34 // rejected). | 34 // rejected). |
35 | 35 |
36 #define _USE_MATH_DEFINES | |
kwiberg-webrtc
2017/03/28 17:52:45
A comment on what effect this has, and on which he
AleBzk
2017/03/29 08:56:44
Done.
| |
37 | |
36 #include <stdio.h> | 38 #include <stdio.h> |
39 #include <cmath> | |
37 #include <map> | 40 #include <map> |
38 #include <memory> | 41 #include <memory> |
39 | 42 |
40 #include "webrtc/base/logging.h" | 43 #include "webrtc/base/logging.h" |
44 #include "webrtc/base/pathutils.h" | |
41 #include "webrtc/modules/audio_processing/test/conversational_speech/config.h" | 45 #include "webrtc/modules/audio_processing/test/conversational_speech/config.h" |
42 #include "webrtc/modules/audio_processing/test/conversational_speech/mock_wavrea der_factory.h" | 46 #include "webrtc/modules/audio_processing/test/conversational_speech/mock_wavrea der_factory.h" |
43 #include "webrtc/modules/audio_processing/test/conversational_speech/multiend_ca ll.h" | 47 #include "webrtc/modules/audio_processing/test/conversational_speech/multiend_ca ll.h" |
44 #include "webrtc/modules/audio_processing/test/conversational_speech/timing.h" | 48 #include "webrtc/modules/audio_processing/test/conversational_speech/timing.h" |
49 #include "webrtc/modules/audio_processing/test/conversational_speech/wavreader_a daptor.h" | |
45 #include "webrtc/test/gmock.h" | 50 #include "webrtc/test/gmock.h" |
46 #include "webrtc/test/gtest.h" | 51 #include "webrtc/test/gtest.h" |
47 #include "webrtc/test/testsupport/fileutils.h" | 52 #include "webrtc/test/testsupport/fileutils.h" |
48 | 53 |
49 namespace webrtc { | 54 namespace webrtc { |
50 namespace test { | 55 namespace test { |
51 namespace { | 56 namespace { |
52 | 57 |
53 using conversational_speech::LoadTiming; | 58 using conversational_speech::LoadTiming; |
54 using conversational_speech::SaveTiming; | 59 using conversational_speech::SaveTiming; |
55 using conversational_speech::MockWavReaderFactory; | 60 using conversational_speech::MockWavReaderFactory; |
56 using conversational_speech::MultiEndCall; | 61 using conversational_speech::MultiEndCall; |
57 using conversational_speech::Turn; | 62 using conversational_speech::Turn; |
58 using conversational_speech::WavReaderAbstractFactory; | 63 using conversational_speech::WavReaderAbstractFactory; |
64 using conversational_speech::WavReaderAdaptor; | |
59 | 65 |
60 const char* const audiotracks_path = "/path/to/audiotracks"; | 66 const char* const audiotracks_path = "/path/to/audiotracks"; |
61 const char* const timing_filepath = "/path/to/timing_file.txt"; | 67 const char* const timing_filepath = "/path/to/timing_file.txt"; |
62 const char* const output_path = "/path/to/output_dir"; | 68 const char* const output_path = "/path/to/output_dir"; |
63 | 69 |
64 const std::vector<Turn> expected_timing = { | 70 const std::vector<Turn> expected_timing = { |
65 {"A", "a1", 0}, | 71 {"A", "a1", 0}, |
66 {"B", "b1", 0}, | 72 {"B", "b1", 0}, |
67 {"A", "a2", 100}, | 73 {"A", "a2", 100}, |
68 {"B", "b2", -200}, | 74 {"B", "b2", -200}, |
(...skipping 19 matching lines...) Expand all Loading... | |
88 {"t500", kMockWavReaderFactoryParams500ms}, | 94 {"t500", kMockWavReaderFactoryParams500ms}, |
89 {"t1000", kMockWavReaderFactoryParams1000ms}, | 95 {"t1000", kMockWavReaderFactoryParams1000ms}, |
90 }; | 96 }; |
91 | 97 |
92 std::unique_ptr<MockWavReaderFactory> CreateMockWavReaderFactory() { | 98 std::unique_ptr<MockWavReaderFactory> CreateMockWavReaderFactory() { |
93 return std::unique_ptr<MockWavReaderFactory>( | 99 return std::unique_ptr<MockWavReaderFactory>( |
94 new MockWavReaderFactory(kDefaultMockWavReaderFactoryParams, | 100 new MockWavReaderFactory(kDefaultMockWavReaderFactoryParams, |
95 kDefaultMockWavReaderFactoryParamsMap)); | 101 kDefaultMockWavReaderFactoryParamsMap)); |
96 } | 102 } |
97 | 103 |
104 void CreateSineWavFile(const std::string& filepath, | |
105 const MockWavReaderFactory::Params& params, | |
106 float frequency = 440.0f) { | |
107 // Create samples. | |
108 const double two_pi = 2.0 * M_PI; | |
kwiberg-webrtc
2017/03/28 17:52:45
constexpr
AleBzk
2017/03/29 08:56:44
Done.
| |
109 std::unique_ptr<int16_t[]> samples(new int16_t[params.num_samples]); | |
kwiberg-webrtc
2017/03/28 17:52:45
It's easier to avoid bugs if you use e.g. a std::v
AleBzk
2017/03/29 08:56:44
Done.
| |
110 for (std::size_t i = 0; i < params.num_samples; ++i) { | |
111 // TODO(alessiob): the produced tone is not pure, improve. | |
112 samples[i] = std::lround(32767.0f * std::sin( | |
113 two_pi * i * frequency / params.sample_rate)); | |
114 } | |
115 | |
116 // Write samples. | |
117 WavWriter wav_writer(filepath, params.sample_rate, params.num_channels); | |
118 wav_writer.WriteSamples(samples.get(), params.num_samples); | |
119 } | |
120 | |
98 } // namespace | 121 } // namespace |
99 | 122 |
100 class ConversationalSpeechTest : public testing::Test { | 123 class ConversationalSpeechTest : public testing::Test { |
101 public: | 124 public: |
102 ConversationalSpeechTest() { | 125 ConversationalSpeechTest() { |
103 rtc::LogMessage::LogToDebug(rtc::LS_VERBOSE); | 126 rtc::LogMessage::LogToDebug(rtc::LS_VERBOSE); |
104 } | 127 } |
105 }; | 128 }; |
106 | 129 |
107 TEST_F(ConversationalSpeechTest, Settings) { | 130 TEST_F(ConversationalSpeechTest, Settings) { |
(...skipping 320 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
428 kDefaultMockWavReaderFactoryParamsMap)); | 451 kDefaultMockWavReaderFactoryParamsMap)); |
429 | 452 |
430 // There are two unique audio tracks to read. | 453 // There are two unique audio tracks to read. |
431 EXPECT_CALL(*mock_wavreader_factory, Create(testing::_)).Times(2); | 454 EXPECT_CALL(*mock_wavreader_factory, Create(testing::_)).Times(2); |
432 | 455 |
433 conversational_speech::MultiEndCall multiend_call( | 456 conversational_speech::MultiEndCall multiend_call( |
434 timing, audiotracks_path, std::move(mock_wavreader_factory)); | 457 timing, audiotracks_path, std::move(mock_wavreader_factory)); |
435 EXPECT_FALSE(multiend_call.valid()); | 458 EXPECT_FALSE(multiend_call.valid()); |
436 } | 459 } |
437 | 460 |
461 TEST_F(ConversationalSpeechTest, MultiEndCallWavReaderAdaptorSine) { | |
462 // Parameters with which wav files are created. | |
463 constexpr int duration_seconds = 5; | |
464 const int sample_rates[] = {8000, 11025, 16000, 22050, 32000, 44100, 48000}; | |
465 | |
466 for (int sample_rate : sample_rates) { | |
467 const rtc::Pathname temp_filename( | |
468 OutputPath(), "TempSineWavFile_" + std::to_string(sample_rate) | |
469 + ".wav"); | |
470 | |
471 // Write wav file. | |
472 std::size_t num_samples = duration_seconds * sample_rate; | |
kwiberg-webrtc
2017/03/28 17:52:44
const?
AleBzk
2017/03/29 08:56:44
Done.
| |
473 MockWavReaderFactory::Params params = {sample_rate, 1u, num_samples}; | |
474 CreateSineWavFile(temp_filename.pathname(), params); | |
475 LOG(LS_VERBOSE) << "wav file @" << sample_rate << " Hz created (" | |
476 << num_samples << " samples)"; | |
477 | |
478 // Load wav file and check if params match. | |
479 WavReaderAdaptor wav_reader_adaptor(temp_filename.pathname()); | |
480 EXPECT_EQ(sample_rate, wav_reader_adaptor.sample_rate()); | |
481 EXPECT_EQ(1u, wav_reader_adaptor.num_channels()); | |
482 EXPECT_EQ(num_samples, wav_reader_adaptor.num_samples()); | |
483 | |
484 // Clean up. | |
485 remove(temp_filename.pathname().c_str()); | |
486 } | |
487 } | |
488 | |
438 } // namespace test | 489 } // namespace test |
439 } // namespace webrtc | 490 } // namespace webrtc |
OLD | NEW |