/* * Copyright (c) 2012 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 WEBRTC_MODULES_AUDIO_PROCESSING_NS_NOISE_SUPPRESSION_H_ #define WEBRTC_MODULES_AUDIO_PROCESSING_NS_NOISE_SUPPRESSION_H_ #include #include "webrtc/typedefs.h" typedef struct NsHandleT NsHandle; #ifdef __cplusplus extern "C" { #endif /* * This function creates an instance of the floating point Noise Suppression. */ NsHandle* WebRtcNs_Create(); /* * This function frees the dynamic memory of a specified noise suppression * instance. * * Input: * - NS_inst : Pointer to NS instance that should be freed */ void WebRtcNs_Free(NsHandle* NS_inst); /* * This function initializes a NS instance and has to be called before any other * processing is made. * * Input: * - NS_inst : Instance that should be initialized * - fs : sampling frequency * * Output: * - NS_inst : Initialized instance * * Return value : 0 - Ok * -1 - Error */ int WebRtcNs_Init(NsHandle* NS_inst, uint32_t fs); /* * This changes the aggressiveness of the noise suppression method. * * Input: * - NS_inst : Noise suppression instance. * - mode : 0: Mild, 1: Medium , 2: Aggressive * * Output: * - NS_inst : Updated instance. * * Return value : 0 - Ok * -1 - Error */ int WebRtcNs_set_policy(NsHandle* NS_inst, int mode); /* * This functions estimates the background noise for the inserted speech frame. * The input and output signals should always be 10ms (80 or 160 samples). * * Input * - NS_inst : Noise suppression instance. * - spframe : Pointer to speech frame buffer for L band * * Output: * - NS_inst : Updated NS instance */ void WebRtcNs_Analyze(NsHandle* NS_inst, const float* spframe); /* * This functions does Noise Suppression for the inserted speech frame. The * input and output signals should always be 10ms (80 or 160 samples). * * Input * - NS_inst : Noise suppression instance. * - spframe : Pointer to speech frame buffer for each band * - num_bands : Number of bands * * Output: * - NS_inst : Updated NS instance * - outframe : Pointer to output frame for each band */ void WebRtcNs_Process(NsHandle* NS_inst, const float* const* spframe, size_t num_bands, float* const* outframe); /* Returns the internally used prior speech probability of the current frame. * There is a frequency bin based one as well, with which this should not be * confused. * * Input * - handle : Noise suppression instance. * * Return value : Prior speech probability in interval [0.0, 1.0]. * -1 - NULL pointer or uninitialized instance. */ float WebRtcNs_prior_speech_probability(NsHandle* handle); /* Returns a pointer to the noise estimate per frequency bin. The number of * frequency bins can be provided using WebRtcNs_num_freq(). * * Input * - handle : Noise suppression instance. * * Return value : Pointer to the noise estimate per frequency bin. * Returns NULL if the input is a NULL pointer or an * uninitialized instance. */ const float* WebRtcNs_noise_estimate(const NsHandle* handle); /* Returns the number of frequency bins, which is the length of the noise * estimate for example. * * Return value : Number of frequency bins. */ size_t WebRtcNs_num_freq(); #ifdef __cplusplus } #endif #endif // WEBRTC_MODULES_AUDIO_PROCESSING_NS_NOISE_SUPPRESSION_H_