1*49fe348cSAndroid Build Coastguard Worker /****************************************************************************** 2*49fe348cSAndroid Build Coastguard Worker * 3*49fe348cSAndroid Build Coastguard Worker * Copyright 2022 Google LLC 4*49fe348cSAndroid Build Coastguard Worker * 5*49fe348cSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 6*49fe348cSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 7*49fe348cSAndroid Build Coastguard Worker * You may obtain a copy of the License at: 8*49fe348cSAndroid Build Coastguard Worker * 9*49fe348cSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 10*49fe348cSAndroid Build Coastguard Worker * 11*49fe348cSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 12*49fe348cSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 13*49fe348cSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*49fe348cSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 15*49fe348cSAndroid Build Coastguard Worker * limitations under the License. 16*49fe348cSAndroid Build Coastguard Worker * 17*49fe348cSAndroid Build Coastguard Worker ******************************************************************************/ 18*49fe348cSAndroid Build Coastguard Worker 19*49fe348cSAndroid Build Coastguard Worker #ifndef __LC3_TNS_H 20*49fe348cSAndroid Build Coastguard Worker #define __LC3_TNS_H 21*49fe348cSAndroid Build Coastguard Worker 22*49fe348cSAndroid Build Coastguard Worker #include "common.h" 23*49fe348cSAndroid Build Coastguard Worker #include "bits.h" 24*49fe348cSAndroid Build Coastguard Worker 25*49fe348cSAndroid Build Coastguard Worker 26*49fe348cSAndroid Build Coastguard Worker /** 27*49fe348cSAndroid Build Coastguard Worker * Bitstream data 28*49fe348cSAndroid Build Coastguard Worker */ 29*49fe348cSAndroid Build Coastguard Worker 30*49fe348cSAndroid Build Coastguard Worker typedef struct lc3_tns_data { 31*49fe348cSAndroid Build Coastguard Worker int nfilters; 32*49fe348cSAndroid Build Coastguard Worker bool lpc_weighting; 33*49fe348cSAndroid Build Coastguard Worker int rc_order[2]; 34*49fe348cSAndroid Build Coastguard Worker int rc[2][8]; 35*49fe348cSAndroid Build Coastguard Worker } lc3_tns_data_t; 36*49fe348cSAndroid Build Coastguard Worker 37*49fe348cSAndroid Build Coastguard Worker 38*49fe348cSAndroid Build Coastguard Worker /* ---------------------------------------------------------------------------- 39*49fe348cSAndroid Build Coastguard Worker * Encoding 40*49fe348cSAndroid Build Coastguard Worker * -------------------------------------------------------------------------- */ 41*49fe348cSAndroid Build Coastguard Worker 42*49fe348cSAndroid Build Coastguard Worker /** 43*49fe348cSAndroid Build Coastguard Worker * TNS analysis 44*49fe348cSAndroid Build Coastguard Worker * dt, bw Duration and bandwidth of the frame 45*49fe348cSAndroid Build Coastguard Worker * nn_flag True when high energy detected near Nyquist frequency 46*49fe348cSAndroid Build Coastguard Worker * nbytes Size in bytes of the frame 47*49fe348cSAndroid Build Coastguard Worker * data Return bitstream data 48*49fe348cSAndroid Build Coastguard Worker * x Spectral coefficients, filtered as output 49*49fe348cSAndroid Build Coastguard Worker */ 50*49fe348cSAndroid Build Coastguard Worker void lc3_tns_analyze(enum lc3_dt dt, enum lc3_bandwidth bw, 51*49fe348cSAndroid Build Coastguard Worker bool nn_flag, int nbytes, lc3_tns_data_t *data, float *x); 52*49fe348cSAndroid Build Coastguard Worker 53*49fe348cSAndroid Build Coastguard Worker /** 54*49fe348cSAndroid Build Coastguard Worker * Return number of bits coding the data 55*49fe348cSAndroid Build Coastguard Worker * data Bitstream data 56*49fe348cSAndroid Build Coastguard Worker * return Bit consumption 57*49fe348cSAndroid Build Coastguard Worker */ 58*49fe348cSAndroid Build Coastguard Worker int lc3_tns_get_nbits(const lc3_tns_data_t *data); 59*49fe348cSAndroid Build Coastguard Worker 60*49fe348cSAndroid Build Coastguard Worker /** 61*49fe348cSAndroid Build Coastguard Worker * Put bitstream data 62*49fe348cSAndroid Build Coastguard Worker * bits Bitstream context 63*49fe348cSAndroid Build Coastguard Worker * data Bitstream data 64*49fe348cSAndroid Build Coastguard Worker */ 65*49fe348cSAndroid Build Coastguard Worker void lc3_tns_put_data(lc3_bits_t *bits, const lc3_tns_data_t *data); 66*49fe348cSAndroid Build Coastguard Worker 67*49fe348cSAndroid Build Coastguard Worker 68*49fe348cSAndroid Build Coastguard Worker /* ---------------------------------------------------------------------------- 69*49fe348cSAndroid Build Coastguard Worker * Decoding 70*49fe348cSAndroid Build Coastguard Worker * -------------------------------------------------------------------------- */ 71*49fe348cSAndroid Build Coastguard Worker 72*49fe348cSAndroid Build Coastguard Worker /** 73*49fe348cSAndroid Build Coastguard Worker * Get bitstream data 74*49fe348cSAndroid Build Coastguard Worker * bits Bitstream context 75*49fe348cSAndroid Build Coastguard Worker * dt, bw Duration and bandwidth of the frame 76*49fe348cSAndroid Build Coastguard Worker * nbytes Size in bytes of the frame 77*49fe348cSAndroid Build Coastguard Worker * data Bitstream data 78*49fe348cSAndroid Build Coastguard Worker * return 0: Ok -1: Invalid bitstream data 79*49fe348cSAndroid Build Coastguard Worker */ 80*49fe348cSAndroid Build Coastguard Worker int lc3_tns_get_data(lc3_bits_t *bits, 81*49fe348cSAndroid Build Coastguard Worker enum lc3_dt dt, enum lc3_bandwidth bw, int nbytes, lc3_tns_data_t *data); 82*49fe348cSAndroid Build Coastguard Worker 83*49fe348cSAndroid Build Coastguard Worker /** 84*49fe348cSAndroid Build Coastguard Worker * TNS synthesis 85*49fe348cSAndroid Build Coastguard Worker * dt, bw Duration and bandwidth of the frame 86*49fe348cSAndroid Build Coastguard Worker * data Bitstream data 87*49fe348cSAndroid Build Coastguard Worker * x Spectral coefficients, filtered as output 88*49fe348cSAndroid Build Coastguard Worker */ 89*49fe348cSAndroid Build Coastguard Worker void lc3_tns_synthesize(enum lc3_dt dt, enum lc3_bandwidth bw, 90*49fe348cSAndroid Build Coastguard Worker const lc3_tns_data_t *data, float *x); 91*49fe348cSAndroid Build Coastguard Worker 92*49fe348cSAndroid Build Coastguard Worker 93*49fe348cSAndroid Build Coastguard Worker #endif /* __LC3_TNS_H */ 94