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

Side by Side Diff: webrtc/modules/audio_processing/vad/pitch_based_vad.h

Issue 1212543002: Pull the Voice Activity Detector out from the AGC (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 5 years, 6 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) 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_AGC_PITCH_BASED_VAD_H_ 11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_VAD_PITCH_BASED_VAD_H_
12 #define WEBRTC_MODULES_AUDIO_PROCESSING_AGC_PITCH_BASED_VAD_H_ 12 #define WEBRTC_MODULES_AUDIO_PROCESSING_VAD_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/agc/common.h" 15 #include "webrtc/modules/audio_processing/vad/common.h"
16 #include "webrtc/modules/audio_processing/agc/gmm.h" 16 #include "webrtc/modules/audio_processing/vad/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 AgcCircularBuffer; 22 class VadCircularBuffer;
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
40 private: 41 private:
41 int UpdatePrior(double p); 42 int UpdatePrior(double p);
42 43
43 // TODO(turajs): maybe defining this at a higher level (maybe enum) so that 44 // TODO(turajs): maybe defining this at a higher level (maybe enum) so that
44 // all the code recognize it as "no-error." 45 // all the code recognize it as "no-error."
45 static const int kNoError = 0; 46 static const int kNoError = 0;
46 47
47 GmmParameters noise_gmm_; 48 GmmParameters noise_gmm_;
48 GmmParameters voice_gmm_; 49 GmmParameters voice_gmm_;
49 50
50 double p_prior_; 51 double p_prior_;
51 52
52 rtc::scoped_ptr<AgcCircularBuffer> circular_buffer_; 53 rtc::scoped_ptr<VadCircularBuffer> circular_buffer_;
53 }; 54 };
54 55
55 } // namespace webrtc 56 } // namespace webrtc
56 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_AGC_PITCH_BASED_VAD_H_ 57 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_VAD_PITCH_BASED_VAD_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698