annotate doc/AMR-EFR-hybrid-emu @ 477:4c9222d95647

libtwamr encoder: always emit frame->mode = mode; In the original implementation of amr_encode_frame(), the 'mode' member of the output struct was set to 0xFF if the output frame type is TX_NO_DATA. This design was made to mimic the mode field (16-bit word) being set to 0xFFFF (or -1) in 3GPP test sequence format - but nothing actually depends on this struct member being set in any way, and amr_frame_to_tseq() generates the needed 0xFFFF on its own, based on frame->type being equal to TX_NO_DATA. It is simpler and more efficient to always set frame->mode to the actual encoding mode in amr_encode_frame(), and this new behavior has already been documented in doc/AMR-library-API description in anticipation of the present change.
author Mychaela Falconia <falcon@freecalypso.org>
date Sat, 18 May 2024 22:30:42 +0000
parents ad032051166a
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
1 Emulation of other people's AMR-EFR hybrid implementations
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
2 ==========================================================
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
3
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
4 [Please see AMR-EFR-philosophy article for background information on the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
5 differences between classic GSM-EFR and the 12k2 mode of AMR, and how ETSI/3GPP
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
6 loosened their regulation on bit-exactness of EFR, then continue here.]
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
7
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
8 Experiments reveal that the extant commercial GSM networks of T-Mobile USA and
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
9 Telcel Mexico (and likely other countries' GSM networks too) use a GSM speech
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
10 transcoder implementation that performs EFR encoding and decoding (for times
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
11 when the MS declares no support for AMR and the network falls back to EFR) per
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
12 the alternative which we call AMR-EFR hybrid. The needed experiments are done
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
13 by using a FreeCalypso phone or devboard as the MS (declaring yourself to the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
14 network as non-AMR-capable via AT%SPVER), capturing TCH DL and feeding TCH UL
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
15 with FreeCalypso tools, and using a SIP-to-PSTN connectivity provider (BulkVS
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
16 or Anveo) on the other end of the test call that allows the experimenter to
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
17 receive the PCMU or PCMA sample stream coming out of the GSM network's speech
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
18 transcoder and feed a crafted PCMU/PCMA sample stream in the other direction.
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
19
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
20 In this experimental setup, bit-exact details of how the GSM network under study
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
21 implements EFR decoding can be tested by feeding a controlled sequence of EFR
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
22 codec frames (beginning with at least two DHFs) to GSM Um uplink and observing
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
23 the PCMU or PCMA sample stream received on the IP-PSTN end of the call.
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
24 Similarly, bit-exact details of how the NUS implements EFR encoding can be
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
25 tested by feeding controlled PCMU/PCMA sample streams into the call from IP-PSTN
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
26 and observing what the network emits on GSM Um downlink. In the latter case,
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
27 frame synchronization finding tricks described in ETSI/3GPP test sequence specs
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
28 need to included as part of the experiment.
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
29
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
30 When these experiments were performed on the GSM networks of T-Mobile USA and
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
31 Telcel Mexico, it was immediately apparent that they do not implement EFR
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
32 following the original bit-exact code of GSM 06.53: feeding any of the original
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
33 EFR test sequences from GSM 06.54 to the NUS does not produce matching results.
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
34 However, when I tried feeding EFR codec frame sequences from amr122_efr.zip
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
35 (the late addendum to GSM 06.54 for the AMR-EFR hybrid option) to GSM UL, the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
36 PCMU (T-Mobile USA) or PCMA (Telcel Mexico) output from the GSM network's EFR
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
37 decoder matched _those_ test sequences, indicating that these networks use the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
38 AMR-EFR alternative implementation.
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
39
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
40 Creating tinkerer-oriented FOSS tools that can emulate or replicate the poorly
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
41 defined "EFR alternative 2" implemented by these extant commercial networks has
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
42 been a sportive challenge ever since. The present development in Themyscira
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
43 GSM codec libraries and utilities suite is a step toward conquering that
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
44 challenge: we are now able to replicate the mystery commercial transcoder in
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
45 non-DTX operation, specifically:
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
46
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
47 a) We can feed a SID-free stream of EFR codec frames to GSM UL, beginning with
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
48 DHF, and get the expected result on PCMU or PCMA;
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
49
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
50 b) In the encoder direction, for the first 7 frames after EHF, before DTX is
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
51 allowed to kick in, we can get GSM DL output from the network that matches
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
52 our expectations.
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
53
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
54 Encoder 5 ms delay and DHF transformation
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
55 =========================================
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
56
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
57 One of the diffs between classic EFR and MR122 in the encoder direction is the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
58 artificial delay of 5 ms introduced in the AMR version. In true multirate
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
59 operation this delay is needed to support seamless switching between codec
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
60 modes, but when the only allowed codec rate is 12k2 (which is the case with EFR
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
61 by definition), this delay is pure waste. (Needless to say, an extra delay of
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
62 5 ms is nothing compared to the egregious latencies introduced by today's ugly
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
63 and horrible world of IP-based transport everywhere, but still...) This
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
64 artificial 5 ms delay in the encoder is the reason for the DHF difference
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
65 between EFR and MR122 - but here is the wild part: instead of recognizing this
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
66 artificial delay as unnecessary and wasteful for 12k2-only EFR and removing it
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
67 from the AMR-EFR hybrid contraption, those commercial transcoder vendors and
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
68 the people who prepared amr122_efr.zip for ETSI/3GPP (were they the same
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
69 people?) kept this 5 ms encoder delay, keeping the whole encoder unchanged AMR
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
70 except for whatever insane trickery they did to fit EFR DTX logic and EFR SID
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
71 generation into it, but added special DHF transformation logic on the output of
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
72 this AMR encoder to produce compliant EFR DHF when the input is EHF.
136
8eb0e7a39409 doc: document command line utilities
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
73
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
74 Exactly how this DHF transformation is done in those actually-deployed AMR-EFR
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
75 hybrid encoders is a bit of a mystery. My first thought was to compare the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
76 speech parameters emitted by the AMR encoder against MR122 DHF, and if the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
77 result is a match, replace that MR122-DHF parameter set with EFR DHF. This
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
78 approach is implemented in the simple amr_dhf_subst_efr() function in libtwamr.
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
79 One distinctive signature of this approach is that the output of a hybrid
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
80 encoder following this method can never equal MR122 DHF: this one particular
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
81 bit pattern is precluded from the set of possible outputs under all conditions.
457
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
82
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
83 However, subsequent experiments quickly revealed that the logic implemented by
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
84 the transcoder in the network of T-Mobile USA must be different. One of the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
85 counter-intuitive effects of the 5 ms artificial delay in the MR122 encoder is
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
86 what happens when the encoder is in its homed state and you feed it an input
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
87 frame whose first 120 samples are all 0x0008, but some (as few as one or as many
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
88 as all) of the last 40 samples are different. This frame does not meet the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
89 definition of EHF and won't be recognized as such - the encoder won't get
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
90 rehomed once again after processing this frame - yet the output will be
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
91 bit-exact MR122 DHF. How do those AMR-EFR hybrid encoders handle *this* case?
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
92
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
93 Experiments on T-Mobile reveal that in the case in question, the encoded frame
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
94 is emitted with the bit pattern of MR122 DHF, *not* transformed into EFR DHF.
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
95 Because MR122-DHF output is impossible with an encoder that implements logic
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
96 like our amr_dhf_subst_efr() first cut, we know (by modus tollens) that
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
97 T-Mobile's implementation uses some different logic.
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
98
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
99 Our new (current) working model is implemented in amr_dhf_subst_efr2(): we
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
100 replace the output of the AMR encoder with EFR DHF if the raw encoder output
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
101 was MR122 DHF *and* the input frame was EHF. This version appears to match
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
102 the observed behavior of T-Mobile USA so far.
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
103
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
104 EFR DHF in the decoder direction
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
105 ================================
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
106
467
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
107 The way decoder homing works in all ETSI/3GPP-defined speech codecs, there is
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
108 an explicit check against known DHF bit pattern (up to first subframe only) at
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
109 the beginning of the decoder (if the decoder is homed and the input is DHF per
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
110 this reduced check, artificially emit EHF, stay homed and do nothing more), and
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
111 a second similar check against the known DHF bit pattern (full frame comparison
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
112 this time) at the end of the decoder, triggering the state reset function on
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
113 match. These checks are (and can only be) implemented by explicit comparison
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
114 against a known hard-coded DHF pattern - hence it doesn't matter in the decoder
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
115 case whether the DHF is natural (as in all properly ETSI-defined codecs) or
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
116 artificial as in AMR-EFR hybrid. Thus the "correct" handling of DHF in the
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
117 AMR-EFR hybrid decoder is a matter of replacing the check against MR122 DHF bit
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
118 pattern with a check against the different bit pattern of EFR DHF.
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
119
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
120 The decoder engine in libtwamr supports this different-DHF option for MR122
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
121 decoding by way of a bit set in the mode field in struct amr_param_frame - see
ad032051166a doc: AMR-EFR-hybrid-emu new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 457
diff changeset
122 the detailed description in AMR-library-API article.
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
123
457
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
124 Command line utilities for AMR-EFR hybrid
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
125 =========================================
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
126
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
127 The present package includes a small set of command line utilities that work
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
128 with the AMR-EFR hybrid described above:
311
83408f67a96c doc/AMR-EFR-philosophy: new article
Mychaela Falconia <falcon@freecalypso.org>
parents: 136
diff changeset
129
457
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
130 amrefr-encode-r
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
131 amrefr-decode-r
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
132
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
133 These two utilities function just like gsmefr-encode-r and
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
134 gsmefr-decode-r described in Codec-utils article, but implement the
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
135 AMR-EFR hybrid version of the codec instead of original EFR. The
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
136 no-DTX limitation applies: amrefr-encode-r lacks -d option, and the
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
137 input to amrefr-decode-r must not contain any SID frames.
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
138
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
139 amrefr-tseq-enc
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
140 amrefr-tseq-dec
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
141
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
142 These two utilities are AMR-EFR counterparts to gsmefr-etsi-enc and
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
143 gsmefr-etsi-dec test programs described in EFR-testing article. They
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
144 pass all tests on the non-DTX t??_efr.* sequences in ETSI's
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
145 amr122_efr.zip, but not on any of the DTX sequences included in the
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
146 same ZIP. Just like amrefr-encode-r, amrefr-tseq-enc lacks -d option,
9bcf65088006 doc/AMR-EFR-philosophy: document implemented solution
Mychaela Falconia <falcon@freecalypso.org>
parents: 311
diff changeset
147 and amrefr-tseq-dec rejects input containing SID frames.