FreeCalypso > hg > gsm-codec-lib
annotate libgsmefr/dec_wrap.c @ 494:aaf4dec8bee0
libgsmhr1: implement perfect SID detection
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 17 Jun 2024 23:14:19 +0000 |
parents | f80a3202c8ff |
children |
rev | line source |
---|---|
95
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
2 * This module contains our EFR_decode_frame() function, which is the primary |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 * (most common, most useful) interface to our EFR decoder. |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 */ |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
5 |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 #include "gsm_efr.h" |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
7 |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 void EFR_decode_frame(struct EFR_decoder_state *st, const uint8_t *frame, |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 int bfi, int taf, int16_t *pcm_out) |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 { |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 int16_t params[EFR_NUM_PARAMS]; |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 int sid; |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 EFR_frame2params(frame, params); |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 sid = EFR_sid_classify(frame); |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 EFR_decode_params(st, params, bfi, sid, taf, pcm_out); |
f80a3202c8ff
libgsmefr: implement main decoder wrapper
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 } |