blob: 3a5e835e21d3b782fe2eb971ea7a7b8f1bda93f2 [file] [log] [blame]
peahd0263542017-01-03 04:20:34 -08001/*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
peah522d71b2017-02-23 05:16:26 -080011#ifndef WEBRTC_MODULES_AUDIO_PROCESSING_AEC3_AEC3_COMMON_H_
12#define WEBRTC_MODULES_AUDIO_PROCESSING_AEC3_AEC3_COMMON_H_
peahd0263542017-01-03 04:20:34 -080013
14#include <stddef.h>
peah522d71b2017-02-23 05:16:26 -080015#include "webrtc/typedefs.h"
peahd0263542017-01-03 04:20:34 -080016
17namespace webrtc {
18
peah522d71b2017-02-23 05:16:26 -080019#ifdef _MSC_VER /* visual c++ */
20#define ALIGN16_BEG __declspec(align(16))
21#define ALIGN16_END
22#else /* gcc or icc */
23#define ALIGN16_BEG
24#define ALIGN16_END __attribute__((aligned(16)))
25#endif
26
27enum class Aec3Optimization { kNone, kSse2 };
28
peahd0263542017-01-03 04:20:34 -080029constexpr size_t kFftLengthBy2 = 64;
30constexpr size_t kFftLengthBy2Plus1 = kFftLengthBy2 + 1;
peah522d71b2017-02-23 05:16:26 -080031constexpr size_t kFftLengthBy2Minus1 = kFftLengthBy2 - 1;
peahd0263542017-01-03 04:20:34 -080032constexpr size_t kFftLength = 2 * kFftLengthBy2;
33
34constexpr size_t kMaxNumBands = 3;
35constexpr size_t kSubFrameLength = 80;
36
37constexpr size_t kBlockSize = kFftLengthBy2;
38constexpr size_t kExtendedBlockSize = 2 * kFftLengthBy2;
39constexpr size_t kSubBlockSize = 16;
40
41constexpr size_t NumBandsForRate(int sample_rate_hz) {
42 return static_cast<size_t>(sample_rate_hz == 8000 ? 1
43 : sample_rate_hz / 16000);
44}
45constexpr int LowestBandRate(int sample_rate_hz) {
46 return sample_rate_hz == 8000 ? sample_rate_hz : 16000;
47}
48
peah21920892017-02-08 05:08:56 -080049constexpr bool ValidFullBandRate(int sample_rate_hz) {
50 return sample_rate_hz == 8000 || sample_rate_hz == 16000 ||
51 sample_rate_hz == 32000 || sample_rate_hz == 48000;
52}
53
peah522d71b2017-02-23 05:16:26 -080054// Detects what kind of optimizations to use for the code.
55Aec3Optimization DetectOptimization();
56
peahd0263542017-01-03 04:20:34 -080057static_assert(1 == NumBandsForRate(8000), "Number of bands for 8 kHz");
58static_assert(1 == NumBandsForRate(16000), "Number of bands for 16 kHz");
59static_assert(2 == NumBandsForRate(32000), "Number of bands for 32 kHz");
60static_assert(3 == NumBandsForRate(48000), "Number of bands for 48 kHz");
61
62static_assert(8000 == LowestBandRate(8000), "Sample rate of band 0 for 8 kHz");
63static_assert(16000 == LowestBandRate(16000),
64 "Sample rate of band 0 for 16 kHz");
65static_assert(16000 == LowestBandRate(32000),
66 "Sample rate of band 0 for 32 kHz");
67static_assert(16000 == LowestBandRate(48000),
68 "Sample rate of band 0 for 48 kHz");
69
peah21920892017-02-08 05:08:56 -080070static_assert(ValidFullBandRate(8000),
71 "Test that 8 kHz is a valid sample rate");
72static_assert(ValidFullBandRate(16000),
73 "Test that 16 kHz is a valid sample rate");
74static_assert(ValidFullBandRate(32000),
75 "Test that 32 kHz is a valid sample rate");
76static_assert(ValidFullBandRate(48000),
77 "Test that 48 kHz is a valid sample rate");
78static_assert(!ValidFullBandRate(8001),
79 "Test that 8001 Hz is not a valid sample rate");
80
peahd0263542017-01-03 04:20:34 -080081} // namespace webrtc
82
peah522d71b2017-02-23 05:16:26 -080083#endif // WEBRTC_MODULES_AUDIO_PROCESSING_AEC3_AEC3_COMMON_H_