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_LTPF_H 20*49fe348cSAndroid Build Coastguard Worker #define __LC3_LTPF_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 * LTPF data 28*49fe348cSAndroid Build Coastguard Worker */ 29*49fe348cSAndroid Build Coastguard Worker 30*49fe348cSAndroid Build Coastguard Worker typedef struct lc3_ltpf_data { 31*49fe348cSAndroid Build Coastguard Worker bool active; 32*49fe348cSAndroid Build Coastguard Worker int pitch_index; 33*49fe348cSAndroid Build Coastguard Worker } lc3_ltpf_data_t; 34*49fe348cSAndroid Build Coastguard Worker 35*49fe348cSAndroid Build Coastguard Worker 36*49fe348cSAndroid Build Coastguard Worker /* ---------------------------------------------------------------------------- 37*49fe348cSAndroid Build Coastguard Worker * Encoding 38*49fe348cSAndroid Build Coastguard Worker * -------------------------------------------------------------------------- */ 39*49fe348cSAndroid Build Coastguard Worker 40*49fe348cSAndroid Build Coastguard Worker /** 41*49fe348cSAndroid Build Coastguard Worker * LTPF analysis 42*49fe348cSAndroid Build Coastguard Worker * dt, sr Duration and samplerate of the frame 43*49fe348cSAndroid Build Coastguard Worker * ltpf Context of analysis 44*49fe348cSAndroid Build Coastguard Worker * allowed True when activation of LTPF is allowed 45*49fe348cSAndroid Build Coastguard Worker * x [-d..-1] Previous, [0..ns-1] Current samples 46*49fe348cSAndroid Build Coastguard Worker * data Return bitstream data 47*49fe348cSAndroid Build Coastguard Worker * return True when pitch present, False otherwise 48*49fe348cSAndroid Build Coastguard Worker * 49*49fe348cSAndroid Build Coastguard Worker * The `x` vector is aligned on 32 bits 50*49fe348cSAndroid Build Coastguard Worker * The number of previous samples `d` accessed on `x` is : 51*49fe348cSAndroid Build Coastguard Worker * d: { 10, 20, 30, 40, 60 } - 1 for samplerates from 8KHz to 48KHz 52*49fe348cSAndroid Build Coastguard Worker */ 53*49fe348cSAndroid Build Coastguard Worker bool lc3_ltpf_analyse(enum lc3_dt dt, enum lc3_srate sr, 54*49fe348cSAndroid Build Coastguard Worker lc3_ltpf_analysis_t *ltpf, const int16_t *x, lc3_ltpf_data_t *data); 55*49fe348cSAndroid Build Coastguard Worker 56*49fe348cSAndroid Build Coastguard Worker /** 57*49fe348cSAndroid Build Coastguard Worker * LTPF disable 58*49fe348cSAndroid Build Coastguard Worker * data LTPF data, disabled activation on return 59*49fe348cSAndroid Build Coastguard Worker */ 60*49fe348cSAndroid Build Coastguard Worker void lc3_ltpf_disable(lc3_ltpf_data_t *data); 61*49fe348cSAndroid Build Coastguard Worker 62*49fe348cSAndroid Build Coastguard Worker /** 63*49fe348cSAndroid Build Coastguard Worker * Return number of bits coding the bitstream data 64*49fe348cSAndroid Build Coastguard Worker * pitch True when pitch present, False otherwise 65*49fe348cSAndroid Build Coastguard Worker * return Bit consumption, including the pitch present flag 66*49fe348cSAndroid Build Coastguard Worker */ 67*49fe348cSAndroid Build Coastguard Worker int lc3_ltpf_get_nbits(bool pitch); 68*49fe348cSAndroid Build Coastguard Worker 69*49fe348cSAndroid Build Coastguard Worker /** 70*49fe348cSAndroid Build Coastguard Worker * Put bitstream data 71*49fe348cSAndroid Build Coastguard Worker * bits Bitstream context 72*49fe348cSAndroid Build Coastguard Worker * data LTPF data 73*49fe348cSAndroid Build Coastguard Worker */ 74*49fe348cSAndroid Build Coastguard Worker void lc3_ltpf_put_data(lc3_bits_t *bits, const lc3_ltpf_data_t *data); 75*49fe348cSAndroid Build Coastguard Worker 76*49fe348cSAndroid Build Coastguard Worker 77*49fe348cSAndroid Build Coastguard Worker /* ---------------------------------------------------------------------------- 78*49fe348cSAndroid Build Coastguard Worker * Decoding 79*49fe348cSAndroid Build Coastguard Worker * -------------------------------------------------------------------------- */ 80*49fe348cSAndroid Build Coastguard Worker /** 81*49fe348cSAndroid Build Coastguard Worker * Get bitstream data 82*49fe348cSAndroid Build Coastguard Worker * bits Bitstream context 83*49fe348cSAndroid Build Coastguard Worker * data Return bitstream data 84*49fe348cSAndroid Build Coastguard Worker */ 85*49fe348cSAndroid Build Coastguard Worker void lc3_ltpf_get_data(lc3_bits_t *bits, lc3_ltpf_data_t *data); 86*49fe348cSAndroid Build Coastguard Worker 87*49fe348cSAndroid Build Coastguard Worker /** 88*49fe348cSAndroid Build Coastguard Worker * LTPF synthesis 89*49fe348cSAndroid Build Coastguard Worker * dt, sr Duration and samplerate of the frame 90*49fe348cSAndroid Build Coastguard Worker * nbytes Size in bytes of the frame 91*49fe348cSAndroid Build Coastguard Worker * ltpf Context of synthesis 92*49fe348cSAndroid Build Coastguard Worker * data Bitstream data, NULL when pitch not present 93*49fe348cSAndroid Build Coastguard Worker * xr Base address of ring buffer of decoded samples 94*49fe348cSAndroid Build Coastguard Worker * x Samples to proceed in the ring buffer, filtered as output 95*49fe348cSAndroid Build Coastguard Worker * 96*49fe348cSAndroid Build Coastguard Worker * The size of the ring buffer is `nh + ns`. 97*49fe348cSAndroid Build Coastguard Worker * The filtering needs an history of at least 18 ms. 98*49fe348cSAndroid Build Coastguard Worker */ 99*49fe348cSAndroid Build Coastguard Worker void lc3_ltpf_synthesize(enum lc3_dt dt, enum lc3_srate sr, int nbytes, 100*49fe348cSAndroid Build Coastguard Worker lc3_ltpf_synthesis_t *ltpf, const lc3_ltpf_data_t *data, 101*49fe348cSAndroid Build Coastguard Worker const float *xr, float *x); 102*49fe348cSAndroid Build Coastguard Worker 103*49fe348cSAndroid Build Coastguard Worker 104*49fe348cSAndroid Build Coastguard Worker #endif /* __LC3_LTPF_H */ 105