OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2012 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 |
11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_VAD_PITCH_BASED_VAD_H_ | 11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_AGC_PITCH_BASED_VAD_H_ |
12 #define WEBRTC_MODULES_AUDIO_PROCESSING_VAD_PITCH_BASED_VAD_H_ | 12 #define WEBRTC_MODULES_AUDIO_PROCESSING_AGC_PITCH_BASED_VAD_H_ |
13 | 13 |
14 #include "webrtc/base/scoped_ptr.h" | 14 #include "webrtc/base/scoped_ptr.h" |
15 #include "webrtc/modules/audio_processing/vad/common.h" | 15 #include "webrtc/modules/audio_processing/agc/common.h" |
16 #include "webrtc/modules/audio_processing/vad/gmm.h" | 16 #include "webrtc/modules/audio_processing/agc/gmm.h" |
17 #include "webrtc/typedefs.h" | 17 #include "webrtc/typedefs.h" |
18 | 18 |
19 namespace webrtc { | 19 namespace webrtc { |
20 | 20 |
21 class AudioFrame; | 21 class AudioFrame; |
22 class VadCircularBuffer; | 22 class AgcCircularBuffer; |
23 | 23 |
24 // Computes the probability of the input audio frame to be active given | 24 // Computes the probability of the input audio frame to be active given |
25 // the corresponding pitch-gain and lag of the frame. | 25 // the corresponding pitch-gain and lag of the frame. |
26 class PitchBasedVad { | 26 class PitchBasedVad { |
27 public: | 27 public: |
28 PitchBasedVad(); | 28 PitchBasedVad(); |
29 ~PitchBasedVad(); | 29 ~PitchBasedVad(); |
30 | 30 |
31 // Compute pitch-based voicing probability, given the features. | 31 // Compute pitch-based voicing probability, given the features. |
32 // features: a structure containing features required for computing voicing | 32 // features: a structure containing features required for computing voicing |
33 // probabilities. | 33 // probabilities. |
34 // | 34 // |
35 // p_combined: an array which contains the combined activity probabilities | 35 // p_combined: an array which contains the combined activity probabilities |
36 // computed prior to the call of this function. The method, | 36 // computed prior to the call of this function. The method, |
37 // then, computes the voicing probabilities and combine them | 37 // then, computes the voicing probabilities and combine them |
38 // with the given values. The result are returned in |p|. | 38 // with the given values. The result are returned in |p|. |
39 int VoicingProbability(const AudioFeatures& features, double* p_combined); | 39 int VoicingProbability(const AudioFeatures& features, double* p_combined); |
40 | |
41 private: | 40 private: |
42 int UpdatePrior(double p); | 41 int UpdatePrior(double p); |
43 | 42 |
44 // TODO(turajs): maybe defining this at a higher level (maybe enum) so that | 43 // TODO(turajs): maybe defining this at a higher level (maybe enum) so that |
45 // all the code recognize it as "no-error." | 44 // all the code recognize it as "no-error." |
46 static const int kNoError = 0; | 45 static const int kNoError = 0; |
47 | 46 |
48 GmmParameters noise_gmm_; | 47 GmmParameters noise_gmm_; |
49 GmmParameters voice_gmm_; | 48 GmmParameters voice_gmm_; |
50 | 49 |
51 double p_prior_; | 50 double p_prior_; |
52 | 51 |
53 rtc::scoped_ptr<VadCircularBuffer> circular_buffer_; | 52 rtc::scoped_ptr<AgcCircularBuffer> circular_buffer_; |
54 }; | 53 }; |
55 | 54 |
56 } // namespace webrtc | 55 } // namespace webrtc |
57 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_VAD_PITCH_BASED_VAD_H_ | 56 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_AGC_PITCH_BASED_VAD_H_ |
OLD | NEW |