This CL adds code to the BlockProcessor, which basically constitutes the second layer in echo canceller 3. The CL includes two incomplete classes (EchoRemover and EchoPathDelayEstimator) which will be completed in upcoming CLs. Because of this, some of the unittests are disabled until those are added. BUG=webrtc:6018 Review-Url: https://codereview.webrtc.org/2611223003 Cr-Commit-Position: refs/heads/master@{#16319}
213 lines
5.7 KiB
C++
213 lines
5.7 KiB
C++
/*
|
|
* Copyright (c) 2016 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_LOGGING_APM_DATA_DUMPER_H_
|
|
#define WEBRTC_MODULES_AUDIO_PROCESSING_LOGGING_APM_DATA_DUMPER_H_
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
#include <unordered_map>
|
|
|
|
#include "webrtc/base/array_view.h"
|
|
#include "webrtc/base/constructormagic.h"
|
|
#include "webrtc/common_audio/wav_file.h"
|
|
|
|
// Check to verify that the define is properly set.
|
|
#if !defined(WEBRTC_APM_DEBUG_DUMP) || \
|
|
(WEBRTC_APM_DEBUG_DUMP != 0 && WEBRTC_APM_DEBUG_DUMP != 1)
|
|
#error "Set WEBRTC_APM_DEBUG_DUMP to either 0 or 1"
|
|
#endif
|
|
|
|
namespace webrtc {
|
|
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
// Functor used to use as a custom deleter in the map of file pointers to raw
|
|
// files.
|
|
struct RawFileCloseFunctor {
|
|
void operator()(FILE* f) const { fclose(f); }
|
|
};
|
|
#endif
|
|
|
|
// Class that handles dumping of variables into files.
|
|
class ApmDataDumper {
|
|
public:
|
|
// Constructor that takes an instance index that may
|
|
// be used to distinguish data dumped from different
|
|
// instances of the code.
|
|
explicit ApmDataDumper(int instance_index);
|
|
|
|
~ApmDataDumper();
|
|
|
|
// Reinitializes the data dumping such that new versions
|
|
// of all files being dumped to are created.
|
|
void InitiateNewSetOfRecordings() {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
++recording_set_index_;
|
|
#endif
|
|
}
|
|
|
|
// Methods for performing dumping of data of various types into
|
|
// various formats.
|
|
void DumpRaw(const char* name, double v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(&v, sizeof(v), 1, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, size_t v_length, const double* v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(v, sizeof(v[0]), v_length, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, rtc::ArrayView<const double> v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
DumpRaw(name, v.size(), v.data());
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, float v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(&v, sizeof(v), 1, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, size_t v_length, const float* v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(v, sizeof(v[0]), v_length, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, rtc::ArrayView<const float> v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
DumpRaw(name, v.size(), v.data());
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, bool v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
DumpRaw(name, static_cast<int16_t>(v));
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, size_t v_length, const bool* v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
for (size_t k = 0; k < v_length; ++k) {
|
|
int16_t value = static_cast<int16_t>(v[k]);
|
|
fwrite(&value, sizeof(value), 1, file);
|
|
}
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, rtc::ArrayView<const bool> v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
DumpRaw(name, v.size(), v.data());
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, int16_t v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(&v, sizeof(v), 1, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, size_t v_length, const int16_t* v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(v, sizeof(v[0]), v_length, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, rtc::ArrayView<const int16_t> v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
DumpRaw(name, v.size(), v.data());
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, int32_t v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(&v, sizeof(v), 1, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, size_t v_length, const int32_t* v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(v, sizeof(v[0]), v_length, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, size_t v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(&v, sizeof(v), 1, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, size_t v_length, const size_t* v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
FILE* file = GetRawFile(name);
|
|
fwrite(v, sizeof(v[0]), v_length, file);
|
|
#endif
|
|
}
|
|
|
|
void DumpRaw(const char* name, rtc::ArrayView<const int32_t> v) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
DumpRaw(name, v.size(), v.data());
|
|
#endif
|
|
}
|
|
|
|
void DumpWav(const char* name,
|
|
size_t v_length,
|
|
const float* v,
|
|
int sample_rate_hz,
|
|
int num_channels) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
WavWriter* file = GetWavFile(name, sample_rate_hz, num_channels);
|
|
file->WriteSamples(v, v_length);
|
|
#endif
|
|
}
|
|
|
|
void DumpWav(const char* name,
|
|
rtc::ArrayView<const float> v,
|
|
int sample_rate_hz,
|
|
int num_channels) {
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
DumpWav(name, v.size(), v.data(), sample_rate_hz, num_channels);
|
|
#endif
|
|
}
|
|
|
|
private:
|
|
#if WEBRTC_APM_DEBUG_DUMP == 1
|
|
const int instance_index_;
|
|
int recording_set_index_ = 0;
|
|
std::unordered_map<std::string, std::unique_ptr<FILE, RawFileCloseFunctor>>
|
|
raw_files_;
|
|
std::unordered_map<std::string, std::unique_ptr<WavWriter>> wav_files_;
|
|
|
|
FILE* GetRawFile(const char* name);
|
|
WavWriter* GetWavFile(const char* name, int sample_rate_hz, int num_channels);
|
|
#endif
|
|
RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(ApmDataDumper);
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // WEBRTC_MODULES_AUDIO_PROCESSING_LOGGING_APM_DATA_DUMPER_H_
|