mirror of
https://github.com/google/liblc3.git
synced 2026-04-18 05:35:31 +00:00
Duplicate interfaces for HR mode spec: Remove intermediate quantized table fix: legacy lc3_frame_bytes() and lc3_resolve_bitrate() Cosmetic: rename fast_xxx math function to lc3_xxx
63 lines
1.6 KiB
C
63 lines
1.6 KiB
C
/******************************************************************************
|
|
*
|
|
* Copyright 2022 Google LLC
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at:
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
******************************************************************************/
|
|
|
|
#include "plc.h"
|
|
#include "tables.h"
|
|
|
|
|
|
/**
|
|
* Reset Packet Loss Concealment state
|
|
*/
|
|
void lc3_plc_reset(struct lc3_plc_state *plc)
|
|
{
|
|
plc->seed = 24607;
|
|
lc3_plc_suspend(plc);
|
|
}
|
|
|
|
/**
|
|
* Suspend PLC execution (Good frame received)
|
|
*/
|
|
void lc3_plc_suspend(struct lc3_plc_state *plc)
|
|
{
|
|
plc->count = 1;
|
|
plc->alpha = 1.0f;
|
|
}
|
|
|
|
/**
|
|
* Synthesis of a PLC frame
|
|
*/
|
|
void lc3_plc_synthesize(enum lc3_dt dt, enum lc3_srate sr,
|
|
struct lc3_plc_state *plc, const float *x, float *y)
|
|
{
|
|
uint16_t seed = plc->seed;
|
|
float alpha = plc->alpha;
|
|
int ne = lc3_ne(dt, sr);
|
|
|
|
alpha *= (plc->count < 4 ? 1.0f :
|
|
plc->count < 8 ? 0.9f : 0.85f);
|
|
|
|
for (int i = 0; i < ne; i++) {
|
|
seed = (16831 + seed * 12821) & 0xffff;
|
|
y[i] = alpha * (seed & 0x8000 ? -x[i] : x[i]);
|
|
}
|
|
|
|
plc->seed = seed;
|
|
plc->alpha = alpha;
|
|
plc->count++;
|
|
}
|