00001 #include "sr_lpc10.h"
00002
00003
00004
00005 static INT G_enctab[16] = {
00006 0, 7, 11, 12, 13, 10, 6, 1, 14, 9, 5, 2, 3, 4, 8, 15
00007 };
00008
00009 static INT G_entau[60] = {
00010 19, 11, 27, 25, 29, 21, 23, 22, 30, 14, 15, 7, 39,
00011 38, 46, 42, 43, 41, 45, 37, 53, 49, 51, 50, 54, 52,
00012 60, 56, 58, 26, 90, 88, 92, 84, 86, 82, 83, 81, 85,
00013 69, 77, 73, 75, 74, 78, 70, 71, 67, 99, 97, 113, 112,
00014 114, 98, 106, 104, 108, 100, 101, 76
00015 };
00016
00017 static INDEX g_isync;
00018
00019
00020
00021
00022
00023 VOID encode_2400( INDEX itab[13] )
00024 {
00025 if (ITAB13_IVOICE==3)
00026 ITAB13_IPITCH = G_entau[ITAB13_IPITCH];
00027 else if (!ITAB13_IVOICE)
00028 ITAB13_IPITCH = 0;
00029 else
00030 ITAB13_IPITCH = 127;
00031
00032
00033
00034
00035
00036
00037 if (!(ITAB13_IPITCH) || (ITAB13_IPITCH == 127)) {
00038 ITAB13_IRC(4) = G_enctab[(ITAB13_IRC(0) & 30) >> 1];
00039 ITAB13_IRC(5) = G_enctab[(ITAB13_IRC(1) & 30) >> 1];
00040 ITAB13_IRC(6) = G_enctab[(ITAB13_IRC(2) & 30) >> 1];
00041 ITAB13_IRC(7) = G_enctab[(ITAB13_IRMS & 30) >> 1];
00042 ITAB13_IRC(8) = G_enctab[(ITAB13_IRC(3) & 30) >> 1] >> 1;
00043 ITAB13_IRC(9) = G_enctab[(ITAB13_IRC(3) & 30) >> 1] & 1;
00044 }
00045 }
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074 VOID chan_write_2400_i( INDEX itab[12], INDEX ibits[54])
00075 {
00076 INDEX i;
00077
00078
00079 for (i = 0; i < 53; i++) {
00080 ibits[i] = itab[G_iblist[i]] & 1;
00081 itab[G_iblist[i]] >>= 1;
00082 }
00083 ibits[53] = g_isync;
00084 g_isync ^= 1;
00085 }
00086
00087
00088
00089 VOID send_2400_ini( VOID )
00090 {
00091 g_isync = 0;
00092 }
00093
00094
00095
00096 VOID send_2400_i( BOOL voice[2], INDEX pitch,
00097 FLOAT rms, FLOAT rc[ORDER], INDEX ibits[54] )
00098 {
00099 INDEX itab[13];
00100
00101 quant(voice, pitch, rms, rc, itab);
00102
00103 encode_2400(itab);
00104
00105 chan_write_2400_i(itab, ibits);
00106 }
00107
00108