xref: /btstack/src/classic/btstack_sbc_plc.h (revision 2fca4dad957cd7b88f4657ed51e89c12615dda72)
14e074f72SMilanka Ringwald /*
24e074f72SMilanka Ringwald  * Copyright (C) 2016 BlueKitchen GmbH
34e074f72SMilanka Ringwald  *
44e074f72SMilanka Ringwald  * Redistribution and use in source and binary forms, with or without
54e074f72SMilanka Ringwald  * modification, are permitted provided that the following conditions
64e074f72SMilanka Ringwald  * are met:
74e074f72SMilanka Ringwald  *
84e074f72SMilanka Ringwald  * 1. Redistributions of source code must retain the above copyright
94e074f72SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer.
104e074f72SMilanka Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
114e074f72SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer in the
124e074f72SMilanka Ringwald  *    documentation and/or other materials provided with the distribution.
134e074f72SMilanka Ringwald  * 3. Neither the name of the copyright holders nor the names of
144e074f72SMilanka Ringwald  *    contributors may be used to endorse or promote products derived
154e074f72SMilanka Ringwald  *    from this software without specific prior written permission.
164e074f72SMilanka Ringwald  * 4. Any redistribution, use, or modification is done solely for
174e074f72SMilanka Ringwald  *    personal benefit and not for any commercial purpose or for
184e074f72SMilanka Ringwald  *    monetary gain.
194e074f72SMilanka Ringwald  *
204e074f72SMilanka Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
214e074f72SMilanka Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
224e074f72SMilanka Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*2fca4dadSMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN
24*2fca4dadSMilanka Ringwald  * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
254e074f72SMilanka Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
264e074f72SMilanka Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
274e074f72SMilanka Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
284e074f72SMilanka Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
294e074f72SMilanka Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
304e074f72SMilanka Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
314e074f72SMilanka Ringwald  * SUCH DAMAGE.
324e074f72SMilanka Ringwald  *
334e074f72SMilanka Ringwald  * Please inquire about commercial licensing options at
344e074f72SMilanka Ringwald  * [email protected]
354e074f72SMilanka Ringwald  *
364e074f72SMilanka Ringwald  */
374e074f72SMilanka Ringwald 
38fe5a6c4eSMilanka Ringwald /**
39fe5a6c4eSMilanka Ringwald  * SBC Packet Loss Concealment
404e074f72SMilanka Ringwald  *
414e074f72SMilanka Ringwald  */
424e074f72SMilanka Ringwald 
4380e33422SMatthias Ringwald #ifndef BTSTACK_SBC_PLC_H
4480e33422SMatthias Ringwald #define BTSTACK_SBC_PLC_H
454e074f72SMilanka Ringwald 
464e074f72SMilanka Ringwald #include <stdint.h>
474e074f72SMilanka Ringwald 
484e074f72SMilanka Ringwald #if defined __cplusplus
494e074f72SMilanka Ringwald extern "C" {
504e074f72SMilanka Ringwald #endif
514e074f72SMilanka Ringwald 
527e6b1e83SMilanka Ringwald #define SBC_FS 120          /* SBC Frame Size */
53ee5b2fc6SMilanka Ringwald #define SBC_N 512           /* 32ms - Window Length for pattern matching */
547e6b1e83SMilanka Ringwald #define SBC_M 64            /* 4ms - Template for matching */
557e6b1e83SMilanka Ringwald #define SBC_LHIST (SBC_N+SBC_FS-1)  /* Length of history buffer required */
567e6b1e83SMilanka Ringwald #define SBC_RT 36           /* SBC Reconvergence Time (samples) */
577e6b1e83SMilanka Ringwald #define SBC_OLAL 16         /* OverLap-Add Length (samples) */
584e074f72SMilanka Ringwald 
594e074f72SMilanka Ringwald /* PLC State Information */
604e074f72SMilanka Ringwald typedef struct sbc_plc_state {
617e6b1e83SMilanka Ringwald     int16_t hist[SBC_LHIST+SBC_FS+SBC_RT+SBC_OLAL];
624e074f72SMilanka Ringwald     int16_t bestlag;
634e074f72SMilanka Ringwald     int     nbf;
64de854f9aSMilanka Ringwald 
65de854f9aSMilanka Ringwald     // summary of processed good and bad frames
66de854f9aSMilanka Ringwald     int good_frames_nr;
67de854f9aSMilanka Ringwald     int bad_frames_nr;
68de854f9aSMilanka Ringwald     int frame_count;
69de854f9aSMilanka Ringwald     int max_consecutive_bad_frames_nr;
70e7a41128SMilanka Ringwald } btstack_sbc_plc_state_t;
71e7a41128SMilanka Ringwald 
727cd567c8SMatthias Ringwald // All int16 audio samples are in host endiness
73e7a41128SMilanka Ringwald void btstack_sbc_plc_init(btstack_sbc_plc_state_t *plc_state);
74e7a41128SMilanka Ringwald void btstack_sbc_plc_bad_frame(btstack_sbc_plc_state_t *plc_state, int16_t *ZIRbuf, int16_t *out);
75e7a41128SMilanka Ringwald void btstack_sbc_plc_good_frame(btstack_sbc_plc_state_t *plc_state, int16_t *in, int16_t *out);
76e7a41128SMilanka Ringwald uint8_t * btstack_sbc_plc_zero_signal_frame(void);
77de854f9aSMilanka Ringwald void btstack_sbc_dump_statistics(btstack_sbc_plc_state_t * state);
784e074f72SMilanka Ringwald 
79ee5b2fc6SMilanka Ringwald #ifdef OCTAVE_OUTPUT
80d1550f90SMilanka Ringwald void btstack_sbc_plc_octave_set_base_name(const char * name);
81ee5b2fc6SMilanka Ringwald #endif
82ee5b2fc6SMilanka Ringwald 
834e074f72SMilanka Ringwald #if defined __cplusplus
844e074f72SMilanka Ringwald }
854e074f72SMilanka Ringwald #endif
864e074f72SMilanka Ringwald 
8780e33422SMatthias Ringwald #endif // BTSTACK_SBC_PLC_H
88