mirror of
https://github.com/danog/libtgvoip.git
synced 2025-01-09 06:08:17 +01:00
5caaaafa42
I'm now using the entire audio processing module from WebRTC as opposed to individual DSP algorithms pulled from there before. Seems to work better this way.
90 lines
2.9 KiB
C++
90 lines
2.9 KiB
C++
/*
|
|
* 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 MODULES_AUDIO_PROCESSING_AGC_LOUDNESS_HISTOGRAM_H_
|
|
#define MODULES_AUDIO_PROCESSING_AGC_LOUDNESS_HISTOGRAM_H_
|
|
|
|
#include <stdint.h>
|
|
#include <memory>
|
|
|
|
namespace webrtc {
|
|
|
|
// This class implements the histogram of loudness with circular buffers so that
|
|
// the histogram tracks the last T seconds of the loudness.
|
|
class LoudnessHistogram {
|
|
public:
|
|
// Create a non-sliding LoudnessHistogram.
|
|
static LoudnessHistogram* Create();
|
|
|
|
// Create a sliding LoudnessHistogram, i.e. the histogram represents the last
|
|
// |window_size| samples.
|
|
static LoudnessHistogram* Create(int window_size);
|
|
~LoudnessHistogram();
|
|
|
|
// Insert RMS and the corresponding activity probability.
|
|
void Update(double rms, double activity_probability);
|
|
|
|
// Reset the histogram, forget the past.
|
|
void Reset();
|
|
|
|
// Current loudness, which is actually the mean of histogram in loudness
|
|
// domain.
|
|
double CurrentRms() const;
|
|
|
|
// Sum of the histogram content.
|
|
double AudioContent() const;
|
|
|
|
// Number of times the histogram has been updated.
|
|
int num_updates() const { return num_updates_; }
|
|
|
|
private:
|
|
LoudnessHistogram();
|
|
explicit LoudnessHistogram(int window);
|
|
|
|
// Find the histogram bin associated with the given |rms|.
|
|
int GetBinIndex(double rms);
|
|
|
|
void RemoveOldestEntryAndUpdate();
|
|
void InsertNewestEntryAndUpdate(int activity_prob_q10, int hist_index);
|
|
void UpdateHist(int activity_prob_q10, int hist_index);
|
|
void RemoveTransient();
|
|
|
|
// Number of histogram bins.
|
|
static const int kHistSize = 77;
|
|
|
|
// Number of times the histogram is updated
|
|
int num_updates_;
|
|
// Audio content, this should be equal to the sum of the components of
|
|
// |bin_count_q10_|.
|
|
int64_t audio_content_q10_;
|
|
|
|
// LoudnessHistogram of input RMS in Q10 with |kHistSize_| bins. In each
|
|
// 'Update(),' we increment the associated histogram-bin with the given
|
|
// probability. The increment is implemented in Q10 to avoid rounding errors.
|
|
int64_t bin_count_q10_[kHistSize];
|
|
|
|
// Circular buffer for probabilities
|
|
std::unique_ptr<int[]> activity_probability_;
|
|
// Circular buffer for histogram-indices of probabilities.
|
|
std::unique_ptr<int[]> hist_bin_index_;
|
|
// Current index of circular buffer, where the newest data will be written to,
|
|
// therefore, pointing to the oldest data if buffer is full.
|
|
int buffer_index_;
|
|
// Indicating if buffer is full and we had a wrap around.
|
|
int buffer_is_full_;
|
|
// Size of circular buffer.
|
|
int len_circular_buffer_;
|
|
int len_high_activity_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // MODULES_AUDIO_PROCESSING_AGC_LOUDNESS_HISTOGRAM_H_
|