mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-15 23:01:21 +01:00

This CL does the following: 1. Adds a new AdaptiveModeLevelEstimatorAgc implementation of the Agc interface. The new implementation differs from webrtc::Agc by 1. using the AGC2 speech level estimator in GetRmsErrorDb. webrtc::Agc implements its own with help of webrtc::LoudnessHistogram. 2. Doesn't forget its past at every GetRmsErrorDb call. 2. Makes AgcManagerDirect use AdaptiveModeLevelEstimatorAgc instead of webrtc::Agc if the use_agc2_level_estimation flag is set. Bug: webrtc:7494 Change-Id: I8df3f52e322d433eb5ce5297f4236af2f1877b04 Reviewed-on: https://webrtc-review.googlesource.com/86603 Commit-Queue: Alex Loiko <aleloi@webrtc.org> Reviewed-by: Sam Zackrisson <saza@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23875}
87 lines
3.4 KiB
C++
87 lines
3.4 KiB
C++
/*
|
|
* Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#ifndef MODULES_AUDIO_PROCESSING_AGC2_AGC2_COMMON_H_
|
|
#define MODULES_AUDIO_PROCESSING_AGC2_AGC2_COMMON_H_
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <cmath>
|
|
|
|
namespace webrtc {
|
|
|
|
constexpr float kMinFloatS16Value = -32768.f;
|
|
constexpr float kMaxFloatS16Value = 32767.f;
|
|
constexpr float kMaxAbsFloatS16Value = 32768.0f;
|
|
|
|
constexpr size_t kFrameDurationMs = 10;
|
|
constexpr size_t kSubFramesInFrame = 20;
|
|
constexpr size_t kMaximalNumberOfSamplesPerChannel = 480;
|
|
|
|
constexpr float kAttackFilterConstant = 0.f;
|
|
|
|
// Adaptive digital gain applier settings below.
|
|
constexpr float kMaxGainChangePerSecondDb = 3.f;
|
|
constexpr float kMaxGainChangePerFrameDb =
|
|
kMaxGainChangePerSecondDb * kFrameDurationMs / 1000.f;
|
|
constexpr float kHeadroomDbfs = 1.f;
|
|
constexpr float kMaxGainDb = 30.f;
|
|
constexpr float kInitialAdaptiveDigitalGainDb = 8.f;
|
|
|
|
// This parameter must be tuned together with the noise estimator.
|
|
constexpr float kMaxNoiseLevelDbfs = -50.f;
|
|
|
|
// This is the threshold for speech. Speech frames are used for updating the
|
|
// speech level, measuring the amount of speech, and decide when to allow target
|
|
// gain reduction.
|
|
constexpr float kVadConfidenceThreshold = 0.4f;
|
|
|
|
// The amount of 'memory' of the Level Estimator. Decides leak factors.
|
|
constexpr size_t kFullBufferSizeMs = 1600;
|
|
constexpr float kFullBufferLeakFactor = 1.f - 1.f / kFullBufferSizeMs;
|
|
|
|
constexpr float kInitialSpeechLevelEstimateDbfs = -30.f;
|
|
|
|
// Saturation Protector settings.
|
|
constexpr float kInitialSaturationMarginDb = 17.f;
|
|
|
|
constexpr size_t kPeakEnveloperSuperFrameLengthMs = 400;
|
|
static_assert(kFullBufferSizeMs % kPeakEnveloperSuperFrameLengthMs == 0,
|
|
"Full buffer size should be a multiple of super frame length for "
|
|
"optimal Saturation Protector performance.");
|
|
|
|
constexpr size_t kPeakEnveloperBufferSize =
|
|
kFullBufferSizeMs / kPeakEnveloperSuperFrameLengthMs + 1;
|
|
|
|
// This value is 10 ** (-1/20 * frame_size_ms / satproc_attack_ms),
|
|
// where satproc_attack_ms is 5000.
|
|
constexpr float kSaturationProtectorAttackConstant = 0.9988493699365052f;
|
|
|
|
// This value is 10 ** (-1/20 * frame_size_ms / satproc_decay_ms),
|
|
// where satproc_decay_ms is 1000.
|
|
constexpr float kSaturationProtectorDecayConstant = 0.9997697679981565f;
|
|
|
|
// This is computed from kDecayMs by
|
|
// 10 ** (-1/20 * subframe_duration / kDecayMs).
|
|
// |subframe_duration| is |kFrameDurationMs / kSubFramesInFrame|.
|
|
// kDecayMs is defined in agc2_testing_common.h
|
|
constexpr float kDecayFilterConstant = 0.9998848773724686f;
|
|
|
|
// Number of interpolation points for each region of the limiter.
|
|
// These values have been tuned to limit the interpolated gain curve error given
|
|
// the limiter parameters and allowing a maximum error of +/- 32768^-1.
|
|
constexpr size_t kInterpolatedGainCurveKneePoints = 22;
|
|
constexpr size_t kInterpolatedGainCurveBeyondKneePoints = 10;
|
|
constexpr size_t kInterpolatedGainCurveTotalPoints =
|
|
kInterpolatedGainCurveKneePoints + kInterpolatedGainCurveBeyondKneePoints;
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // MODULES_AUDIO_PROCESSING_AGC2_AGC2_COMMON_H_
|