Keep track of the user-facing number of channels in a ChannelBuffer
Before this change the ChannelBuffer had a fixed number of channels. This meant for example that when the Beamformer would reduce the number of channels to one, the merging filter bank was still merging all the channels, which was unnecessary since they were not processed and just discarded later. This change doesn't change the signal at all. It just reflects the number of channels in the ChannelBuffer, reducing the complexity. R=henrik.lundin@webrtc.org, peah@webrtc.org, tina.legrand@webrtc.org Review URL: https://codereview.webrtc.org/2053773002 . Cr-Commit-Position: refs/heads/master@{#13352}
This commit is contained in:
@ -184,6 +184,10 @@ void AudioBuffer::InitForNewData() {
|
||||
reference_copied_ = false;
|
||||
activity_ = AudioFrame::kVadUnknown;
|
||||
num_channels_ = num_proc_channels_;
|
||||
data_->set_num_channels(num_proc_channels_);
|
||||
if (split_data_.get()) {
|
||||
split_data_->set_num_channels(num_proc_channels_);
|
||||
}
|
||||
}
|
||||
|
||||
const int16_t* const* AudioBuffer::channels_const() const {
|
||||
@ -345,6 +349,10 @@ size_t AudioBuffer::num_channels() const {
|
||||
|
||||
void AudioBuffer::set_num_channels(size_t num_channels) {
|
||||
num_channels_ = num_channels;
|
||||
data_->set_num_channels(num_channels);
|
||||
if (split_data_.get()) {
|
||||
split_data_->set_num_channels(num_channels);
|
||||
}
|
||||
}
|
||||
|
||||
size_t AudioBuffer::num_frames() const {
|
||||
|
||||
@ -123,6 +123,8 @@ class AudioBuffer {
|
||||
void MergeFrequencyBands();
|
||||
|
||||
private:
|
||||
FRIEND_TEST_ALL_PREFIXES(AudioBufferTest,
|
||||
SetNumChannelsSetsChannelBuffersNumChannels);
|
||||
// Called from DeinterleaveFrom() and CopyFrom().
|
||||
void InitForNewData();
|
||||
|
||||
|
||||
48
webrtc/modules/audio_processing/audio_buffer_unittest.cc
Normal file
48
webrtc/modules/audio_processing/audio_buffer_unittest.cc
Normal file
@ -0,0 +1,48 @@
|
||||
/*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include "testing/gtest/include/gtest/gtest.h"
|
||||
#include "webrtc/modules/audio_processing/audio_buffer.h"
|
||||
|
||||
namespace webrtc {
|
||||
|
||||
namespace {
|
||||
|
||||
const size_t kNumFrames = 480u;
|
||||
const size_t kStereo = 2u;
|
||||
const size_t kMono = 1u;
|
||||
|
||||
void ExpectNumChannels(const AudioBuffer& ab, size_t num_channels) {
|
||||
EXPECT_EQ(ab.data()->num_channels(), num_channels);
|
||||
EXPECT_EQ(ab.data_f()->num_channels(), num_channels);
|
||||
EXPECT_EQ(ab.split_data()->num_channels(), num_channels);
|
||||
EXPECT_EQ(ab.split_data_f()->num_channels(), num_channels);
|
||||
EXPECT_EQ(ab.num_channels(), num_channels);
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
||||
TEST(AudioBufferTest, SetNumChannelsSetsChannelBuffersNumChannels) {
|
||||
AudioBuffer ab(kNumFrames, kStereo, kNumFrames, kStereo, kNumFrames);
|
||||
ExpectNumChannels(ab, kStereo);
|
||||
ab.set_num_channels(kMono);
|
||||
ExpectNumChannels(ab, kMono);
|
||||
ab.InitForNewData();
|
||||
ExpectNumChannels(ab, kStereo);
|
||||
}
|
||||
|
||||
#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
|
||||
TEST(AudioBufferTest, SetNumChannelsDeathTest) {
|
||||
AudioBuffer ab(kNumFrames, kMono, kNumFrames, kMono, kNumFrames);
|
||||
EXPECT_DEATH(ab.set_num_channels(kStereo), "num_channels");
|
||||
}
|
||||
#endif
|
||||
|
||||
} // namespace webrtc
|
||||
@ -72,8 +72,8 @@ void SplittingFilter::TwoBandsAnalysis(const IFChannelBuffer* data,
|
||||
|
||||
void SplittingFilter::TwoBandsSynthesis(const IFChannelBuffer* bands,
|
||||
IFChannelBuffer* data) {
|
||||
RTC_DCHECK_EQ(two_bands_states_.size(), data->num_channels());
|
||||
for (size_t i = 0; i < two_bands_states_.size(); ++i) {
|
||||
RTC_DCHECK_LE(data->num_channels(), two_bands_states_.size());
|
||||
for (size_t i = 0; i < data->num_channels(); ++i) {
|
||||
WebRtcSpl_SynthesisQMF(bands->ibuf_const()->channels(0)[i],
|
||||
bands->ibuf_const()->channels(1)[i],
|
||||
bands->num_frames_per_band(),
|
||||
@ -95,8 +95,8 @@ void SplittingFilter::ThreeBandsAnalysis(const IFChannelBuffer* data,
|
||||
|
||||
void SplittingFilter::ThreeBandsSynthesis(const IFChannelBuffer* bands,
|
||||
IFChannelBuffer* data) {
|
||||
RTC_DCHECK_EQ(three_band_filter_banks_.size(), data->num_channels());
|
||||
for (size_t i = 0; i < three_band_filter_banks_.size(); ++i) {
|
||||
RTC_DCHECK_LE(data->num_channels(), three_band_filter_banks_.size());
|
||||
for (size_t i = 0; i < data->num_channels(); ++i) {
|
||||
three_band_filter_banks_[i]->Synthesis(bands->fbuf_const()->bands(i),
|
||||
bands->num_frames_per_band(),
|
||||
data->fbuf()->channels()[i]);
|
||||
|
||||
Reference in New Issue
Block a user