1*9a19cd78SMatthias Ringwald /****************************************************************************** 2*9a19cd78SMatthias Ringwald * 3*9a19cd78SMatthias Ringwald * Copyright 2021 Google, Inc. 4*9a19cd78SMatthias Ringwald * 5*9a19cd78SMatthias Ringwald * Licensed under the Apache License, Version 2.0 (the "License"); 6*9a19cd78SMatthias Ringwald * you may not use this file except in compliance with the License. 7*9a19cd78SMatthias Ringwald * You may obtain a copy of the License at: 8*9a19cd78SMatthias Ringwald * 9*9a19cd78SMatthias Ringwald * http://www.apache.org/licenses/LICENSE-2.0 10*9a19cd78SMatthias Ringwald * 11*9a19cd78SMatthias Ringwald * Unless required by applicable law or agreed to in writing, software 12*9a19cd78SMatthias Ringwald * distributed under the License is distributed on an "AS IS" BASIS, 13*9a19cd78SMatthias Ringwald * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*9a19cd78SMatthias Ringwald * See the License for the specific language governing permissions and 15*9a19cd78SMatthias Ringwald * limitations under the License. 16*9a19cd78SMatthias Ringwald * 17*9a19cd78SMatthias Ringwald ******************************************************************************/ 18*9a19cd78SMatthias Ringwald 19*9a19cd78SMatthias Ringwald /** 20*9a19cd78SMatthias Ringwald * LC3 - Common constants and types 21*9a19cd78SMatthias Ringwald */ 22*9a19cd78SMatthias Ringwald 23*9a19cd78SMatthias Ringwald #ifndef __LC3_COMMON_H 24*9a19cd78SMatthias Ringwald #define __LC3_COMMON_H 25*9a19cd78SMatthias Ringwald 26*9a19cd78SMatthias Ringwald #include <lc3.h> 27*9a19cd78SMatthias Ringwald 28*9a19cd78SMatthias Ringwald #include <limits.h> 29*9a19cd78SMatthias Ringwald #include <string.h> 30*9a19cd78SMatthias Ringwald #include <math.h> 31*9a19cd78SMatthias Ringwald 32*9a19cd78SMatthias Ringwald 33*9a19cd78SMatthias Ringwald /** 34*9a19cd78SMatthias Ringwald * Macros 35*9a19cd78SMatthias Ringwald * MIN/MAX Minimum and maximum between 2 values 36*9a19cd78SMatthias Ringwald * CLIP Clip a value between low and high limits 37*9a19cd78SMatthias Ringwald * ABS Return the absolute value 38*9a19cd78SMatthias Ringwald */ 39*9a19cd78SMatthias Ringwald 40*9a19cd78SMatthias Ringwald #define LC3_MIN(a, b) ( (a) < (b) ? (a) : (b) ) 41*9a19cd78SMatthias Ringwald #define LC3_MAX(a, b) ( (a) > (b) ? (a) : (b) ) 42*9a19cd78SMatthias Ringwald #define LC3_CLIP(v, min, max) LC3_MIN(LC3_MAX(v, min), max) 43*9a19cd78SMatthias Ringwald 44*9a19cd78SMatthias Ringwald #define LC3_ABS(n) ( (n) < 0 ? -(n) : (n) ) 45*9a19cd78SMatthias Ringwald 46*9a19cd78SMatthias Ringwald 47*9a19cd78SMatthias Ringwald /** 48*9a19cd78SMatthias Ringwald * Convert `dt` in us and `sr` in KHz 49*9a19cd78SMatthias Ringwald */ 50*9a19cd78SMatthias Ringwald 51*9a19cd78SMatthias Ringwald #define LC3_DT_US(dt) \ 52*9a19cd78SMatthias Ringwald ( (3 + (dt)) * 2500 ) 53*9a19cd78SMatthias Ringwald 54*9a19cd78SMatthias Ringwald #define LC3_SRATE_KHZ(sr) \ 55*9a19cd78SMatthias Ringwald ( (1 + (sr) + ((sr) == LC3_SRATE_48K)) * 8 ) 56*9a19cd78SMatthias Ringwald 57*9a19cd78SMatthias Ringwald 58*9a19cd78SMatthias Ringwald /** 59*9a19cd78SMatthias Ringwald * Return number of samples, delayed samples and 60*9a19cd78SMatthias Ringwald * encoded spectrum coefficients within a frame 61*9a19cd78SMatthias Ringwald * For decoding, add number of samples of 18 ms history 62*9a19cd78SMatthias Ringwald */ 63*9a19cd78SMatthias Ringwald 64*9a19cd78SMatthias Ringwald #define LC3_NS(dt, sr) \ 65*9a19cd78SMatthias Ringwald ( 20 * (3 + (dt)) * (1 + (sr) + ((sr) == LC3_SRATE_48K)) ) 66*9a19cd78SMatthias Ringwald 67*9a19cd78SMatthias Ringwald #define LC3_ND(dt, sr) \ 68*9a19cd78SMatthias Ringwald ( (dt) == LC3_DT_7M5 ? 23 * LC3_NS(dt, sr) / 30 \ 69*9a19cd78SMatthias Ringwald : 5 * LC3_NS(dt, sr) / 8 ) 70*9a19cd78SMatthias Ringwald #define LC3_NE(dt, sr) \ 71*9a19cd78SMatthias Ringwald ( 20 * (3 + (dt)) * (1 + (sr)) ) 72*9a19cd78SMatthias Ringwald 73*9a19cd78SMatthias Ringwald #define LC3_MAX_NE \ 74*9a19cd78SMatthias Ringwald LC3_NE(LC3_DT_10M, LC3_SRATE_48K) 75*9a19cd78SMatthias Ringwald 76*9a19cd78SMatthias Ringwald #define LC3_NH(sr) \ 77*9a19cd78SMatthias Ringwald (18 * LC3_SRATE_KHZ(sr)) 78*9a19cd78SMatthias Ringwald 79*9a19cd78SMatthias Ringwald 80*9a19cd78SMatthias Ringwald /** 81*9a19cd78SMatthias Ringwald * Bandwidth, mapped to Nyquist frequency of samplerates 82*9a19cd78SMatthias Ringwald */ 83*9a19cd78SMatthias Ringwald 84*9a19cd78SMatthias Ringwald enum lc3_bandwidth { 85*9a19cd78SMatthias Ringwald LC3_BANDWIDTH_NB = LC3_SRATE_8K, 86*9a19cd78SMatthias Ringwald LC3_BANDWIDTH_WB = LC3_SRATE_16K, 87*9a19cd78SMatthias Ringwald LC3_BANDWIDTH_SSWB = LC3_SRATE_24K, 88*9a19cd78SMatthias Ringwald LC3_BANDWIDTH_SWB = LC3_SRATE_32K, 89*9a19cd78SMatthias Ringwald LC3_BANDWIDTH_FB = LC3_SRATE_48K, 90*9a19cd78SMatthias Ringwald 91*9a19cd78SMatthias Ringwald LC3_NUM_BANDWIDTH, 92*9a19cd78SMatthias Ringwald }; 93*9a19cd78SMatthias Ringwald 94*9a19cd78SMatthias Ringwald 95*9a19cd78SMatthias Ringwald /** 96*9a19cd78SMatthias Ringwald * Complex floating point number 97*9a19cd78SMatthias Ringwald */ 98*9a19cd78SMatthias Ringwald 99*9a19cd78SMatthias Ringwald struct lc3_complex 100*9a19cd78SMatthias Ringwald { 101*9a19cd78SMatthias Ringwald float re, im; 102*9a19cd78SMatthias Ringwald }; 103*9a19cd78SMatthias Ringwald 104*9a19cd78SMatthias Ringwald 105*9a19cd78SMatthias Ringwald #endif /* __LC3_COMMON_H */ 106