File: preprocess.c

package info (click to toggle)
mgetty 1.2.1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,880 kB
  • sloc: ansic: 42,728; sh: 6,487; perl: 6,262; makefile: 1,457; tcl: 756; lisp: 283
file content (113 lines) | stat: -rw-r--r-- 2,882 bytes parent folder | download | duplicates (14)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*
 * Copyright 1992 by Jutta Degener and Carsten Bormann, Technische
 * Universitaet Berlin.  See the accompanying file "COPYRIGHT" for
 * details.  THERE IS ABSOLUTELY NO WARRANTY FOR THIS SOFTWARE.
 */

/* $Id: preprocess.c,v 1.4 1998/09/09 21:06:51 gert Exp $ */

#include  <stdio.h>
#include  <assert.h>

#include "private.h"

#include  "gsm.h"
#include  "proto.h"

/*   4.2.0 .. 4.2.3 PREPROCESSING SECTION
 *
 *   After A-law to linear conversion (or directly from the
 *        Ato D converter) the following scaling is assumed for
 *   input to the RPE-LTP algorithm:
 *
 *      in:  0.1.....................12
 *        S.v.v.v.v.v.v.v.v.v.v.v.v.*.*.*
 *
 *   Where S is the sign bit, v a valid bit, and * a "don't care" bit.
 *   The original signal is called sop[..]
 *
 *      out:   0.1................... 12
 *        S.S.v.v.v.v.v.v.v.v.v.v.v.v.0.0
 */


void Gsm_Preprocess P3((S, s, so),
     struct gsm_state * S,
     word       * s,
     word            * so )        /* [0..159]    IN/OUT    */
{

     word       z1 = S->z1;
     longword L_z2 = S->L_z2;
     word         mp = S->mp;

     word           s1;
     longword      L_s2;

     longword      L_temp;

     word      msp, lsp;
     word      SO;

     longword  ltmp;          /* for   ADD */
     ulongword utmp;          /* for L_ADD */

     register int        k = 160;

     while (k--) {

     /*  4.2.1   Downscaling of the input signal
      */
          SO = SASR( *s, 3 ) << 2;
          s++;

          assert (SO >= -0x4000);  /* downscaled by     */
          assert (SO <=  0x3FFC);  /* previous routine. */


     /*  4.2.2   Offset compensation
      *
      *  This part implements a high-pass filter and requires extended
      *  arithmetic precision for the recursive part of this filter.
      *  The input of this procedure is the array so[0...159] and the
      *  output the array sof[ 0...159 ].
      */
          /*   Compute the non-recursive part
           */

          s1 = SO - z1;            /* s1 = gsm_sub( *so, z1 ); */
          z1 = SO;

          assert(s1 != MIN_WORD);

          /*   Compute the recursive part
           */
          L_s2 = s1;
          L_s2 <<= 15;

          /*   Execution of a 31 bv 16 bits multiplication
           */

          msp = SASR( L_z2, 15 );
          lsp = L_z2-((longword)msp<<15); /* gsm_L_sub(L_z2,(msp<<15)); */

          L_s2  += GSM_MULT_R( lsp, 32735 );
          L_temp = (longword)msp * 32735; /* GSM_L_MULT(msp,32735) >> 1;*/
          L_z2   = GSM_L_ADD( L_temp, L_s2 );

          /*    Compute sof[k] with rounding
           */
          L_temp = GSM_L_ADD( L_z2, 16384 );

     /*   4.2.3  Preemphasis
      */

          msp   = GSM_MULT_R( mp, -28180 );
          mp    = SASR( L_temp, 15 );
          *so++ = GSM_ADD( mp, msp );
     }

     S->z1   = z1;
     S->L_z2 = L_z2;
     S->mp   = mp;
}