Я пытаюсь создать отдельную AGC с использованием библиотеки WebRtc. (Вход — файл WAV, выход — файл WAV с отрегулированным усилением). Но в настоящее время у меня есть некоторые проблемы с этим вопросом.
Я пытаюсь использовать функции, которые объявлены в gain_control.h
файл. Когда я использую WebRtcAgc_Process (….), я получаю постоянное усиление, которое применяется ко всему сигналу, но не нелинейное усиление, которое зависит от величины входного сигнала.
Может быть, я должен использовать другие функции для моих целей? Как я могу реализовать AGC через библиотеку WebRTC?
Основная цель AGC — предоставить рекомендуемый объем микрофона системы, который пользователь должен будет устанавливать через ОС. Если вы хотите применить чисто цифровое усиление, вы можете настроить его в одном из двух режимов (от modules/audio_processing/include/audio_processing.h
, но gain_control.h
имеет аналогичные режимы):
// Adaptive mode intended for situations in which an analog volume control
// is unavailable. It operates in a similar fashion to the adaptive analog
// mode, but with scaling instead applied in the digital domain. As with
// the analog mode, it additionally uses a digital compression stage.
kAdaptiveDigital,
// Fixed mode which enables only the digital compression stage also used by
// the two adaptive modes.
//
// It is distinguished from the adaptive modes by considering only a
// short time-window of the input signal. It applies a fixed gain through
// most of the input level range, and compresses (gradually reduces gain
// with increasing level) the input signal at higher levels. This mode is
// preferred on embedded devices where the capture signal level is
// predictable, so that a known gain can be applied.
kFixedDigital
Вы можете установить их через WebRtcAgc_Init()
хотя, если вам не нужно избегать накладных расходов, я бы порекомендовал просто использовать класс AudioProcessing.
Ссылаться на http://osxr.org/android/source/external/webrtc/src/modules/audio_processing/agc/interface/gain_control.h#0133
Регулировка усиления выполняется только в течение 0135 * активных периодов
речь. Длина входной речи может быть 10 мс или 0136 * 20 мс, а
выход имеет одинаковую длину.
краткий обзор webrtcage_process
int WebRtcAgc_Process(void* agcInst,
const WebRtc_Word16* inNear,
const WebRtc_Word16* inNear_H,
WebRtc_Word16 samples,
WebRtc_Word16* out,
WebRtc_Word16* out_H,
WebRtc_Word32 inMicLevel,
WebRtc_Word32* outMicLevel,
WebRtc_Word16 echo,
WebRtc_UWord8* saturationWarning);