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