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

Side by Side Diff: webrtc/modules/audio_processing/agc/pole_zero_filter.cc

Issue 1181933002: Pull the Voice Activity Detector out from the AGC (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Remove unused files from isolate 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
(Empty)
1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 *
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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11 #include "webrtc/modules/audio_processing/agc/pole_zero_filter.h"
12
13 #include <stdlib.h>
14 #include <string.h>
15 #include <algorithm>
16
17 namespace webrtc {
18
19 PoleZeroFilter* PoleZeroFilter::Create(const float* numerator_coefficients,
20 int order_numerator,
21 const float* denominator_coefficients,
22 int order_denominator) {
23 if (order_numerator < 0 ||
24 order_denominator < 0 ||
25 order_numerator > kMaxFilterOrder ||
26 order_denominator > kMaxFilterOrder ||
27 denominator_coefficients[0] == 0 ||
28 numerator_coefficients == NULL ||
29 denominator_coefficients == NULL)
30 return NULL;
31 return new PoleZeroFilter(numerator_coefficients, order_numerator,
32 denominator_coefficients, order_denominator);
33 }
34
35 PoleZeroFilter::PoleZeroFilter(const float* numerator_coefficients,
36 int order_numerator,
37 const float* denominator_coefficients,
38 int order_denominator)
39 : past_input_(),
40 past_output_(),
41 numerator_coefficients_(),
42 denominator_coefficients_(),
43 order_numerator_(order_numerator),
44 order_denominator_(order_denominator),
45 highest_order_(std::max(order_denominator, order_numerator)) {
46 memcpy(numerator_coefficients_, numerator_coefficients,
47 sizeof(numerator_coefficients_[0]) * (order_numerator_ + 1));
48 memcpy(denominator_coefficients_, denominator_coefficients,
49 sizeof(denominator_coefficients_[0]) * (order_denominator_ + 1));
50
51 if (denominator_coefficients_[0] != 1) {
52 for (int n = 0; n <= order_numerator_; n++)
53 numerator_coefficients_[n] /= denominator_coefficients_[0];
54 for (int n = 0; n <= order_denominator_; n++)
55 denominator_coefficients_[n] /= denominator_coefficients_[0];
56 }
57 }
58
59 template <typename T>
60 static float FilterArPast(const T* past, int order,
61 const float* coefficients) {
62 float sum = 0.0f;
63 int past_index = order - 1;
64 for (int k = 1; k <= order; k++, past_index--)
65 sum += coefficients[k] * past[past_index];
66 return sum;
67 }
68
69 int PoleZeroFilter::Filter(const int16_t* in,
70 int num_input_samples,
71 float* output) {
72 if (in == NULL || num_input_samples < 0 || output == NULL)
73 return -1;
74 // This is the typical case, just a memcpy.
75 const int k = std::min(num_input_samples, highest_order_);
76 int n;
77 for (n = 0; n < k; n++) {
78 output[n] = in[n] * numerator_coefficients_[0];
79 output[n] += FilterArPast(&past_input_[n], order_numerator_,
80 numerator_coefficients_);
81 output[n] -= FilterArPast(&past_output_[n], order_denominator_,
82 denominator_coefficients_);
83
84 past_input_[n + order_numerator_] = in[n];
85 past_output_[n + order_denominator_] = output[n];
86 }
87 if (highest_order_ < num_input_samples) {
88 for (int m = 0; n < num_input_samples; n++, m++) {
89 output[n] = in[n] * numerator_coefficients_[0];
90 output[n] += FilterArPast(&in[m], order_numerator_,
91 numerator_coefficients_);
92 output[n] -= FilterArPast(&output[m], order_denominator_,
93 denominator_coefficients_);
94 }
95 // Record into the past signal.
96 memcpy(past_input_, &in[num_input_samples - order_numerator_],
97 sizeof(in[0]) * order_numerator_);
98 memcpy(past_output_, &output[num_input_samples - order_denominator_],
99 sizeof(output[0]) * order_denominator_);
100 } else {
101 // Odd case that the length of the input is shorter that filter order.
102 memmove(past_input_, &past_input_[num_input_samples], order_numerator_ *
103 sizeof(past_input_[0]));
104 memmove(past_output_, &past_output_[num_input_samples], order_denominator_ *
105 sizeof(past_output_[0]));
106 }
107 return 0;
108 }
109
110 } // namespace webrtc
111
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698