Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

232 lines
9.8 KiB

/*
* Project: Direct Subband about 13000 bps coder and SBCELP 4800 bps coder
* Workfile: data.c
* Author: Georges Zanellato, Alfred Wiesen
* Created: 30 August 1995
* Last update: 26 October 1995
* DLL Version: 1.00
* Revision: Single DLL for coder and decoder.
* Comment:
*
* (C) Copyright 1993-95 Lernout & Hauspie Speech Products N.V. (TM)
* All rights reserved. Company confidential.
*/
//#include <math.h>
#include <windows.h>
#include "data.h"
// ------------------------------------------------------------------------
// ROM tables :
// ------------------------------------------------------------------------
short coef_I[Fil_Lenght] = // QMF filter coefficients
{ 94, -62, -528, 3499,
15641, -3122, 1178, -326 };
/****/
short B3_I[2]={-3072, 3072};
short B4_I[3]={-4233, 0, 4233};
short B5_I[4]={-4915,-1638, 1638, 4915};
short B6_I[5]={-5406,-2703, 0, 2703, 5406};
short B7_I[6]={-5802,-3481,-1160, 1160, 3481, 5802};
short B8_I[7]={-6144,-4096,-2048, 0, 2048, 4096, 6144};
short B9_I[8]={-6451,-4607,-2764, -921, 921, 2764, 4607, 6451};
short V3_I[3]={-6144, 0, 6144}; // 75 %
short V4_I[4]={-6349,-2116, 2116, 6349}; // 77.5 %
short V5_I[5]={-6554,-3277, 0, 3277, 6554}; // 80 %
short V6_I[6]={-6758,-4055,-1352, 1352, 4055, 6758}; // 82.5 %
short V7_I[7]={-6963,-4642,-2321, 0, 2321, 4642, 6963}; // 85 %
short V8_I[8]={-7168,-5120,-3072,-1024, 1024, 3072, 5120, 7168}; // 87.5 %
short V9_I[9]={-7373,-5529,-3686,-1843, 0, 1843, 3686, 5529, 7373};// 90 %
/**** Nouvelles tables ****/
//short B9_I[8]={-6707,-4791,-2874, -958, 958, 2874, 4791, 6707}; //lineaires
//short V9_I[9]={-7666,-5749,-3833,-1916, 0, 1916, 3833, 5749, 7666};
//short B9_I[8]={-5702,-3154,-1745, -965, 965, 1745, 3154, 5702}; //log
//short V9_I[9]={-7666,-4241,-2346,-1298, 0, 1298, 2346, 4241, 7666};
/****/
/**** Quantif du maximum des ss bandes avec calcul des distances; ****/
/**** les ech. des ss bandes peuvent etre superieurs a 1 ****/
/****/
short max_level[32] = {
10, 30, 60, 100, 117, 138, 162, 190,
223, 262, 308, 361, 425, 499, 586, 688,
808, 949, 1114, 1308, 1536, 1804, 2119, 2488,
2922, 3431, 4030, 4732, 5557, 6526, 7664, 9000
};
short d_max_level[32] = { // Division des petites valeurs pour r‚duire le bruit
2, 10, 30, 60, 100, 138, 162, 190,
223, 262, 308, 361, 425, 499, 586, 688,
808, 949, 1114, 1308, 1536, 1804, 2119, 2488,
2922, 3431, 4030, 4732, 5557, 6526, 7664, 9000
};
/****/
/**** Cette table est la meme que la precedente mais avec comparaison ****/
/**** simple (les ech des ss bandes seront alors tjs inferieurs a 1) ****/
/****
short max_level[32] = { // Quantified maximum sample level
20, 45, 80, 109, 128, 150, 176, 207,
243, 285, 335, 393, 462, 543, 637, 748,
879, 1032, 1211, 1422, 1670, 1962, 2304, 2705,
3177, 3731, 4381, 5145, 6042, 7095, 8332,16000
};
/****/
/*** New table with new structure (variable threshold) ***
short max_level[32] = {
100, 125, 150, 200, 250, 285, 326, 372,
425, 485, 554, 633, 723, 825, 943, 1076,
1229, 1404, 1603, 1830, 2090, 2387, 2726, 3113,
3554, 4059, 4635, 5293, 6044, 6902, 7881, 9000,
};
/****/
// Masques utilis‚s pour le multiplexage et d‚multiplexage des trames cod‚es
// Mask[i] donne accŠs aux i bits de poids faible d'un long
long Mask[9]={0,1,3,7,15,31,63,127,255};
// PhilF: Since these depend on the bit rate, moved them from global to instance data...
//short quantif[2*NBSB_SP_MAX1]={QUANT_LEVELS};
//short bits[NBSB_SP_MAX1]={CODING_BITS};
//short bytes[NBSB_SP_MAX1+1]={OUTPUT_BYTES};
/*short quantif[16]={9,9,7,7,7,6,5,5,5,5,0,0,0,0,0,0};
short bits[8]={52,46,44,38,38,0,0,0};
short bytes[9]={1,9,15,21,26,32,0,0,0};*/
// Hamming window
short hamming[220] =
{ 2621, 2628, 2646, 2677, 2721, 2776, 2844, 2924, 3017, 3121,
3237, 3366, 3506, 3658, 3821, 3996, 4182, 4379, 4587, 4806,
5035, 5275, 5525, 5786, 6056, 6335, 6624, 6922, 7229, 7544,
7868, 8200, 8540, 8887, 9242, 9603, 9971, 10346, 10726, 11113,
11504, 11901, 12303, 12709, 13119, 13533, 13950, 14370, 14793, 15219,
15646, 16076, 16506, 16938, 17370, 17802, 18235, 18667, 19098, 19528,
19956, 20382, 20807, 21229, 21648, 22063, 22475, 22883, 23287, 23686,
24081, 24470, 24853, 25231, 25602, 25967, 26325, 26676, 27019, 27355,
27683, 28003, 28314, 28616, 28910, 29194, 29469, 29734, 29989, 30234,
30469, 30693, 30907, 31109, 31301, 31481, 31650, 31808, 31954, 32088,
32211, 32321, 32419, 32506, 32580, 32642, 32691, 32728, 32753, 32765,
32765, 32753, 32728, 32691, 32642, 32580, 32506, 32419, 32321, 32211,
32088, 31954, 31808, 31650, 31481, 31301, 31109, 30907, 30693, 30469,
30234, 29989, 29734, 29469, 29194, 28910, 28616, 28314, 28003, 27683,
27355, 27019, 26676, 26325, 25967, 25602, 25231, 24853, 24470, 24081,
23686, 23287, 22883, 22475, 22063, 21648, 21229, 20807, 20382, 19956,
19528, 19098, 18667, 18235, 17802, 17370, 16938, 16506, 16076, 15646,
15219, 14793, 14370, 13950, 13533, 13119, 12709, 12303, 11901, 11504,
11113, 10726, 10346, 9971, 9603, 9242, 8887, 8540, 8200, 7868,
7544, 7229, 6922, 6624, 6335, 6056, 5786, 5525, 5275, 5035,
4806, 4587, 4379, 4182, 3996, 3821, 3658, 3506, 3366, 3237,
3121, 3017, 2924, 2844, 2776, 2721, 2677, 2646, 2628, 2621
};
short A0[11] = { 32767, 29491, 26542, 23887, 21499, 19349, 17414, 15672, 14105, 12694, 11425};
short LSP0ROM[10] = {1638, 4915, 8192, 11468, 14745, 18022, 21299, 24576, 27852, 31129};
short tabcos[292] =
{ 32767, 32512, 32256, 32000, 31744, 31488, 31232, 30976, 30720, 30464,
30208, 29952, 29696, 29440, 29184, 28928, 28672, 28416, 28160, 27904,
27648, 27392, 27136, 26880, 26624, 26368, 26112, 25856, 25600, 25344,
25088, 24832, 24576, 24320, 24064, 23808, 23552, 23296, 23040, 22784,
22528, 22272, 22016, 21760, 21504, 21248, 20992, 20736, 20480, 20224,
19968, 19712, 19456, 19200, 18944, 18688, 18432, 18176, 17920, 17664,
17408, 17152, 16896, 16640, 16384, 16128, 15872, 15616, 15360, 15104,
14848, 14592, 14336, 14080, 13824, 13568, 13312, 13056, 12800, 12544,
12288, 12032, 11776, 11520, 11264, 11008, 10752, 10496, 10240, 9984,
9728, 9472, 9216, 8960, 8704, 8448, 8192, 7936, 7680, 7424,
7168, 6912, 6656, 6400, 6144, 5888, 5632, 5376, 5120, 4864,
4608, 4352, 4096, 3840, 3584, 3328, 3072, 2816, 2560, 2304,
2048, 1792, 1536, 1280, 1024, 768, 512, 256, 0, 0,
1304, 1846, 2262, 2614, 2924, 3206, 3465, 3707, 3934, 4150,
4355, 4552, 4741, 4923, 5100, 5271, 5437, 5598, 5755, 5909,
6059, 6206, 6350, 6491, 6630, 6766, 6899, 7031, 7160, 7288,
7414, 7538, 7660, 7781, 7900, 8018, 8135, 8250, 8364, 8477,
8589, 8699, 8809, 8917, 9025, 9131, 9237, 9342, 9446, 9549,
9651, 9753, 9854, 9954, 10053, 10152, 10251, 10348, 10445, 10542,
10638, 10733, 10828, 10922, 11016, 11109, 11202, 11295, 11387, 11478,
11570, 11660, 11751, 11841, 11931, 12020, 12109, 12198, 12286, 12374,
12462, 12549, 12637, 12723, 12810, 12896, 12983, 13068, 13154, 13240,
13325, 13410, 13495, 13579, 13664, 13748, 13832, 13916, 14000, 14083,
14167, 14250, 14333, 14416, 14499, 14582, 14665, 14747, 14830, 14912,
14994, 15076, 15158, 15240, 15322, 15404, 15486, 15568, 15650, 15731,
15813, 15894, 15976, 16058, 16139, 16221, 16302, 16384, 32767, 32735,
32703, 32671, 32639, 32607, 32575, 32543, 32511, 32479, 32447, 32415,
32383, 32351, 32319, 32287, 32255, 8, 461, 652, 798, 922,
1031, 1129, 1220, 1304, 1383, 1458, 1530, 1598, 1663, 1726,
1787, 1846 };
// First table for LSP quantification
short LSP_Q[56] =
{ 819, 1392, 1843, 2048, 2293, 2785, 3440, 4096, 3440, 3768,
4096, 4423, 4792, 5242, 5775, 6348, 6963, 7782, 8601, 9420,
10240, 11059, 11878, 12697, 8192, 8601, 9256, 9912, 10526, 11059,
11714, 12369, 13025, 13680, 14336, 15155, 15974, 16793, 17612, 18432,
14745, 15400, 16056, 17203, 18841, 20316, 22118, 23756, 22609, 23592,
24576, 25395, 26214, 27115, 28098, 29081
};
short TAB_DI[38] =
{ 1604, 3522, 5816, 8559, 11839, 15761, 20451, 26060, 32767,
1825, 4057, 6787, 10125, 14207, 19199, 25303,
3110, 7402, 13324, 21494, 32767,
4057, 10125, 19199,
3110, 7402, 13324, 21494, 32767,
4057, 10125, 19199, 5816, 15761, 32767,
10125, 10125, 32767
};
short GQ[17] = { 0, 37, 81, 132, 194, 266, 352, 454, 575,
717, 887, 1087, 1324, 1606, 1939, 2333, 2800 };
short GV[17] = { 0, 9, 58, 105, 162, 228, 307, 401, 512,
643, 798, 983, 1201, 1459, 1765, 2127, 2557 };
short BQ[11] = { 0, 328, 757, 1320, 2058, 3026, 4295, 5958,
8139, 10998, 14746 };
short BV[11] = { 0, 153, 528, 1020, 1664, 2509, 3617, 5070,
6975, 9471, 12745 };
short NBB[25] = {8,16,16,8,8,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0};
short BITDD[5] = {9,5,5,3,2};
long coef_i[9] = { -626684736, 7274874, 1238819712, 7274874, -626684736,
-4058, -23341, 1585, 10127 };
// } ROM TABLES
// -------------------------------------------------------------------------
// RAM variables :
// -------------------------------------------------------------------------
// All in data structures.
// ------------------------------------------------------------------------
void InitializeROM(void)
// Global initializations of ROM tables : should only be called once
{
// All data hardcoded. no initialization needed.
return;
}