xref: /btstack/3rd-party/lc3-google/src/spec.h (revision 4930cef6e21e6da2d7571b9259c7f0fb8bed3d01)
19a19cd78SMatthias Ringwald /******************************************************************************
29a19cd78SMatthias Ringwald  *
3*4930cef6SMatthias Ringwald  *  Copyright 2022 Google LLC
49a19cd78SMatthias Ringwald  *
59a19cd78SMatthias Ringwald  *  Licensed under the Apache License, Version 2.0 (the "License");
69a19cd78SMatthias Ringwald  *  you may not use this file except in compliance with the License.
79a19cd78SMatthias Ringwald  *  You may obtain a copy of the License at:
89a19cd78SMatthias Ringwald  *
99a19cd78SMatthias Ringwald  *  http://www.apache.org/licenses/LICENSE-2.0
109a19cd78SMatthias Ringwald  *
119a19cd78SMatthias Ringwald  *  Unless required by applicable law or agreed to in writing, software
129a19cd78SMatthias Ringwald  *  distributed under the License is distributed on an "AS IS" BASIS,
139a19cd78SMatthias Ringwald  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
149a19cd78SMatthias Ringwald  *  See the License for the specific language governing permissions and
159a19cd78SMatthias Ringwald  *  limitations under the License.
169a19cd78SMatthias Ringwald  *
179a19cd78SMatthias Ringwald  ******************************************************************************/
189a19cd78SMatthias Ringwald 
199a19cd78SMatthias Ringwald /**
209a19cd78SMatthias Ringwald  * LC3 - Spectral coefficients encoding/decoding
219a19cd78SMatthias Ringwald  *
229a19cd78SMatthias Ringwald  * Reference : Low Complexity Communication Codec (LC3)
239a19cd78SMatthias Ringwald  *             Bluetooth Specification v1.0
249a19cd78SMatthias Ringwald  */
259a19cd78SMatthias Ringwald 
269a19cd78SMatthias Ringwald #ifndef __LC3_SPEC_H
279a19cd78SMatthias Ringwald #define __LC3_SPEC_H
289a19cd78SMatthias Ringwald 
299a19cd78SMatthias Ringwald #include "common.h"
309a19cd78SMatthias Ringwald #include "tables.h"
319a19cd78SMatthias Ringwald #include "bwdet.h"
329a19cd78SMatthias Ringwald #include "ltpf.h"
339a19cd78SMatthias Ringwald #include "tns.h"
349a19cd78SMatthias Ringwald #include "sns.h"
359a19cd78SMatthias Ringwald 
369a19cd78SMatthias Ringwald 
379a19cd78SMatthias Ringwald /**
389a19cd78SMatthias Ringwald  * Spectral quantization side data
399a19cd78SMatthias Ringwald  */
409a19cd78SMatthias Ringwald typedef struct lc3_spec_side {
419a19cd78SMatthias Ringwald     int g_idx, nq;
429a19cd78SMatthias Ringwald     bool lsb_mode;
439a19cd78SMatthias Ringwald } lc3_spec_side_t;
449a19cd78SMatthias Ringwald 
459a19cd78SMatthias Ringwald 
469a19cd78SMatthias Ringwald /* ----------------------------------------------------------------------------
479a19cd78SMatthias Ringwald  *  Encoding
489a19cd78SMatthias Ringwald  * -------------------------------------------------------------------------- */
499a19cd78SMatthias Ringwald 
509a19cd78SMatthias Ringwald /**
519a19cd78SMatthias Ringwald  * Spectrum analysis
529a19cd78SMatthias Ringwald  * dt, sr, nbytes  Duration, samplerate and size of the frame
539a19cd78SMatthias Ringwald  * pitch, tns      Pitch present indication and TNS bistream data
549a19cd78SMatthias Ringwald  * spec            Context of analysis
559a19cd78SMatthias Ringwald  * x               Spectral coefficients, scaled as output
569a19cd78SMatthias Ringwald  * xq, side        Return quantization data
57*4930cef6SMatthias Ringwald  *
58*4930cef6SMatthias Ringwald  * The spectral coefficients `xq` storage is :
59*4930cef6SMatthias Ringwald  *   b0       0:positive or zero  1:negative
60*4930cef6SMatthias Ringwald  *   b15..b1  Absolute value
619a19cd78SMatthias Ringwald  */
629a19cd78SMatthias Ringwald void lc3_spec_analyze(enum lc3_dt dt, enum lc3_srate sr,
639a19cd78SMatthias Ringwald     int nbytes, bool pitch, const lc3_tns_data_t *tns,
64*4930cef6SMatthias Ringwald     lc3_spec_analysis_t *spec, float *x, uint16_t *xq, lc3_spec_side_t *side);
659a19cd78SMatthias Ringwald 
669a19cd78SMatthias Ringwald /**
679a19cd78SMatthias Ringwald  * Put spectral quantization side data
689a19cd78SMatthias Ringwald  * bits            Bitstream context
699a19cd78SMatthias Ringwald  * dt, sr          Duration and samplerate of the frame
709a19cd78SMatthias Ringwald  * side            Spectral quantization side data
719a19cd78SMatthias Ringwald  */
729a19cd78SMatthias Ringwald void lc3_spec_put_side(lc3_bits_t *bits,
739a19cd78SMatthias Ringwald     enum lc3_dt dt, enum lc3_srate sr, const lc3_spec_side_t *side);
749a19cd78SMatthias Ringwald 
759a19cd78SMatthias Ringwald /**
769a19cd78SMatthias Ringwald  * Encode spectral coefficients
779a19cd78SMatthias Ringwald  * bits            Bitstream context
789a19cd78SMatthias Ringwald  * dt, sr, bw      Duration, samplerate, bandwidth
799a19cd78SMatthias Ringwald  * nbytes          and size of the frame
809a19cd78SMatthias Ringwald  * xq, side        Quantization data
819a19cd78SMatthias Ringwald  * x               Scaled spectral coefficients
82*4930cef6SMatthias Ringwald  *
83*4930cef6SMatthias Ringwald  * The spectral coefficients `xq` storage is :
84*4930cef6SMatthias Ringwald  *   b0       0:positive or zero  1:negative
85*4930cef6SMatthias Ringwald  *   b15..b1  Absolute value
869a19cd78SMatthias Ringwald  */
879a19cd78SMatthias Ringwald void lc3_spec_encode(lc3_bits_t *bits,
889a19cd78SMatthias Ringwald     enum lc3_dt dt, enum lc3_srate sr, enum lc3_bandwidth bw, int nbytes,
89*4930cef6SMatthias Ringwald     const uint16_t *xq, const lc3_spec_side_t *side, const float *x);
909a19cd78SMatthias Ringwald 
919a19cd78SMatthias Ringwald 
929a19cd78SMatthias Ringwald /* ----------------------------------------------------------------------------
939a19cd78SMatthias Ringwald  *  Decoding
949a19cd78SMatthias Ringwald  * -------------------------------------------------------------------------- */
959a19cd78SMatthias Ringwald 
969a19cd78SMatthias Ringwald /**
979a19cd78SMatthias Ringwald  * Get spectral quantization side data
989a19cd78SMatthias Ringwald  * bits            Bitstream context
999a19cd78SMatthias Ringwald  * dt, sr          Duration and samplerate of the frame
1009a19cd78SMatthias Ringwald  * side            Return quantization side data
1019a19cd78SMatthias Ringwald  * return          0: Ok  -1: Invalid bandwidth indication
1029a19cd78SMatthias Ringwald  */
1039a19cd78SMatthias Ringwald int lc3_spec_get_side(lc3_bits_t *bits,
1049a19cd78SMatthias Ringwald     enum lc3_dt dt, enum lc3_srate sr, lc3_spec_side_t *side);
1059a19cd78SMatthias Ringwald 
1069a19cd78SMatthias Ringwald /**
1079a19cd78SMatthias Ringwald  * Decode spectral coefficients
1089a19cd78SMatthias Ringwald  * bits            Bitstream context
1099a19cd78SMatthias Ringwald  * dt, sr, bw      Duration, samplerate, bandwidth
1109a19cd78SMatthias Ringwald  * nbytes          and size of the frame
1119a19cd78SMatthias Ringwald  * side            Quantization side data
1129a19cd78SMatthias Ringwald  * x               Spectral coefficients
1139a19cd78SMatthias Ringwald  * return          0: Ok  -1: Invalid bitstream data
1149a19cd78SMatthias Ringwald  */
1159a19cd78SMatthias Ringwald int lc3_spec_decode(lc3_bits_t *bits, enum lc3_dt dt, enum lc3_srate sr,
1169a19cd78SMatthias Ringwald     enum lc3_bandwidth bw, int nbytes, const lc3_spec_side_t *side, float *x);
1179a19cd78SMatthias Ringwald 
1189a19cd78SMatthias Ringwald 
1199a19cd78SMatthias Ringwald #endif /* __LC3_SPEC_H */
120