libavcodec/amrwbdata.h
Go to the documentation of this file.
00001 /*
00002  * AMR wideband data and definitions
00003  * Copyright (c) 2010 Marcelo Galvao Povoa
00004  *
00005  * This file is part of FFmpeg.
00006  *
00007  * FFmpeg is free software; you can redistribute it and/or
00008  * modify it under the terms of the GNU Lesser General Public
00009  * License as published by the Free Software Foundation; either
00010  * version 2.1 of the License, or (at your option) any later version.
00011  *
00012  * FFmpeg is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015  * Lesser General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU Lesser General Public
00018  * License along with FFmpeg; if not, write to the Free Software
00019  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
00020  */
00021 
00027 #ifndef AVCODEC_AMRWBDATA_H
00028 #define AVCODEC_AMRWBDATA_H
00029 
00030 #include <stdint.h>
00031 #include <stddef.h>
00032 
00033 #define LP_ORDER            16                ///< linear predictive coding filter order
00034 #define LP_ORDER_16k        20                ///< lpc filter order at 16kHz
00035 #define HB_FIR_SIZE         30                ///< amount of past data needed by HB filters
00036 #define UPS_FIR_SIZE        12                ///< upsampling filter size
00037 #define UPS_MEM_SIZE        (2 * UPS_FIR_SIZE)
00038 
00039 #define MIN_ISF_SPACING     (128.0 / 32768.0) ///< minimum isf gap
00040 #define PRED_FACTOR         (1.0 / 3.0)
00041 #define MIN_ENERGY         -14.0              ///< initial innnovation energy (dB)
00042 #define ENERGY_MEAN         30.0              ///< mean innovation energy (dB) in all modes
00043 #define PREEMPH_FAC         0.68              ///< factor used to de-emphasize synthesis
00044 
00045 #define AMRWB_SFR_SIZE      64                ///< samples per subframe at 12.8 kHz
00046 #define AMRWB_SFR_SIZE_16k  80                ///< samples per subframe at 16 kHz
00047 #define AMRWB_P_DELAY_MAX   231               ///< maximum pitch delay value
00048 #define AMRWB_P_DELAY_MIN   34
00049 
00050 /* Relative mode ordering is sensitive */
00051 enum Mode {
00052     MODE_6k60 = 0,                         
00053     MODE_8k85,                             
00054     MODE_12k65,                            
00055     MODE_14k25,                            
00056     MODE_15k85,                            
00057     MODE_18k25,                            
00058     MODE_19k85,                            
00059     MODE_23k05,                            
00060     MODE_23k85,                            
00061     MODE_SID,                              
00062     /* 10-13:  Future use */
00063     SP_LOST = 14,                          
00064     NO_DATA                                
00065 };
00066 
00067 /* All decoded parameters in these structs must be 2 bytes long
00068  * because of the direct indexing at the frame parsing */
00069 typedef struct {
00070     uint16_t adap;                         
00071     uint16_t ltp;                          
00072     uint16_t vq_gain;                      
00073     uint16_t hb_gain;                      
00074     uint16_t pul_ih[4];                    
00075     uint16_t pul_il[4];                    
00076 } AMRWBSubFrame;
00077 
00078 typedef struct {
00079     uint16_t vad;                          
00080     uint16_t isp_id[7];                    
00081     AMRWBSubFrame subframe[4];             
00082 } AMRWBFrame;
00083 
00085 #define AMR_BIT(field)                  (offsetof(AMRWBFrame, field) >> 1)
00086 
00087 #define AMR_OF(frame_num, variable)     AMR_BIT(subframe[frame_num].variable)
00088 
00089 //As defined in 3GPP TS 26.201 V9.0.0
00090 //Tables for bit parsing in Core Frame speech frames
00091 //The reordered bits are in order of decreasing importance and
00092 //may be contiguously separated in Class A, B and C bits.
00093 
00094 // Each field in AMRWBFrame is stored as:
00095 // * one byte for the number of bits in the field
00096 // * one byte for the field index
00097 // * then, one byte for each bit of the field (from most-significant to least)
00098 //         of the position of that bit in the AMR frame.
00099 static const uint16_t order_MODE_6k60[] = {
00100      1,         AMR_BIT(vad),   7,
00101      8,   AMR_BIT(isp_id[0]),  24,  33,  39,  12,   6,   5,   4,  13,
00102      8,   AMR_BIT(isp_id[1]),  65,  79,  64,  78,  51,  61,  71,  70,
00103      7,   AMR_BIT(isp_id[2]),  52,  55,  44,  54,  53,  43,  42,
00104      7,   AMR_BIT(isp_id[3]),  60,  59,  58,  57,  56,  75,  74,
00105      6,   AMR_BIT(isp_id[4]),  73,  72,  86,  87,  85,  84,
00106      8,      AMR_OF(0, adap),  11,  10,   9,   8,  28,  27,  49,  69,
00107      6, AMR_OF(0, pul_il[0]),  83,  91,  99, 107, 115, 123,
00108      6, AMR_OF(0, pul_il[1]),  82, 103, 111, 119, 127, 135,
00109      6,   AMR_OF(0, vq_gain),  38,  23,  34,  19,   3,  15,
00110      5,      AMR_OF(1, adap),  32,  41,  63,  67,  77,
00111      6, AMR_OF(1, pul_il[0]),  81,  90,  98, 106, 114, 122,
00112      6, AMR_OF(1, pul_il[1]),  80, 102, 110, 118, 126, 134,
00113      6,   AMR_OF(1, vq_gain),  26,  22,  36,  18,   2,  14,
00114      5,      AMR_OF(2, adap),  45,  40,  50,  48,  68,
00115      6, AMR_OF(2, pul_il[0]),  95,  89,  97, 105, 113, 121,
00116      6, AMR_OF(2, pul_il[1]),  94, 101, 109, 117, 125, 133,
00117      6,   AMR_OF(2, vq_gain),  37,  21,  35,  17,   1,  31,
00118      5,      AMR_OF(3, adap),  47,  46,  62,  66,  76,
00119      6, AMR_OF(3, pul_il[0]),  93,  88,  96, 104, 112, 120,
00120      6, AMR_OF(3, pul_il[1]),  92, 100, 108, 116, 124, 132,
00121      6,   AMR_OF(3, vq_gain),  25,  20,  29,  16,   0,  30,
00122      0
00123 };
00124 
00125 static const uint16_t order_MODE_8k85[] = {
00126      1,         AMR_BIT(vad),   7,
00127      8,   AMR_BIT(isp_id[0]),  47,  32,   2,   6,   3,   5,   4,  60,
00128      8,   AMR_BIT(isp_id[1]),  69,  50,  67,  41,  51,  49,  59,  53,
00129      6,   AMR_BIT(isp_id[2]),  40,  55,  43,  54,  42,  62,
00130      7,   AMR_BIT(isp_id[3]),  63,  48,  52,  61,  77,  78,  72,
00131      7,   AMR_BIT(isp_id[4]),  85,  56,  86,  68,  74,  73,  81,
00132      5,   AMR_BIT(isp_id[5]),  82,  95,  80,  94,  91,
00133      5,   AMR_BIT(isp_id[6]),  90,  89,  88, 103,  87,
00134      8,      AMR_OF(0, adap),   1,   0,  15,  35,  33,  58,  64,  84,
00135      5, AMR_OF(0, pul_il[0]), 102, 118, 134, 150, 166,
00136      5, AMR_OF(0, pul_il[1]), 101, 114, 130, 146, 162,
00137      5, AMR_OF(0, pul_il[2]), 100, 126, 142, 158, 174,
00138      5, AMR_OF(0, pul_il[3]),  99, 122, 138, 154, 170,
00139      6,   AMR_OF(0, vq_gain),  11,  39,  19,  31,  27,  23,
00140      5,      AMR_OF(1, adap),  46,  71,  66,  76,  93,
00141      5, AMR_OF(1, pul_il[0]),  98, 117, 133, 149, 165,
00142      5, AMR_OF(1, pul_il[1]),  97, 113, 129, 145, 161,
00143      5, AMR_OF(1, pul_il[2]),  96, 125, 141, 157, 173,
00144      5, AMR_OF(1, pul_il[3]), 111, 121, 137, 153, 169,
00145      6,   AMR_OF(1, vq_gain),  10,  38,  18,  30,  26,  22,
00146      8,      AMR_OF(2, adap),  14,  13,  12,  34,  45,  57,  79,  83,
00147      5, AMR_OF(2, pul_il[0]), 110, 116, 132, 148, 164,
00148      5, AMR_OF(2, pul_il[1]), 109, 112, 128, 144, 160,
00149      5, AMR_OF(2, pul_il[2]), 108, 124, 140, 156, 172,
00150      5, AMR_OF(2, pul_il[3]), 107, 120, 136, 152, 168,
00151      6,   AMR_OF(2, vq_gain),   9,  37,  17,  29,  25,  21,
00152      5,      AMR_OF(3, adap),  44,  70,  65,  75,  92,
00153      5, AMR_OF(3, pul_il[0]), 106, 115, 131, 147, 163,
00154      5, AMR_OF(3, pul_il[1]), 105, 127, 143, 159, 175,
00155      5, AMR_OF(3, pul_il[2]), 104, 123, 139, 155, 171,
00156      5, AMR_OF(3, pul_il[3]), 119, 135, 151, 167, 183,
00157      6,   AMR_OF(3, vq_gain),   8,  36,  16,  28,  24,  20,
00158      0
00159 };
00160 
00161 static const uint16_t order_MODE_12k65[] = {
00162      1,         AMR_BIT(vad),   7,
00163      8,   AMR_BIT(isp_id[0]),  55,  40,  14,   6,  15,   5,   0,  68,
00164      8,   AMR_BIT(isp_id[1]),  77,  58,  75,  49,  59,  57,  67,  61,
00165      6,   AMR_BIT(isp_id[2]),  48,  63,  51,  62,  50,  70,
00166      7,   AMR_BIT(isp_id[3]),  71,  56,  60,  69,  85,  86,  80,
00167      7,   AMR_BIT(isp_id[4]),  93,  64,  94,  76,  82,  81,  89,
00168      5,   AMR_BIT(isp_id[5]),  90, 103,  88, 102,  99,
00169      5,   AMR_BIT(isp_id[6]),  98,  97,  96, 111,  95,
00170      9,      AMR_OF(0, adap),  13,  12,  11,  10,   9,  41,  66,  72,
00171                                92,
00172      1,       AMR_OF(0, ltp), 110,
00173      9, AMR_OF(0, pul_il[0]), 106, 122, 154, 186, 218, 134, 166, 198,
00174                               230,
00175      9, AMR_OF(0, pul_il[1]), 105, 130, 162, 194, 226, 142, 174, 206,
00176                               238,
00177      9, AMR_OF(0, pul_il[2]), 104, 138, 170, 202, 234, 150, 182, 214,
00178                               246,
00179      9, AMR_OF(0, pul_il[3]), 119, 146, 178, 210, 242, 158, 190, 222,
00180                               254,
00181      7,   AMR_OF(0, vq_gain),   4,  19,  45,  27,  39,  33,  31,
00182      6,      AMR_OF(1, adap),  35,  54,  79,  74,  84, 101,
00183      1,       AMR_OF(1, ltp), 109,
00184      9, AMR_OF(1, pul_il[0]), 118, 121, 153, 185, 217, 133, 165, 197,
00185                               229,
00186      9, AMR_OF(1, pul_il[1]), 117, 129, 161, 193, 225, 141, 173, 205,
00187                               237,
00188      9, AMR_OF(1, pul_il[2]), 116, 137, 169, 201, 233, 149, 181, 213,
00189                               245,
00190      9, AMR_OF(1, pul_il[3]), 115, 145, 177, 209, 241, 157, 189, 221,
00191                               253,
00192      7,   AMR_OF(1, vq_gain),   3,  18,  44,  26,  38,  32,  30,
00193      9,      AMR_OF(2, adap),   8,  23,  22,  21,  20,  52,  65,  87,
00194                                91,
00195      1,       AMR_OF(2, ltp), 108,
00196      9, AMR_OF(2, pul_il[0]), 114, 120, 152, 184, 216, 132, 164, 196,
00197                               228,
00198      9, AMR_OF(2, pul_il[1]), 113, 128, 160, 192, 224, 140, 172, 204,
00199                               236,
00200      9, AMR_OF(2, pul_il[2]), 112, 136, 168, 200, 232, 148, 180, 212,
00201                               244,
00202      9, AMR_OF(2, pul_il[3]), 127, 144, 176, 208, 240, 156, 188, 220,
00203                               252,
00204      7,   AMR_OF(2, vq_gain),   2,  17,  43,  25,  37,  47,  29,
00205      6,      AMR_OF(3, adap),  34,  53,  78,  73,  83, 100,
00206      1,       AMR_OF(3, ltp), 107,
00207      9, AMR_OF(3, pul_il[0]), 126, 135, 167, 199, 231, 131, 163, 195,
00208                               227,
00209      9, AMR_OF(3, pul_il[1]), 125, 143, 175, 207, 239, 139, 171, 203,
00210                               235,
00211      9, AMR_OF(3, pul_il[2]), 124, 151, 183, 215, 247, 147, 179, 211,
00212                               243,
00213      9, AMR_OF(3, pul_il[3]), 123, 159, 191, 223, 255, 155, 187, 219,
00214                               251,
00215      7,   AMR_OF(3, vq_gain),   1,  16,  42,  24,  36,  46,  28,
00216      0
00217 };
00218 
00219 static const uint16_t order_MODE_14k25[] = {
00220      1,         AMR_BIT(vad),   7,
00221      8,   AMR_BIT(isp_id[0]),  55,  40,  14,   6,  15,   5,   0,  68,
00222      8,   AMR_BIT(isp_id[1]),  77,  58,  75,  49,  59,  57,  67,  61,
00223      6,   AMR_BIT(isp_id[2]),  48,  63,  51,  62,  50,  70,
00224      7,   AMR_BIT(isp_id[3]),  71,  56,  60,  69,  85,  86,  80,
00225      7,   AMR_BIT(isp_id[4]),  93,  64,  94,  76,  82,  81,  89,
00226      5,   AMR_BIT(isp_id[5]),  90, 103,  88, 102,  99,
00227      5,   AMR_BIT(isp_id[6]),  98,  97,  96, 111,  95,
00228      9,      AMR_OF(0, adap),  13,  12,  11,  10,   9,  41,  66,  72,
00229                                92,
00230      1,       AMR_OF(0, ltp), 110,
00231     13, AMR_OF(0, pul_il[0]), 114, 186, 210, 234, 258, 106, 126, 162,
00232                               170, 198, 222, 246, 270,
00233     13, AMR_OF(0, pul_il[1]), 122, 194, 218, 242, 266, 118, 134, 174,
00234                               182, 206, 230, 254, 278,
00235      9, AMR_OF(0, pul_il[2]), 130, 138, 146, 154, 178, 202, 226, 250,
00236                               274,
00237      9, AMR_OF(0, pul_il[3]), 142, 150, 158, 166, 190, 214, 238, 262,
00238                               286,
00239      7,   AMR_OF(0, vq_gain),   4,  19,  45,  27,  39,  33,  31,
00240      6,      AMR_OF(1, adap),  35,  54,  79,  74,  84, 101,
00241      1,       AMR_OF(1, ltp), 109,
00242     13, AMR_OF(1, pul_il[0]), 113, 185, 209, 233, 257, 105, 125, 161,
00243                               169, 197, 221, 245, 269,
00244     13, AMR_OF(1, pul_il[1]), 121, 193, 217, 241, 265, 117, 133, 173,
00245                               181, 205, 229, 253, 277,
00246      9, AMR_OF(1, pul_il[2]), 129, 137, 145, 153, 177, 201, 225, 249,
00247                               273,
00248      9, AMR_OF(1, pul_il[3]), 141, 149, 157, 165, 189, 213, 237, 261,
00249                               285,
00250      7,   AMR_OF(1, vq_gain),   3,  18,  44,  26,  38,  32,  30,
00251      9,      AMR_OF(2, adap),   8,  23,  22,  21,  20,  52,  65,  87,
00252                                91,
00253      1,       AMR_OF(2, ltp), 108,
00254     13, AMR_OF(2, pul_il[0]), 112, 184, 208, 232, 256, 104, 124, 160,
00255                               168, 196, 220, 244, 268,
00256     13, AMR_OF(2, pul_il[1]), 120, 192, 216, 240, 264, 116, 132, 172,
00257                               180, 204, 228, 252, 276,
00258      9, AMR_OF(2, pul_il[2]), 128, 136, 144, 152, 176, 200, 224, 248,
00259                               272,
00260      9, AMR_OF(2, pul_il[3]), 140, 148, 156, 164, 188, 212, 236, 260,
00261                               284,
00262      7,   AMR_OF(2, vq_gain),   2,  17,  43,  25,  37,  47,  29,
00263      6,      AMR_OF(3, adap),  34,  53,  78,  73,  83, 100,
00264      1,       AMR_OF(3, ltp), 107,
00265     13, AMR_OF(3, pul_il[0]), 127, 199, 223, 247, 271, 119, 123, 175,
00266                               183, 195, 219, 243, 267,
00267     13, AMR_OF(3, pul_il[1]), 135, 207, 231, 255, 279, 115, 131, 171,
00268                               179, 203, 227, 251, 275,
00269      9, AMR_OF(3, pul_il[2]), 143, 151, 159, 167, 191, 215, 239, 263,
00270                               287,
00271      9, AMR_OF(3, pul_il[3]), 139, 147, 155, 163, 187, 211, 235, 259,
00272                               283,
00273      7,   AMR_OF(3, vq_gain),   1,  16,  42,  24,  36,  46,  28,
00274      0
00275 };
00276 
00277 static const uint16_t order_MODE_15k85[] = {
00278      1,         AMR_BIT(vad),   7,
00279      8,   AMR_BIT(isp_id[0]),  55,  40,  14,   6,  15,   5,   0,  68,
00280      8,   AMR_BIT(isp_id[1]),  77,  58,  75,  49,  59,  57,  67,  61,
00281      6,   AMR_BIT(isp_id[2]),  48,  63,  51,  62,  50,  70,
00282      7,   AMR_BIT(isp_id[3]),  71,  56,  60,  69,  85,  86,  80,
00283      7,   AMR_BIT(isp_id[4]),  93,  64,  94,  76,  82,  81,  89,
00284      5,   AMR_BIT(isp_id[5]),  90, 103,  88, 102,  99,
00285      5,   AMR_BIT(isp_id[6]),  98,  97,  96, 111,  95,
00286      9,      AMR_OF(0, adap),  13,  12,  11,  10,   9,  41,  66,  72,
00287                                92,
00288      1,       AMR_OF(0, ltp), 110,
00289     13, AMR_OF(0, pul_il[0]), 122, 154, 170, 218, 266, 138, 106, 182,
00290                               230, 278, 178, 226, 274,
00291     13, AMR_OF(0, pul_il[1]), 134, 166, 190, 238, 286, 150, 118, 186,
00292                               234, 282, 198, 246, 294,
00293     13, AMR_OF(0, pul_il[2]), 130, 162, 194, 242, 290, 146, 114, 206,
00294                               254, 302, 202, 250, 298,
00295     13, AMR_OF(0, pul_il[3]), 142, 174, 214, 262, 310, 158, 126, 210,
00296                               258, 306, 222, 270, 318,
00297      7,   AMR_OF(0, vq_gain),   4,  19,  45,  27,  39,  33,  31,
00298      6,      AMR_OF(1, adap),  35,  54,  79,  74,  84, 101,
00299      1,       AMR_OF(1, ltp), 109,
00300     13, AMR_OF(1, pul_il[0]), 121, 153, 169, 217, 265, 137, 105, 181,
00301                               229, 277, 177, 225, 273,
00302     13, AMR_OF(1, pul_il[1]), 133, 165, 189, 237, 285, 149, 117, 185,
00303                               233, 281, 197, 245, 293,
00304     13, AMR_OF(1, pul_il[2]), 129, 161, 193, 241, 289, 145, 113, 205,
00305                               253, 301, 201, 249, 297,
00306     13, AMR_OF(1, pul_il[3]), 141, 173, 213, 261, 309, 157, 125, 209,
00307                               257, 305, 221, 269, 317,
00308      7,   AMR_OF(1, vq_gain),   3,  18,  44,  26,  38,  32,  30,
00309      9,      AMR_OF(2, adap),   8,  23,  22,  21,  20,  52,  65,  87,
00310                                91,
00311      1,       AMR_OF(2, ltp), 108,
00312     13, AMR_OF(2, pul_il[0]), 120, 152, 168, 216, 264, 136, 104, 180,
00313                               228, 276, 176, 224, 272,
00314     13, AMR_OF(2, pul_il[1]), 132, 164, 188, 236, 284, 148, 116, 184,
00315                               232, 280, 196, 244, 292,
00316     13, AMR_OF(2, pul_il[2]), 128, 160, 192, 240, 288, 144, 112, 204,
00317                               252, 300, 200, 248, 296,
00318     13, AMR_OF(2, pul_il[3]), 140, 172, 212, 260, 308, 156, 124, 208,
00319                               256, 304, 220, 268, 316,
00320      7,   AMR_OF(2, vq_gain),   2,  17,  43,  25,  37,  47,  29,
00321      6,      AMR_OF(3, adap),  34,  53,  78,  73,  83, 100,
00322      1,       AMR_OF(3, ltp), 107,
00323     13, AMR_OF(3, pul_il[0]), 135, 167, 183, 231, 279, 151, 119, 179,
00324                               227, 275, 191, 239, 287,
00325     13, AMR_OF(3, pul_il[1]), 131, 163, 187, 235, 283, 147, 115, 199,
00326                               247, 295, 195, 243, 291,
00327     13, AMR_OF(3, pul_il[2]), 143, 175, 207, 255, 303, 159, 127, 203,
00328                               251, 299, 215, 263, 311,
00329     13, AMR_OF(3, pul_il[3]), 139, 171, 211, 259, 307, 155, 123, 223,
00330                               271, 319, 219, 267, 315,
00331      7,   AMR_OF(3, vq_gain),   1,  16,  42,  24,  36,  46,  28,
00332      0
00333 };
00334 
00335 static const uint16_t order_MODE_18k25[] = {
00336      1,         AMR_BIT(vad),   7,
00337      8,   AMR_BIT(isp_id[0]),  55,  40,  14,   6,  15,   5,   0,  68,
00338      8,   AMR_BIT(isp_id[1]),  77,  58,  75,  49,  59,  57,  67,  61,
00339      6,   AMR_BIT(isp_id[2]),  48,  63,  51,  62,  50,  70,
00340      7,   AMR_BIT(isp_id[3]),  71,  56,  60,  69,  85,  86,  80,
00341      7,   AMR_BIT(isp_id[4]),  93,  64,  94,  76,  82,  81,  89,
00342      5,   AMR_BIT(isp_id[5]),  90, 103,  88, 102,  99,
00343      5,   AMR_BIT(isp_id[6]),  98,  97,  96, 111,  95,
00344      9,      AMR_OF(0, adap),  13,  12,  11,  10,   9,  41,  66,  72,
00345                                92,
00346      1,       AMR_OF(0, ltp), 110,
00347      2, AMR_OF(0, pul_ih[0]), 124, 115,
00348      2, AMR_OF(0, pul_ih[1]), 150, 117,
00349      2, AMR_OF(0, pul_ih[2]), 129, 114,
00350      2, AMR_OF(0, pul_ih[3]), 121, 131,
00351     14, AMR_OF(0, pul_il[0]), 161, 257, 343, 199, 177, 303, 204, 173,
00352                               168, 260, 277, 307, 338, 128,
00353     14, AMR_OF(0, pul_il[1]), 194, 286, 347, 222, 214, 316, 236, 152,
00354                               166, 242, 284, 308, 344, 142,
00355     14, AMR_OF(0, pul_il[2]), 169, 273, 353, 202, 189, 311, 240, 200,
00356                               171, 261, 309, 296, 345, 130,
00357     14, AMR_OF(0, pul_il[3]), 198, 275, 349, 187, 163, 282, 193, 195,
00358                               175, 234, 265, 289, 328, 119,
00359      7,   AMR_OF(0, vq_gain),   4,  19,  45,  27,  39,  33,  31,
00360      6,      AMR_OF(1, adap),  35,  54,  79,  74,  84, 101,
00361      1,       AMR_OF(1, ltp), 109,
00362      2, AMR_OF(1, pul_ih[0]), 139, 104,
00363      2, AMR_OF(1, pul_ih[1]), 135, 118,
00364      2, AMR_OF(1, pul_ih[2]), 112, 127,
00365      2, AMR_OF(1, pul_ih[3]), 140, 141,
00366     14, AMR_OF(1, pul_il[0]), 179, 276, 340, 225, 223, 321, 235, 190,
00367                               182, 271, 310, 315, 352, 125,
00368     14, AMR_OF(1, pul_il[1]), 153, 264, 329, 232, 209, 323, 231, 165,
00369                               191, 279, 290, 312, 367, 134,
00370     14, AMR_OF(1, pul_il[2]), 167, 269, 341, 205, 197, 298, 224, 160,
00371                               170, 259, 280, 317, 357, 148,
00372     14, AMR_OF(1, pul_il[3]), 203, 272, 342, 227, 192, 299, 233, 172,
00373                               183, 256, 283, 326, 355, 106,
00374      7,   AMR_OF(1, vq_gain),   3,  18,  44,  26,  38,  32,  30,
00375      9,      AMR_OF(2, adap),   8,  23,  22,  21,  20,  52,  65,  87,
00376                                91,
00377      1,       AMR_OF(2, ltp), 108,
00378      2, AMR_OF(2, pul_ih[0]), 144, 120,
00379      2, AMR_OF(2, pul_ih[1]), 157, 123,
00380      2, AMR_OF(2, pul_ih[2]), 145, 138,
00381      2, AMR_OF(2, pul_ih[3]), 132, 154,
00382     14, AMR_OF(2, pul_il[0]), 241, 319, 365, 252, 253, 331, 254, 230,
00383                               220, 263, 285, 314, 364, 156,
00384     14, AMR_OF(2, pul_il[1]), 247, 291, 339, 249, 250, 332, 267, 196,
00385                               207, 268, 304, 324, 356, 158,
00386     14, AMR_OF(2, pul_il[2]), 210, 300, 348, 243, 237, 333, 246, 206,
00387                               219, 266, 318, 335, 363, 159,
00388     14, AMR_OF(2, pul_il[3]), 239, 306, 366, 221, 226, 297, 251, 184,
00389                               178, 258, 292, 305, 346, 116,
00390      7,   AMR_OF(2, vq_gain),   2,  17,  43,  25,  37,  47,  29,
00391      6,      AMR_OF(3, adap),  34,  53,  78,  73,  83, 100,
00392      1,       AMR_OF(3, ltp), 107,
00393      2, AMR_OF(3, pul_ih[0]), 143, 126,
00394      2, AMR_OF(3, pul_ih[1]), 137, 122,
00395      2, AMR_OF(3, pul_ih[2]), 149, 105,
00396      2, AMR_OF(3, pul_ih[3]), 133, 136,
00397     14, AMR_OF(3, pul_il[0]), 162, 287, 337, 244, 229, 322, 218, 180,
00398                               186, 262, 274, 288, 351, 146,
00399     14, AMR_OF(3, pul_il[1]), 212, 294, 358, 248, 228, 334, 215, 174,
00400                               176, 270, 293, 301, 354, 147,
00401     14, AMR_OF(3, pul_il[2]), 185, 327, 336, 211, 213, 313, 245, 181,
00402                               188, 255, 281, 325, 350, 151,
00403     14, AMR_OF(3, pul_il[3]), 201, 295, 359, 216, 208, 320, 238, 164,
00404                               155, 217, 278, 302, 330, 113,
00405      7,   AMR_OF(3, vq_gain),   1,  16,  42,  24,  36,  46,  28,
00406      0
00407 };
00408 
00409 static const uint16_t order_MODE_19k85[] = {
00410      1,         AMR_BIT(vad),   7,
00411      8,   AMR_BIT(isp_id[0]),  55,  40,  14,   6,  15,   5,   0,  68,
00412      8,   AMR_BIT(isp_id[1]),  77,  58,  75,  49,  59,  57,  67,  61,
00413      6,   AMR_BIT(isp_id[2]),  48,  63,  51,  62,  50,  70,
00414      7,   AMR_BIT(isp_id[3]),  71,  56,  60,  69,  85,  86,  80,
00415      7,   AMR_BIT(isp_id[4]),  93,  64,  94,  76,  82,  81,  89,
00416      5,   AMR_BIT(isp_id[5]),  90, 103,  88, 102,  99,
00417      5,   AMR_BIT(isp_id[6]),  98,  97,  96, 111,  95,
00418      9,      AMR_OF(0, adap),  13,  12,  11,  10,   9,  41,  66,  72,
00419                                92,
00420      1,       AMR_OF(0, ltp), 110,
00421     10, AMR_OF(0, pul_ih[0]), 134, 153, 263, 342, 399, 154, 106, 177,
00422                               317, 265,
00423     10, AMR_OF(0, pul_ih[1]), 128, 167, 270, 351, 385, 160, 105, 213,
00424                               329, 259,
00425      2, AMR_OF(0, pul_ih[2]), 123, 147,
00426      2, AMR_OF(0, pul_ih[3]), 131, 143,
00427     10, AMR_OF(0, pul_il[0]), 346, 118, 170, 201, 296, 368, 250, 284,
00428                               341, 391,
00429     10, AMR_OF(0, pul_il[1]), 345, 104, 166, 196, 281, 374, 242, 269,
00430                               327, 390,
00431     14, AMR_OF(0, pul_il[2]), 141, 171, 291, 364, 229, 210, 308, 228,
00432                               206, 200, 258, 295, 313, 361,
00433     14, AMR_OF(0, pul_il[3]), 144, 188, 282, 366, 217, 216, 309, 218,
00434                               193, 182, 245, 287, 300, 367,
00435      7,   AMR_OF(0, vq_gain),   4,  19,  45,  27,  39,  33,  31,
00436      6,      AMR_OF(1, adap),  35,  54,  79,  74,  84, 101,
00437      1,       AMR_OF(1, ltp), 109,
00438     10, AMR_OF(1, pul_ih[0]), 139, 169, 267, 348, 389, 163, 116, 189,
00439                               343, 268,
00440     10, AMR_OF(1, pul_ih[1]), 120, 161, 249, 339, 397, 152, 114, 230,
00441                               334, 303,
00442      2, AMR_OF(1, pul_ih[2]), 125, 138,
00443      2, AMR_OF(1, pul_ih[3]), 112, 129,
00444     10, AMR_OF(1, pul_il[0]), 349, 122, 162, 203, 288, 372, 278, 274,
00445                               312, 377,
00446     10, AMR_OF(1, pul_il[1]), 357, 126, 165, 214, 298, 362, 252, 260,
00447                               321, 378,
00448     14, AMR_OF(1, pul_il[2]), 150, 199, 266, 355, 211, 180, 285, 241,
00449                               195, 198, 243, 275, 323, 375,
00450     14, AMR_OF(1, pul_il[3]), 142, 191, 256, 353, 208, 220, 314, 237,
00451                               190, 212, 255, 304, 318, 371,
00452      7,   AMR_OF(1, vq_gain),   3,  18,  44,  26,  38,  32,  30,
00453      9,      AMR_OF(2, adap),   8,  23,  22,  21,  20,  52,  65,  87,
00454                                91,
00455      1,       AMR_OF(2, ltp), 108,
00456     10, AMR_OF(2, pul_ih[0]), 159, 168, 302, 356, 395, 178, 132, 185,
00457                               330, 286,
00458     10, AMR_OF(2, pul_ih[1]), 158, 181, 292, 358, 396, 176, 133, 235,
00459                               331, 276,
00460      2, AMR_OF(2, pul_ih[2]), 130, 157,
00461      2, AMR_OF(2, pul_ih[3]), 124, 136,
00462     10, AMR_OF(2, pul_il[0]), 354, 121, 194, 246, 322, 379, 272, 273,
00463                               332, 398,
00464     10, AMR_OF(2, pul_il[1]), 359, 140, 186, 236, 333, 376, 290, 301,
00465                               338, 387,
00466     14, AMR_OF(2, pul_il[2]), 155, 227, 319, 369, 253, 254, 350, 248,
00467                               224, 239, 240, 293, 315, 383,
00468     14, AMR_OF(2, pul_il[3]), 156, 209, 297, 373, 225, 215, 326, 247,
00469                               197, 184, 232, 289, 310, 365,
00470      7,   AMR_OF(2, vq_gain),   2,  17,  43,  25,  37,  47,  29,
00471      6,      AMR_OF(3, adap),  34,  53,  78,  73,  83, 100,
00472      1,       AMR_OF(3, ltp), 107,
00473     10, AMR_OF(3, pul_ih[0]), 148, 164, 264, 340, 388, 183, 117, 205,
00474                               336, 261,
00475     10, AMR_OF(3, pul_ih[1]), 146, 174, 257, 335, 384, 173, 113, 187,
00476                               320, 279,
00477      2, AMR_OF(3, pul_ih[2]), 127, 151,
00478      2, AMR_OF(3, pul_ih[3]), 119, 137,
00479     10, AMR_OF(3, pul_il[0]), 352, 135, 172, 238, 306, 381, 262, 271,
00480                               328, 382,
00481     10, AMR_OF(3, pul_il[1]), 347, 115, 179, 219, 305, 380, 277, 294,
00482                               337, 386,
00483     14, AMR_OF(3, pul_il[2]), 145, 192, 307, 370, 234, 223, 324, 244,
00484                               202, 204, 251, 299, 325, 360,
00485     14, AMR_OF(3, pul_il[3]), 149, 221, 311, 363, 226, 222, 316, 231,
00486                               207, 175, 233, 280, 283, 344,
00487      7,   AMR_OF(3, vq_gain),   1,  16,  42,  24,  36,  46,  28,
00488      0
00489 };
00490 
00491 static const uint16_t order_MODE_23k05[] = {
00492      1,         AMR_BIT(vad),   7,
00493      8,   AMR_BIT(isp_id[0]),  55,  40,  14,   6,  15,   5,   0,  68,
00494      8,   AMR_BIT(isp_id[1]),  77,  58,  75,  49,  59,  57,  67,  61,
00495      6,   AMR_BIT(isp_id[2]),  48,  63,  51,  62,  50,  70,
00496      7,   AMR_BIT(isp_id[3]),  71,  56,  60,  69,  85,  86,  80,
00497      7,   AMR_BIT(isp_id[4]),  93,  64,  94,  76,  82,  81,  89,
00498      5,   AMR_BIT(isp_id[5]),  90, 103,  88, 102,  99,
00499      5,   AMR_BIT(isp_id[6]),  98,  97,  96, 111,  95,
00500      9,      AMR_OF(0, adap),  13,  12,  11,  10,   9,  41,  66,  72,
00501                                92,
00502      1,       AMR_OF(0, ltp), 110,
00503     11, AMR_OF(0, pul_ih[0]), 118, 129, 131, 153, 170, 282, 298, 210,
00504                               191, 357, 317,
00505     11, AMR_OF(0, pul_ih[1]), 126, 146, 135, 165, 187, 273, 345, 295,
00506                               172, 338, 340,
00507     11, AMR_OF(0, pul_ih[2]), 119, 137, 141, 167, 208, 304, 366, 256,
00508                               177, 339, 328,
00509     11, AMR_OF(0, pul_ih[3]), 116, 130, 120, 166, 190, 252, 311, 239,
00510                               173, 343, 318,
00511     11, AMR_OF(0, pul_il[0]), 245, 180, 342, 424, 259, 277, 266, 380,
00512                               398, 423, 440,
00513     11, AMR_OF(0, pul_il[1]), 218, 207, 367, 434, 201, 240, 275, 363,
00514                               399, 419, 452,
00515     11, AMR_OF(0, pul_il[2]), 274, 188, 348, 425, 242, 204, 262, 365,
00516                               402, 431, 463,
00517     11, AMR_OF(0, pul_il[3]), 221, 183, 337, 439, 243, 216, 251, 354,
00518                               390, 411, 462,
00519      7,   AMR_OF(0, vq_gain),   4,  19,  45,  27,  39,  33,  31,
00520      6,      AMR_OF(1, adap),  35,  54,  79,  74,  84, 101,
00521      1,       AMR_OF(1, ltp), 109,
00522     11, AMR_OF(1, pul_ih[0]), 115, 140, 142, 161, 230, 291, 351, 235,
00523                               181, 293, 310,
00524     11, AMR_OF(1, pul_ih[1]), 104, 138, 132, 162, 211, 315, 347, 233,
00525                               176, 320, 329,
00526     11, AMR_OF(1, pul_ih[2]), 106, 134, 125, 154, 205, 267, 306, 220,
00527                               185, 330, 297,
00528     11, AMR_OF(1, pul_ih[3]), 105, 148, 122, 152, 215, 302, 350, 254,
00529                               178, 319, 313,
00530     11, AMR_OF(1, pul_il[0]), 269, 189, 382, 432, 272, 228, 263, 383,
00531                               406, 422, 453,
00532     11, AMR_OF(1, pul_il[1]), 286, 206, 377, 446, 226, 222, 265, 368,
00533                               404, 416, 454,
00534     11, AMR_OF(1, pul_il[2]), 247, 195, 358, 445, 224, 236, 309, 341,
00535                               375, 408, 449,
00536     11, AMR_OF(1, pul_il[3]), 225, 192, 359, 436, 250, 258, 290, 389,
00537                               400, 420, 448,
00538      7,   AMR_OF(1, vq_gain),   3,  18,  44,  26,  38,  32,  30,
00539      9,      AMR_OF(2, adap),   8,  23,  22,  21,  20,  52,  65,  87,
00540                                91,
00541      1,       AMR_OF(2, ltp), 108,
00542     11, AMR_OF(2, pul_ih[0]), 139, 144, 145, 169, 234, 327, 395, 299,
00543                               244, 356, 379,
00544     11, AMR_OF(2, pul_ih[1]), 127, 156, 158, 171, 231, 308, 397, 355,
00545                               261, 371, 335,
00546     11, AMR_OF(2, pul_ih[2]), 123, 155, 157, 193, 241, 362, 384, 323,
00547                               238, 392, 361,
00548     11, AMR_OF(2, pul_ih[3]), 114, 147, 121, 175, 196, 333, 373, 303,
00549                               184, 353, 322,
00550     11, AMR_OF(2, pul_il[0]), 271, 203, 385, 442, 307, 276, 334, 405,
00551                               412, 427, 459,
00552     11, AMR_OF(2, pul_il[1]), 278, 200, 388, 447, 292, 288, 296, 403,
00553                               415, 429, 460,
00554     11, AMR_OF(2, pul_il[2]), 312, 214, 393, 433, 279, 301, 314, 391,
00555                               410, 426, 450,
00556     11, AMR_OF(2, pul_il[3]), 280, 186, 376, 437, 268, 260, 255, 364,
00557                               414, 417, 441,
00558      7,   AMR_OF(2, vq_gain),   2,  17,  43,  25,  37,  47,  29,
00559      6,      AMR_OF(3, adap),  34,  53,  78,  73,  83, 100,
00560      1,       AMR_OF(3, ltp), 107,
00561     11, AMR_OF(3, pul_ih[0]), 112, 159, 143, 164, 213, 281, 332, 284,
00562                               168, 344, 325,
00563     11, AMR_OF(3, pul_ih[1]), 113, 150, 149, 179, 199, 316, 324, 285,
00564                               237, 360, 336,
00565     11, AMR_OF(3, pul_ih[2]), 124, 136, 151, 174, 209, 326, 349, 248,
00566                               198, 374, 331,
00567     11, AMR_OF(3, pul_ih[3]), 117, 128, 133, 163, 202, 300, 372, 305,
00568                               194, 387, 321,
00569     11, AMR_OF(3, pul_il[0]), 249, 182, 352, 428, 253, 264, 289, 413,
00570                               407, 418, 461,
00571     11, AMR_OF(3, pul_il[1]), 287, 212, 369, 444, 223, 246, 217, 346,
00572                               394, 401, 451,
00573     11, AMR_OF(3, pul_il[2]), 219, 197, 378, 435, 229, 257, 283, 396,
00574                               409, 430, 455,
00575     11, AMR_OF(3, pul_il[3]), 232, 160, 370, 438, 227, 270, 294, 381,
00576                               386, 421, 443,
00577      7,   AMR_OF(3, vq_gain),   1,  16,  42,  24,  36,  46,  28,
00578      0
00579 };
00580 
00581 static const uint16_t order_MODE_23k85[] = {
00582      1,         AMR_BIT(vad),   7,
00583      8,   AMR_BIT(isp_id[0]),  55,  40,  14,   6,  15,   5,   0,  68,
00584      8,   AMR_BIT(isp_id[1]),  93,  58,  91,  49,  59,  57,  67,  61,
00585      6,   AMR_BIT(isp_id[2]),  48,  63,  51,  62,  50,  70,
00586      7,   AMR_BIT(isp_id[3]),  71,  56,  60,  69, 101, 102,  96,
00587      7,   AMR_BIT(isp_id[4]), 109,  64, 110,  92,  98,  97, 105,
00588      5,   AMR_BIT(isp_id[5]), 106, 119, 104, 118, 115,
00589      5,   AMR_BIT(isp_id[6]), 114, 113, 112, 127, 111,
00590      9,      AMR_OF(0, adap),  13,  12,  11,  10,   9,  41,  66,  88,
00591                               108,
00592      1,       AMR_OF(0, ltp), 126,
00593     11, AMR_OF(0, pul_ih[0]), 134, 145, 147, 169, 186, 298, 314, 226,
00594                               207, 373, 333,
00595     11, AMR_OF(0, pul_ih[1]), 142, 162, 151, 181, 203, 289, 361, 311,
00596                               188, 354, 356,
00597     11, AMR_OF(0, pul_ih[2]), 135, 153, 157, 183, 224, 320, 382, 272,
00598                               193, 355, 344,
00599     11, AMR_OF(0, pul_ih[3]), 132, 146, 136, 182, 206, 268, 327, 255,
00600                               189, 359, 334,
00601     11, AMR_OF(0, pul_il[0]), 261, 196, 358, 440, 275, 293, 282, 396,
00602                               414, 439, 456,
00603     11, AMR_OF(0, pul_il[1]), 234, 223, 383, 450, 217, 256, 291, 379,
00604                               415, 435, 468,
00605     11, AMR_OF(0, pul_il[2]), 290, 204, 364, 441, 258, 220, 278, 381,
00606                               418, 447, 479,
00607     11, AMR_OF(0, pul_il[3]), 237, 199, 353, 455, 259, 232, 267, 370,
00608                               406, 427, 478,
00609      7,   AMR_OF(0, vq_gain),   4,  19,  45,  27,  39,  33,  31,
00610      4,   AMR_OF(0, hb_gain),  79,  78,  77,  76,
00611      6,      AMR_OF(1, adap),  35,  54,  95,  90, 100, 117,
00612      1,       AMR_OF(1, ltp), 125,
00613     11, AMR_OF(1, pul_ih[0]), 131, 156, 158, 177, 246, 307, 367, 251,
00614                               197, 309, 326,
00615     11, AMR_OF(1, pul_ih[1]), 120, 154, 148, 178, 227, 331, 363, 249,
00616                               192, 336, 345,
00617     11, AMR_OF(1, pul_ih[2]), 122, 150, 141, 170, 221, 283, 322, 236,
00618                               201, 346, 313,
00619     11, AMR_OF(1, pul_ih[3]), 121, 164, 138, 168, 231, 318, 366, 270,
00620                               194, 335, 329,
00621     11, AMR_OF(1, pul_il[0]), 285, 205, 398, 448, 288, 244, 279, 399,
00622                               422, 438, 469,
00623     11, AMR_OF(1, pul_il[1]), 302, 222, 393, 462, 242, 238, 281, 384,
00624                               420, 432, 470,
00625     11, AMR_OF(1, pul_il[2]), 263, 211, 374, 461, 240, 252, 325, 357,
00626                               391, 424, 465,
00627     11, AMR_OF(1, pul_il[3]), 241, 208, 375, 452, 266, 274, 306, 405,
00628                               416, 436, 464,
00629      7,   AMR_OF(1, vq_gain),   3,  18,  44,  26,  38,  32,  30,
00630      4,   AMR_OF(1, hb_gain),  75,  74,  73,  72,
00631      9,      AMR_OF(2, adap),   8,  23,  22,  21,  20,  52,  65, 103,
00632                               107,
00633      1,       AMR_OF(2, ltp), 124,
00634     11, AMR_OF(2, pul_ih[0]), 155, 160, 161, 185, 250, 343, 411, 315,
00635                               260, 372, 395,
00636     11, AMR_OF(2, pul_ih[1]), 143, 172, 174, 187, 247, 324, 413, 371,
00637                               277, 387, 351,
00638     11, AMR_OF(2, pul_ih[2]), 139, 171, 173, 209, 257, 378, 400, 339,
00639                               254, 408, 377,
00640     11, AMR_OF(2, pul_ih[3]), 130, 163, 137, 191, 212, 349, 389, 319,
00641                               200, 369, 338,
00642     11, AMR_OF(2, pul_il[0]), 287, 219, 401, 458, 323, 292, 350, 421,
00643                               428, 443, 475,
00644     11, AMR_OF(2, pul_il[1]), 294, 216, 404, 463, 308, 304, 312, 419,
00645                               431, 445, 476,
00646     11, AMR_OF(2, pul_il[2]), 328, 230, 409, 449, 295, 317, 330, 407,
00647                               426, 442, 466,
00648     11, AMR_OF(2, pul_il[3]), 296, 202, 392, 453, 284, 276, 271, 380,
00649                               430, 433, 457,
00650      7,   AMR_OF(2, vq_gain),   2,  17,  43,  25,  37,  47,  29,
00651      4,   AMR_OF(2, hb_gain),  87,  86,  85,  84,
00652      6,      AMR_OF(3, adap),  34,  53,  94,  89,  99, 116,
00653      1,       AMR_OF(3, ltp), 123,
00654     11, AMR_OF(3, pul_ih[0]), 128, 175, 159, 180, 229, 297, 348, 300,
00655                               184, 360, 341,
00656     11, AMR_OF(3, pul_ih[1]), 129, 166, 165, 195, 215, 332, 340, 301,
00657                               253, 376, 352,
00658     11, AMR_OF(3, pul_ih[2]), 140, 152, 167, 190, 225, 342, 365, 264,
00659                               214, 390, 347,
00660     11, AMR_OF(3, pul_ih[3]), 133, 144, 149, 179, 218, 316, 388, 321,
00661                               210, 403, 337,
00662     11, AMR_OF(3, pul_il[0]), 265, 198, 368, 444, 269, 280, 305, 429,
00663                               423, 434, 477,
00664     11, AMR_OF(3, pul_il[1]), 303, 228, 385, 460, 239, 262, 233, 362,
00665                               410, 417, 467,
00666     11, AMR_OF(3, pul_il[2]), 235, 213, 394, 451, 245, 273, 299, 412,
00667                               425, 446, 471,
00668     11, AMR_OF(3, pul_il[3]), 248, 176, 386, 454, 243, 286, 310, 397,
00669                               402, 437, 459,
00670      7,   AMR_OF(3, vq_gain),   1,  16,  42,  24,  36,  46,  28,
00671      4,   AMR_OF(3, hb_gain),  83,  82,  81,  80,
00672      0
00673 };
00674 
00676 static const uint16_t* amr_bit_orderings_by_mode[] = {
00677     order_MODE_6k60,
00678     order_MODE_8k85,
00679     order_MODE_12k65,
00680     order_MODE_14k25,
00681     order_MODE_15k85,
00682     order_MODE_18k25,
00683     order_MODE_19k85,
00684     order_MODE_23k05,
00685     order_MODE_23k85
00686 };
00687 
00688 // Extracted from 3GPP TS 26.173 V9.0.0 (qpisf_2s.tab)
00689 // The *_36b tables are used in 6k60 mode
00690 // Stored in fixed-point to save some space
00692 static const int16_t dico1_isf[256][9] = {
00693  {  579,  1081,  1035,   390,     3,  -263,  -198,   -82,    38},
00694  {   18,   -68,   -12,   313,   761,   405,   249,   111,   -76},
00695  {  740,  1263,  1292,  1006,   997,  1019,  1017,   976,   923},
00696  {  -91,   827,   948,   648,   613,   535,   522,   490,   421},
00697  {   41,   -44,  -281,  -472,   652,   534,   193,   135,   -90},
00698  {   41,  -121,  -356,   -60,   663,   307,    61,   -48,  -344},
00699  {  557,   946,  1049,   867,   846,   990,  1112,  1262,  1241},
00700  { -118,  -204,   328,   512,   870,   793,   610,   402,   186},
00701  {  156,   293,    74,  -338,  -475,  -897,  -594,  -161,  -497},
00702  {  226,   131,  -138,   307,   169,  -271,  -164,  -387,  -624},
00703  {   62,   -32,   -61,  -252,  -541,  -828, -1027,  -523,  -662},
00704  {  102,   -61,   141,   112,  -270,  -251,  -541,    25,  -150},
00705  {    6,  -132,  -356,  -686,   -96,  -322,  -522,   -31,  -326},
00706  {  -36,  -209,  -521,  -229,   307,  -132,    -5,   -99,  -384},
00707  {   60,   -51,  -237,  -668,  -973,  -407,  -708,   -75,  -172},
00708  {   26,  -138,  -266,   111,  -302,    43,  -278,  -356,  -359},
00709  {  570,   822,   496,  -154,  -312,   -92,   137,   279,   371},
00710  { -146,   368,   409,    68,     6,    77,   167,   202,   162},
00711  {  633,   898,   996,   756,   662,   683,   783,   909,   996},
00712  { -103,   294,   607,   415,   483,   462,   480,   431,   408},
00713  { -120,  -338,  -612,  -524,   584,   331,    92,   433,   276},
00714  { -178,  -293,  -154,   -41,   269,   100,    -9,   213,   160},
00715  {  830,   736,   278,   820,  1254,   686,   712,  1039,   473},
00716  { -218,  -304,   463,   454,   397,   273,   202,   286,   273},
00717  { -232,     7,     6,  -388,  -472,  -427,  -378,  -167,  -100},
00718  { -294,  -183,   134,   -47,   101,   -88,   -84,  -117,    -3},
00719  {   57,    17,  -202,  -634,  -989, -1119,  -533,   176,   -36},
00720  {  120,   -28,    23,   111,  -319,   318,   -22,   -77,   266},
00721  { -271,  -464,  -434,  -658,  -640,  -385,  -385,   -99,   -69},
00722  { -198,  -259,  -266,   -44,   -39,  -139,  -137,   171,    66},
00723  {    9,  -145,  -377,  -846, -1000,  -111,  -325,   342,   135},
00724  {  -81,  -286,  -380,   192,   -57,   307,    76,   -24,  -140},
00725  {  677,   702,   247,    56,   249,   141,  -105,  -236,   -99},
00726  {   36,   -39,   -69,   348,   198,   -93,   322,    91,   -72},
00727  {  503,   885,  1508,  1307,  1282,  1172,  1119,  1209,  1061},
00728  {  416,   719,   989,  1227,  1001,  1052,   954,   741,  1044},
00729  { -127,  -376,  -657,   139,   623,   223,   501,   306,   220},
00730  { -113,  -384,  -796,   504,   438,    85,   213,   -83,  -194},
00731  {  585,  1132,  1233,  1091,  1247,  1433,  1512,  1448,  1314},
00732  { -174,  -422,     7,  1155,  1089,  1182,  1003,   945,   806},
00733  {    8,  -126,  -317,  -103,  -351,  -695,   -98,  -268,  -537},
00734  {   33,  -103,  -290,   167,   -39,  -407,    44,  -208,  -375},
00735  {  104,   -23,   -64,  -291,  -637,  -851, -1084,   -61,  -112},
00736  {  -75,  -306,  -434,   218,  -148,  -354,  -680,  -133,  -216},
00737  { -121,  -377,  -718,   -97,  -130,  -361,  -156,  -379,  -599},
00738  {  -56,  -254,  -586,   235,   157,  -214,    11,  -260,  -149},
00739  { -124,  -267,  -397,  -580,  -593,  -527,  -805,  -385,   346},
00740  { -193,  -440,  -708,  -351,  -141,  -255,  -499,  -147,  -185},
00741  {  448,   660,   494,   208,   509,   461,   338,   291,   149},
00742  { -223,    88,   335,   159,   212,   191,   286,   308,   205},
00743  {  -31,   469,   803,   659,   619,   658,   843,   987,  1113},
00744  { -171,  -242,   514,   362,   295,   524,   552,   694,   585},
00745  {  -64,  -308,  -448,   -21,   284,   786,   446,   289,    92},
00746  { -218,  -390,    -7,   169,   206,   330,   352,   408,   358},
00747  {  -36,   702,   959,   859,   861,  1115,  1269,  1357,  1305},
00748  { -133,  -341,   -65,   678,   417,   440,   486,   518,   780},
00749  {   33,   -44,  -191,  -344,  -461,  -755,  -201,   217,   -31},
00750  { -353,  -547,   -44,   123,   -61,   -68,   -79,    29,    60},
00751  {   73,   -57,  -406,  -766, -1243, -1203,   240,   400,   165},
00752  {  -73,  -282,  -601,  -213,  -171,  -375,   332,    35,  -103},
00753  {  -29,  -207,  -553,  -476,  -638,  -908,   172,   -22,  -135},
00754  { -192,  -239,  -164,  -103,  -111,   -47,   153,   125,   110},
00755  {   -1,  -203,  -570, -1030, -1424,  -535,   155,     1,   147},
00756  { -333,  -653,  -865,  -197,  -158,   -21,   -44,    95,   108},
00757  {  389,   588,   490,    33,  -237,  -524,  -628,  -136,  -260},
00758  {   40,  -177,  -462,   453,   862,   380,   131,  -130,  -405},
00759  {  842,  1678,  1841,  1549,  1474,  1256,  1082,   905,   742},
00760  {  370,  1216,  1768,  1633,  1212,   636,    22,  -330,    71},
00761  {  -76,  -281,  -741,  -742,   898,   619,   277,    71,  -222},
00762  {  -32,  -265,  -556,   -25,   994,   682,   305,   126,  -165},
00763  {   73,   738,   893,   968,   993,  1768,  2273,  1840,  1391},
00764  {  -69,  -349,  -585,   234,  1158,   903,   626,   510,   251},
00765  {   -1,   -99,  -272,  -210,  -603,  -351,  -540,  -811,  -383},
00766  {  -16,  -230,  -504,   410,   149,  -205,  -343,  -651,  -639},
00767  {  103,    -9,  -227,  -205,  -562,  -781, -1079, -1208,  -156},
00768  {  143,    63,  -135,   -67,  -317,  -602,  -784, -1154,  -640},
00769  { -144,  -391,  -674,  -622,  -200,  -254,  -660,  -947,  -395},
00770  {  -40,  -250,  -625,    27,   543,    94,  -131,  -386,  -673},
00771  { -123,  -371,  -757,  -451,  -564,  -614,  -415,  -711,   -35},
00772  { -116,  -309,  -593,  -268,   239,   -33,  -338,  -650,  -135},
00773  {   94,   251,   554,    57,  -312,  -423,  -154,   -57,   235},
00774  { -268,   -71,   381,   114,   -44,   -87,   125,   173,   133},
00775  { 1513,  1714,  1238,   534,   276,   315,   461,   459,   508},
00776  { -131,   -19,  1149,   670,   486,   356,   309,   369,   296},
00777  { -223,  -501,  -899,  -722,   -70,     6,   131,   310,   394},
00778  {  -99,  -303,  -517,   249,    64,   -53,   135,   -11,   453},
00779  { -147,  -399,  -730,  -401,   817,   738,   802,   749,   575},
00780  { -154,  -435,  -739,   800,   593,   366,   529,   318,   326},
00781  { -224,    45,   -39,  -387,  -515,  -518,  -608,  -384,  -321},
00782  { -315,  -377,   143,  -101,  -113,  -377,  -177,  -144,   -12},
00783  {  117,    40,  -239,  -651, -1051,  -581,  -737,  -990,  -328},
00784  {   26,   -50,  -157,   -23,  -453,  -283,  -531,  -546,   192},
00785  { -252,  -501,  -743,  -589,  -627,  -499,  -328,  -118,   -72},
00786  { -324,  -494,  -244,  -306,  -144,  -177,  -262,  -135,   -78},
00787  {  -36,  -234,  -519,  -961, -1290,  -314,  -479,  -371,   -45},
00788  {  -95,  -292,  -535,    -8,  -300,   112,  -164,  -277,   198},
00789  {  -99,  -128,   880,   836,   579,   351,    23,   -95,  -217},
00790  {  -27,  -258,   124,  1011,   597,   425,   144,     7,   -73},
00791  {  421,  1293,  1640,  1623,  1742,  1617,  1499,  1284,  1006},
00792  {  -95,   752,  1680,  1569,  1618,  1436,  1200,   980,   712},
00793  {  -69,  -300,  -683,  -435,  1132,   899,   504,   332,   109},
00794  {  -74,  -323,  -637,   563,  1074,   608,   371,   105,   -49},
00795  {  -78,   831,  1194,  1110,  1378,  1481,  1492,  1365,  1217},
00796  { -259,  -121,  1440,  1334,  1628,  1490,  1438,  1223,   933},
00797  {  -82,  -306,  -613,  -222,  -378,  -675,  -545,  -671,  -845},
00798  {   53,  -124,  -347,   422,    52,  -125,  -270,  -529,     9},
00799  {   79,   -89,  -320,  -662,  -999, -1199, -1243,  -676,  -297},
00800  {  -68,  -273,  -611,   137,  -146,  -397,  -627,  -845,  -220},
00801  { -112,  -346,  -797,  -826,   234,  -132,  -188,  -278,  -522},
00802  { -159,  -405,  -734,  -419,   293,    74,  -167,  -167,   184},
00803  { -153,  -437,  -833, -1080,  -336,  -472,  -561,  -340,  -253},
00804  { -169,  -423,  -820,  -904,  -131,   -19,  -346,  -604,    31},
00805  {   33,   -31,   312,    62,  -148,    49,   -59,   564,   486},
00806  { -306,  -333,   194,   -44,    67,    72,   147,   205,   243},
00807  { -207,   -49,  1360,   983,   969,   991,  1014,  1110,   973},
00808  { -211,  -172,   883,   627,   711,   674,   705,   798,   746},
00809  {  -88,  -325,  -763,  -974,   687,   908,   514,   382,   172},
00810  { -292,  -612,  -805,    63,   131,   270,   259,   352,   348},
00811  { -235,   -84,   955,   818,  1120,  1289,  1559,  1480,  1285},
00812  { -180,  -461,  -614,   657,   691,   745,   854,   783,   713},
00813  {  -97,  -309,  -477,  -614,  -777,  -734,  -768,  -526,  -472},
00814  { -344,  -476,   -35,  -169,    49,   -77,  -150,  -240,  -141},
00815  {  -52,  -268,  -639,  -919, -1278, -1113,  -342,  -333,  -151},
00816  {  -68,  -242,  -585,   -73,  -209,  -478,  -159,  -429,   133},
00817  { -197,  -499, -1005, -1268,  -272,  -224,  -105,   -67,    17},
00818  { -363,  -618,  -414,  -116,   -62,    20,    10,   116,   108},
00819  { -195,  -475,  -906, -1260,  -891,  -441,  -277,  -142,   -28},
00820  { -226,  -519,  -950,  -700,  -275,  -266,  -116,  -105,    82},
00821  {  404,   511,   520,   327,    17,  -194,  -333,  -536,  -586},
00822  { -114,  -130,   276,   237,   204,   342,   135,   -16,  -111},
00823  {  670,  1208,  1168,   860,   742,   601,   528,   403,   309},
00824  {  397,   621,   966,   752,   579,   398,   400,   329,   252},
00825  {  191,   180,  -137,  -467,   272,   106,   -95,    17,  -192},
00826  {  -80,  -290,  -626,   194,   598,   196,    21,  -281,    77},
00827  {  510,   864,  1108,   807,   939,   902,   925,   717,   481},
00828  {  137,   367,   534,   764,   670,   382,   296,   153,    84},
00829  {  303,   497,   144,   -85,  -125,  -539,  -482,  -464,  -764},
00830  {  233,   347,    68,  -147,   169,  -210,  -242,  -226,  -482},
00831  {  307,   422,   154,  -175,  -386,  -722,  -724,  -904, -1015},
00832  {  309,   308,   160,   -60,  -470,  -420,  -598,  -791,  -219},
00833  {   68,   121,  -137,  -560,  -146,  -446,  -515,  -494,  -729},
00834  {  130,    53,  -227,    46,   474,    32,  -161,  -192,  -490},
00835  {  213,   164,   -71,  -465,  -876,  -161,  -456,  -587,   -48},
00836  {  218,   117,    39,   177,  -194,   -88,  -226,  -418,    50},
00837  {  210,   547,   569,   279,   121,   -44,   -50,    10,   -84},
00838  {   58,   140,   182,    -5,   267,   117,   106,   211,   198},
00839  {  539,   835,   913,   719,   617,   544,   591,   565,   642},
00840  {  153,   559,   872,   460,   222,   108,   188,   180,   183},
00841  {  158,   119,   284,  -153,  -271,   229,    87,   110,   -57},
00842  { -183,    82,   118,    21,    13,    40,   118,   191,   185},
00843  {  162,   889,   654,   108,   -34,   244,   488,   561,   532},
00844  {  163,    56,   609,   341,    50,   329,    68,   266,   218},
00845  {  100,   206,    18,  -304,  -107,  -436,  -487,   -65,  -306},
00846  {  -86,   154,   134,   -30,   -45,   -73,  -104,   -80,   -96},
00847  {  245,   330,    10,  -440,  -849, -1082,    79,    40,  -265},
00848  {  196,   372,   272,  -181,  -493,  -389,   275,    80,   -59},
00849  {    2,   -12,  -246,  -505,  -100,  -436,    21,  -187,  -431},
00850  { -221,   -48,    36,  -271,  -186,  -147,  -109,    26,    71},
00851  {  213,   140,    72,  -351,  -620,   -84,  -363,    69,    46},
00852  {   91,   167,    -3,   -95,   -99,  -105,   -48,   114,   147},
00853  {  259,   249,   172,   607,   406,    52,    59,  -189,  -320},
00854  {  115,   -85,   -54,   574,   128,   226,   -59,  -253,   130},
00855  {  -62,  1033,  1308,  1035,  1127,  1098,  1029,   961,   823},
00856  {   39,   364,   757,   940,   728,   660,   659,   583,   770},
00857  { -115,  -338,  -760,  -471,   394,    37,   441,   178,     6},
00858  {  -57,  -305,  -525,   796,   453,   188,    -4,  -114,   248},
00859  {   71,   444,   797,   731,  1096,  1157,  1222,  1029,   811},
00860  {  135,   359,   551,   425,   749,   815,   874,   704,   502},
00861  {  132,   247,     0,  -206,  -449,  -750,  -258,  -514,  -633},
00862  {  248,   249,    91,   121,  -195,  -499,   -90,  -282,  -435},
00863  {   78,    20,  -277,  -623,  -983, -1224,  -415,  -458,  -639},
00864  {  347,   509,   208,  -179,  -464,  -728,   -76,  -237,  -486},
00865  { -103,  -343,  -756,  -713,  -265,  -609,  -191,  -398,  -636},
00866  { -121,  -383,  -749,   567,   252,   -36,  -354,  -417,   -50},
00867  {  204,   100,  -149,  -650, -1081,   -47,    -7,  -263,   111},
00868  {  -46,  -180,  -267,  -324,  -562,  -394,  -692,   398,   292},
00869  {  482,   670,   683,   624,   442,   165,   116,    36,  -149},
00870  {  108,   247,   291,   247,   355,   122,   109,   224,   296},
00871  {  -14,   945,   990,   801,   755,   815,   847,   913,   892},
00872  {  292,   349,   725,   482,   388,   329,   429,   620,   667},
00873  {  -34,   197,   213,  -127,    84,   494,   620,   575,   375},
00874  {  126,   207,   172,   167,   362,   202,   296,   395,   455},
00875  {   -6,   250,   539,   467,   636,   801,  1149,  1287,  1118},
00876  {   27,   240,   369,   280,   440,   411,   634,   892,   953},
00877  {  159,   170,   -58,  -395,  -797,  -690,    77,  -211,  -334},
00878  {   -5,   -28,   -13,   -74,  -335,  -603,   300,    88,  -205},
00879  {   82,   -33,  -364,  -698, -1203, -1153,   110,  -146,  -289},
00880  {  113,     1,  -243,  -588,  -994,  -496,   414,   160,    42},
00881  {  -56,  -247,  -440,  -693,  -996,  -479,    11,  -178,  -357},
00882  { -151,  -353,  -327,  -211,  -340,   141,    65,   425,   453},
00883  {   34,  -169,  -455,  -932, -1215,   138,   499,   256,   324},
00884  {   68,   139,   -15,  -547,  -478,    17,   306,   502,   481},
00885  {  -32,  -134,   445,   129,  -143,  -244,  -503,  -507,  -599},
00886  {   61,  -140,  -345,   496,   458,    -2,    20,  -227,  -514},
00887  {  394,  1765,  1666,  1339,  1117,   806,   642,   479,   380},
00888  {  215,   519,   920,  1053,  1090,   791,   528,   290,   155},
00889  {  -54,  -233,  -647,  -602,   639,   294,    -2,  -167,  -442},
00890  {  -78,  -315,  -791,  -113,   820,   403,   158,  -116,  -356},
00891  {  529,  1851,  2003,  1228,   622,   -41,  -416,   344,   819},
00892  { -105,  -379,  -236,  1224,   893,   749,   568,   356,   214},
00893  {  -17,  -199,  -144,    50,  -283,  -247,  -578,  -846, -1087},
00894  {   69,   -11,  -381,  -206,   209,  -284,  -387,  -416,  -716},
00895  {   39,    -5,  -145,  -374,  -682,  -909, -1074, -1169, -1066},
00896  {  287,   226,    67,  -221,  -662,  -171,  -421,  -642,  -707},
00897  { -132,  -348,  -538,  -448,   -20,    -4,  -354,  -748,  -933},
00898  {    4,   -75,  -289,  -598,   317,    52,  -208,  -297,  -559},
00899  {  -88,  -264,  -358,  -589,  -631,  -248,  -523,  -822, -1071},
00900  {   70,    -8,    54,  -314,  -515,    92,  -146,  -274,  -493},
00901  {  199,    62,   391,   158,  -141,    71,  -219,  -203,  -207},
00902  {  152,    40,   329,   162,   -29,    48,  -149,   108,   127},
00903  {  635,  1058,   883,   492,   372,   312,   317,   274,   241},
00904  {  267,   722,  1256,   882,   625,   248,     8,   -81,   -60},
00905  {  -58,  -138,  -291,  -600,   -12,    -2,   -39,   147,   117},
00906  { -107,  -345,  -513,   459,    76,    92,  -272,   388,   262},
00907  {  362,   516,   203,  -409,  -716,  -831,  -331,   185,   209},
00908  { -117,  -391,  -298,   671,   292,   538,   257,   166,   -38},
00909  { -102,  -319,  -194,  -283,  -573,  -262,  -579,  -219,  -444},
00910  { -235,    78,    11,  -168,  -101,  -229,  -263,  -321,  -123},
00911  {   70,    50,  -170,  -599,  -996,  -588,  -263,  -516,  -455},
00912  {  394,   363,   229,  -136,  -538,    21,  -183,  -348,  -201},
00913  { -124,  -368,  -640,  -879,  -847,  -209,  -409,  -494,  -515},
00914  { -127,  -341,  -541,  -425,  -510,   -10,  -252,  -473,  -291},
00915  {   84,   -69,  -201,  -676,  -868,   103,  -311,  -132,  -320},
00916  {    5,  -173,  -188,  -297,  -628,   197,   -57,     7,   -11},
00917  {   49,  -160,    56,   558,   111,    33,  -311,  -440,  -463},
00918  {   -1,  -246,  -307,   862,   453,   139,  -170,  -355,  -232},
00919  {  279,   966,  1642,  1478,  1463,  1123,   795,   525,   339},
00920  { -197,   -38,  1702,  1331,  1252,   950,   692,   504,   426},
00921  { -108,  -344,  -861, -1172,   444,   354,    88,   -46,  -220},
00922  {  -53,  -321,  -494,  1113,   744,   364,   198,   -34,   -75},
00923  {  457,   955,  1177,  1214,  1427,  1457,  1345,   917,   539},
00924  {  -69,   199,   897,  1140,  1343,  1183,   977,   742,   522},
00925  {  122,    44,  -269,    27,  -155,  -562,  -307,  -590,  -773},
00926  {  154,    42,  -160,   252,  -129,  -305,  -471,  -733,  -371},
00927  {  135,   185,   -82,  -416,  -722,  -913,  -504,  -743,  -880},
00928  {  149,   214,   -84,  -329,  -680,  -835,  -426,  -661,   -81},
00929  { -128,  -380,  -735,  -998,  -337,    17,  -182,  -467,  -697},
00930  {  -84,  -290,  -510,  -592,    13,   440,   154,   -38,  -279},
00931  {   70,   -61,  -246,  -727, -1047,   -80,  -381,  -535,  -704},
00932  {  178,    -2,  -146,  -670,  -938,   482,   138,    63,    65},
00933  {  -11,    15,   772,   443,   142,   -20,  -209,  -126,  -161},
00934  {  -32,  -249,    95,   552,   124,    30,  -343,    82,   -86},
00935  {  148,   751,  1515,  1105,   867,   606,   474,   448,   399},
00936  { -163,  -257,   899,  1097,   906,   751,   502,   390,   294},
00937  {  -51,  -258,  -447,  -806,  -368,   763,   464,   364,   183},
00938  { -166,  -374,  -367,    87,    35,   399,   418,   856,   833},
00939  { -205,  -310,   588,   778,   785,  1065,  1118,  1245,  1157},
00940  { -173,  -312,   107,   345,   400,   790,   870,  1113,  1001},
00941  {   -7,  -120,  -387,  -410,  -614,  -943,  -226,  -384,  -491},
00942  { -203,  -288,   -51,  -331,   -90,  -178,  -408,  -573,  -338},
00943  {   56,   -29,  -273,  -627, -1041,  -798,  -247,  -467,   148},
00944  {   66,    -2,  -205,  -205,  -575,  -349,   -57,  -352,   -58},
00945  {  -45,  -225,  -471,  -924,  -497,    77,   -32,    44,  -135},
00946  { -277,  -491,  -497,  -502,  -424,  -202,  -137,    77,    96},
00947  {   26,  -179,  -469, -1008, -1260,   262,   -35,  -132,  -259},
00948  {  -66,  -232,  -447,  -533,  -789,  -191,  -100,  -267,   364}
00949 };
00950 
00951 static const int16_t dico2_isf[256][7] = {
00952  {  1357,  1313,  1136,   784,   438,   181,   145},
00953  {   636,   648,   667,   568,   442,   217,   362},
00954  {   427,   440,   674,   524,   332,   117,  -417},
00955  {   121,   295,   468,   465,   230,    44,  -221},
00956  {  -147,  -240,   149,    80,   390,   278,   106},
00957  {  -418,  -556,   552,   511,   235,   144,   -95},
00958  {    43,   193,   274,   150,    67,    34,  -273},
00959  {   -43,  -126,   171,   416,   282,    63,  -354},
00960  {  -372,   -86,  -344,  -108,   -94,  -182,   -89},
00961  {  -600,  -840,  -200,   465,   258,   -11,  -253},
00962  {   -48,   329,    97,  -290,  -543,  -795,  -354},
00963  {  -570,  -117,   187,    10,  -133,  -416,   -76},
00964  {  -618,  -129,  -247,  -371,    45,   -76,   277},
00965  { -1022, -1079,   126,   474,   254,   127,    52},
00966  {  -281,    76,  -167,  -361,  -283,  -551,  -283},
00967  {  -119,   -52,    -1,   134,   -32,  -204,  -415},
00968  {  1064,   827,   637,   684,   464,   209,    12},
00969  {   482,   416,   449,   371,   335,   294,   194},
00970  {   719,   576,   365,   135,   113,    91,  -199},
00971  {   298,   176,   493,   366,   194,   163,    36},
00972  {   -35,  -236,  -259,   -36,    -4,    99,   152},
00973  {   -98,  -306,   -27,   228,    90,   111,   -86},
00974  {    91,    13,  -211,  -258,  -106,    86,   -64},
00975  {    73,   -35,   -57,   -31,   162,    35,  -192},
00976  {  -109,  -335,  -629,   -66,   -61,  -128,   322},
00977  {  -495,  -669,  -728,   193,    31,  -220,   122},
00978  {   324,    95,   -89,   -91,  -409,  -710,  -154},
00979  {     0,  -234,    92,    33,  -343,  -609,  -220},
00980  {  -343,  -408,  -476,  -655,  -153,    82,   222},
00981  {  -490,  -745,  -255,    49,   -48,   135,  -127},
00982  {   119,   -67,  -328,  -390,  -272,  -545,   -56},
00983  {   -57,  -130,   -10,    -7,  -164,   -47,   -22},
00984  {   984,  1064,   961,   568,   210,   -27,    16},
00985  {   811,   691,   754,   514,   224,   -35,   166},
00986  {   662,   704,   618,   386,    57,  -211,  -257},
00987  {   510,   359,   418,   393,    91,  -144,   -18},
00988  {  -193,   -31,   -27,   223,    89,  -143,    24},
00989  {  -112,   -98,   471,   319,   185,     3,   175},
00990  {   252,   146,   -47,   272,    48,  -211,  -234},
00991  {   146,    69,   203,   364,    68,   -52,    51},
00992  {  -259,  -478,  -697,  -349,  -758,  -501,    63},
00993  {  -501,  -769,  -289,    79,  -311,  -497,  -106},
00994  {   251,    53,  -235,  -469,  -895,  -884,   145},
00995  {  -416,  -551,   140,  -133,  -523,  -775,    44},
00996  {  -326,  -423,  -713,  -497,   -86,  -431,    99},
00997  {  -757,  -772,  -160,   -76,   -46,   -32,   379},
00998  {    85,   -35,  -200,  -401,  -663, -1040,  -247},
00999  {  -180,  -330,   -92,  -376,    27,  -183,  -110},
01000  {  1279,  1086,   781,   502,   324,   164,   157},
01001  {   682,   466,   449,   277,   146,    28,   409},
01002  {   635,   472,   390,   107,  -232,  -538,  -139},
01003  {   196,   396,   332,   213,   209,   -29,   -81},
01004  {   150,   -95,  -312,    76,   -77,  -320,   -50},
01005  {    46,     9,    47,   175,   139,    30,   384},
01006  {   218,   206,   -24,  -250,   -96,  -276,  -183},
01007  {    26,   119,    38,    14,    -4,  -133,   -52},
01008  {  -477,  -614,  -987,  -715,  -631,  -813,   200},
01009  {  -744, -1009, -1065,  -745,  -631,  -171,    18},
01010  {  -137,  -251,  -483,  -613,  -980, -1203,    12},
01011  {  -605,  -767,  -562,  -686, -1088,  -515,    58},
01012  {  -202,  -428,  -782, -1072,   -96,  -234,  -179},
01013  {  -480,  -709, -1070,  -897,  -131,   -92,   321},
01014  {  -145,  -193,  -512,  -729,  -572,  -765,  -210},
01015  {  -331,  -585,  -525,  -631,  -281,  -208,  -303},
01016  {  1165,  1104,   939,   828,   716,   426,   155},
01017  {     6,  -109,   820,   778,   415,   113,   -27},
01018  {   381,   339,   314,   265,   121,    -9,  -474},
01019  {  -373,    47,   584,   442,    99,  -231,  -113},
01020  {  -496,   -38,  -285,   262,   305,   170,     4},
01021  {  -587,  -556,    69,    66,   471,   354,    13},
01022  {  -138,    70,   -18,   106,    67,   167,  -302},
01023  {  -445,  -141,   185,   191,   151,    83,  -133},
01024  {  -257,  -521,  -720,  -198,   134,   -46,  -182},
01025  {  -819, -1168,  -777,   512,   359,    95,  -113},
01026  {   137,    -2,   -74,  -138,  -401,  -114,  -371},
01027  {  -242,  -466,   204,   223,   -31,  -212,  -192},
01028  {  -532,  -637,  -466,  -686,   256,   277,  -139},
01029  { -1141, -1244,  -381,   -75,   -54,    14,    88},
01030  {  -311,   115,  -143,  -499,  -343,   124,  -416},
01031  {  -616,  -147,  -135,    43,    -4,   121,  -369},
01032  {   835,   783,   641,   390,   355,   350,    64},
01033  {    72,   194,   443,   467,   436,   219,   372},
01034  {   464,   369,   192,     4,  -156,   -72,  -226},
01035  {    57,   206,   303,   205,   188,   101,   265},
01036  {   -40,  -205,  -488,  -184,   276,    64,   -26},
01037  {  -217,  -433,  -297,   137,   328,   308,  -289},
01038  {   378,    81,  -308,  -465,    57,   -37,   227},
01039  {  -100,    24,   -36,  -151,   199,     8,   143},
01040  {  -426,  -697, -1059,  -133,   388,   161,   321},
01041  {  -644, -1023, -1271,    39,    66,  -123,    70},
01042  {   372,   177,  -173,  -556,  -553,  -304,  -189},
01043  {  -117,  -369,  -425,  -122,  -462,  -152,   -73},
01044  {  -649,  -850, -1189,  -767,   497,   360,   222},
01045  {  -798, -1139, -1455,  -190,   430,   234,   179},
01046  {    42,   -94,  -405,  -692,    38,  -202,  -246},
01047  {  -169,  -366,  -290,   -88,   -64,    32,  -292},
01048  {  1010,   923,   938,   710,   465,   230,   342},
01049  {   217,   300,  1054,   675,    68,  -458,  -179},
01050  {    78,   453,   316,    18,  -237,  -496,  -243},
01051  {   167,    21,   424,   215,   -91,  -303,  -170},
01052  {  -290,   -81,   -70,   -67,    40,    54,   -59},
01053  {  -353,  -427,   -90,    53,    94,     9,    54},
01054  {   -28,   318,   283,    15,  -240,   -58,    79},
01055  {   -75,  -121,   229,    35,    58,     6,  -133},
01056  {  -351,  -514,  -744,  -834,  -705,  -137,   164},
01057  { -1124, -1388, -1055,  -230,   -73,    40,    36},
01058  {  -163,  -233,  -532,  -785, -1170,  -697,    96},
01059  {  -788,  -959,  -246,  -430,  -624,  -165,    -8},
01060  {  -856,  -540,  -630,  -907,  -337,   -70,    76},
01061  {  -937, -1042,  -659,  -733,  -208,   199,   -26},
01062  {  -523,    78,   -98,  -501,  -869,  -890,   -81},
01063  {  -624,  -703,   -45,  -348,   -25,    87,  -186},
01064  {  1005,   823,   546,   249,    90,   -22,   207},
01065  {   298,   397,   381,   319,   200,    62,   303},
01066  {   473,   379,   133,  -247,  -632,  -441,    75},
01067  {   284,   208,   391,   115,   -25,    44,    95},
01068  {   -72,    79,   -95,   -63,  -129,  -293,   203},
01069  {  -164,  -349,   115,   122,    69,    -1,   378},
01070  {   348,   170,    99,    58,  -179,  -302,   188},
01071  {  -190,    -2,   150,    23,   -51,   -11,   216},
01072  {  -615,  -863, -1090, -1427,  -802,   -48,    -6},
01073  {  -961, -1276, -1548,  -727,   -58,    56,   223},
01074  {  -124,  -255,  -561,  -988, -1277,  -148,   -82},
01075  {  -480,  -660,  -891, -1191, -1339,  -325,    20},
01076  {  -621,  -917, -1296, -1350,   264,   289,    50},
01077  {  -844, -1022, -1345, -1329,  -293,    46,   278},
01078  {  -260,  -468,  -829, -1176,  -533,  -560,   -78},
01079  {  -215,  -484,  -822, -1233,  -791,    15,  -138},
01080  {  1301,  1317,  1262,  1048,   716,   357,   -64},
01081  {   578,   824,   925,   802,   630,   362,   102},
01082  {   470,   925,   767,   514,   327,   190,  -112},
01083  {   225,   492,   495,   437,   598,   384,   -45},
01084  {    43,    82,   -42,   175,   519,   342,   -64},
01085  {  -304,  -154,   159,   576,   403,   221,   327},
01086  {   214,   244,   122,   -62,   312,    92,  -160},
01087  {   218,   208,   310,   268,   306,   323,  -199},
01088  {  -285,  -269,   -79,  -124,  -143,  -153,   236},
01089  {  -205,  -384,  -426,   344,    59,  -185,  -184},
01090  {  -272,   247,   126,  -210,  -518,  -468,    78},
01091  {   -99,  -120,   502,   160,  -280,  -557,   304},
01092  {  -423,   -17,  -283,  -443,   215,   212,  -140},
01093  {  -564,  -684,  -228,   510,   361,   130,   323},
01094  {  -428,   335,    98,   -65,    36,  -215,  -246},
01095  {  -362,    51,   364,   -16,  -234,   150,  -165},
01096  {   914,   883,   751,   653,   676,   464,  -153},
01097  {   631,   545,   535,   720,   596,   360,   -81},
01098  {   783,   712,   512,   439,   341,   251,  -391},
01099  {   497,   417,   249,   372,   295,   173,  -193},
01100  {   128,  -110,  -385,    93,    39,   173,  -231},
01101  {   216,   -59,  -253,   462,   389,   154,    69},
01102  {   455,   270,    -4,  -337,   -49,   233,  -322},
01103  {   307,   143,    53,   218,   128,   236,  -156},
01104  {   -37,  -186,  -240,  -411,  -110,     9,   399},
01105  {  -140,  -365,  -628,   258,   380,   214,   277},
01106  {   131,   454,   177,  -285,  -520,   108,  -214},
01107  {    77,  -141,   201,  -123,  -490,  -131,    60},
01108  {   -14,  -194,  -521,  -741,   273,   362,   -33},
01109  {  -362,  -566,  -287,  -228,   161,   237,   317},
01110  {  -269,   195,   -75,  -375,  -204,    11,    77},
01111  {  -128,  -264,  -156,  -223,  -475,   265,    27},
01112  {  1238,  1147,   916,   689,   432,   210,  -280},
01113  {   800,   664,   879,   726,   411,   160,  -164},
01114  {   454,   686,   536,   275,   147,    46,   111},
01115  {   303,   486,   512,   355,   241,   181,   -69},
01116  {    79,    92,    29,   147,   233,    52,    17},
01117  {  -171,   289,   131,   439,   271,     3,   -10},
01118  {   413,   241,   144,   174,   155,    -2,    14},
01119  {    58,   217,   247,   219,   149,   175,   -18},
01120  {   228,    -8,  -240,  -206,  -513,  -191,   202},
01121  {   -96,  -272,  -454,    33,  -300,  -575,    46},
01122  {   -10,  -108,  -246,  -347,  -770,  -535,     9},
01123  {  -326,  -430,   -61,  -321,  -704,  -299,   201},
01124  {    -1,  -280,  -603,  -419,  -185,    18,   -36},
01125  {  -516,  -522,  -379,  -291,  -181,   -97,    27},
01126  {  -159,  -313,  -525,  -224,  -510,  -831,  -197},
01127  {  -292,  -459,   -59,  -310,  -562,  -143,  -351},
01128  {  1066,   912,   631,   389,   207,    86,  -224},
01129  {   596,   512,   596,   505,   314,   122,   -48},
01130  {   787,   861,   441,   -93,  -303,    33,  -190},
01131  {   257,   469,   337,    51,    15,   298,   -93},
01132  {   295,    73,  -119,    25,    36,    23,   108},
01133  {   -28,    -3,   -32,   114,    21,   185,   107},
01134  {   482,   305,    15,  -279,  -319,    52,    96},
01135  {   226,    46,   115,    72,  -136,   133,  -125},
01136  {    18,  -207,  -559,  -590,  -503,  -482,   321},
01137  {  -571,  -789,  -951,  -172,  -441,  -538,   113},
01138  {   181,    14,  -310,  -641, -1001,  -202,   159},
01139  {  -136,  -393,  -433,  -513,  -911,  -144,   -22},
01140  {    72,  -265,  -706,  -954,  -159,    53,   332},
01141  {  -338,  -591,  -852,  -383,  -395,    56,    44},
01142  {    43,  -158,  -464,  -897,  -631,  -157,  -294},
01143  {  -161,  -128,  -328,  -573,  -483,  -125,    11},
01144  {  1017,   906,  1051,  1005,   679,   341,  -102},
01145  {   359,   334,  1567,  1314,   723,   105,    10},
01146  {   -65,   726,   529,   301,   220,    43,  -273},
01147  {  -510,   436,   719,   566,   358,   179,   114},
01148  {  -560,   298,   133,  -120,   342,   225,    14},
01149  {  -899,  -101,   217,   617,   400,   146,   -58},
01150  {   -41,   352,    82,  -196,    39,   121,  -167},
01151  {  -212,    59,   447,   284,   423,   250,  -169},
01152  {  -371,  -484,  -596,    30,   -41,   249,    22},
01153  {  -372,  -650,  -794,   477,   445,   216,   -79},
01154  {  -352,   275,    17,  -443,  -929,    92,    19},
01155  {  -699,  -696,   431,   264,   -49,  -310,   182},
01156  {  -978,  -217,  -430,  -400,   101,   261,    72},
01157  {  -929,  -889,  -357,   -13,   463,   378,   236},
01158  {  -826,    56,    30,  -299,  -360,  -128,   -51},
01159  {  -878,  -299,  -111,    75,    65,    36,     3},
01160  {   817,   368,   -25,   354,   697,   591,  -173},
01161  {   309,   212,   222,   751,   484,   140,   -56},
01162  {   593,   379,    70,    -8,   258,   180,   110},
01163  {   165,   -46,   255,   297,   219,   273,   105},
01164  {   160,   -70,  -358,  -181,   379,   330,   319},
01165  {  -238,  -369,  -198,   740,   580,   319,  -143},
01166  {   201,   109,  -202,  -456,   328,   276,  -141},
01167  {   203,   170,   111,    42,   207,   360,   188},
01168  {  -345,  -399,  -513,  -233,   650,   422,    81},
01169  {  -635,  -961, -1220,   463,   539,   204,   209},
01170  {   202,   -25,  -194,  -498,  -787,   193,  -143},
01171  {  -449,  -538,   195,  -106,  -331,    68,    62},
01172  {  -228,  -477,  -840,  -576,   317,   128,   283},
01173  {  -671,  -937,  -807,  -114,   391,   335,   -62},
01174  {   246,     2,  -314,  -679,  -303,   180,   -88},
01175  {  -107,  -272,    90,  -198,   -28,   290,  -112},
01176  {   885,  1149,  1021,   712,   496,   281,   -83},
01177  {   269,   492,   787,   643,   347,    70,   124},
01178  {   336,   636,   499,    92,  -229,  -179,   191},
01179  {    26,   402,   564,   340,   149,   -11,   135},
01180  {  -440,   561,   470,   204,   -72,  -186,   140},
01181  {  -720,    14,   355,   229,    68,  -133,   465},
01182  {   110,   310,   103,    12,   106,    29,   158},
01183  {  -178,   113,   161,   142,   121,   115,    27},
01184  {  -651,  -414,  -645,  -152,  -164,   -13,  -429},
01185  {  -639,  -944,  -681,  -104,   -81,    52,  -189},
01186  {  -663,  -164,  -316,  -683,  -954,  -205,   -83},
01187  {  -609,  -669,  -172,  -517,  -694,   283,   -80},
01188  {  -646,  -152,  -383,  -678,  -246,   -40,  -143},
01189  {  -747,  -796,  -745,  -390,   -98,    43,   275},
01190  {  -599,  -199,  -398,  -433,  -436,  -538,    31},
01191  { -1107,  -568,  -376,  -265,  -126,   -21,     1},
01192  {   847,   573,   308,   392,   305,   101,    55},
01193  {   273,   293,   201,   267,   346,   201,   123},
01194  {   727,   480,   226,     2,   -65,  -138,   164},
01195  {   273,   208,   173,   292,    12,   253,   174},
01196  {   340,   207,   180,    88,   116,    46,   475},
01197  {  -460,  -166,   -30,    13,   110,   173,   396},
01198  {   137,    88,    43,  -137,   -94,    34,   284},
01199  {    96,   -14,   226,    40,    63,    70,   130},
01200  {  -467,  -735, -1012, -1174,  -307,   305,   -67},
01201  {  -612,  -920, -1146,  -567,    -8,    92,   -25},
01202  {  -182,  -271,  -492,  -754,  -857,   287,   -75},
01203  {  -494,  -787,  -689,  -683,  -709,   137,  -326},
01204  {  -288,  -550,  -903, -1105,   334,   321,   -62},
01205  {  -354,  -653,  -834,  -445,     1,   377,  -152},
01206  {  -162,  -306,  -608,  -937,  -297,   247,  -192},
01207  {  -234,  -477,  -244,  -488,  -266,   342,  -332}
01208 };
01209 
01210 static const int16_t dico21_isf[64][3] = {
01211  {   329,   409,   249}, {   -33,   505,   160},
01212  {   -29,   -14,   582}, {  -262,   127,   354},
01213  {   145,   237,   175}, {  -152,   245,   122},
01214  {    27,    42,   340}, {   -84,   -93,   311},
01215  {   285,   222,  -156}, {    47,   -43,  -504},
01216  {   234,   121,   385}, {   104,  -317,    45},
01217  {   176,   195,     8}, {   104,   -59,   -94},
01218  {   177,    53,   192}, {   -34,  -127,   152},
01219  {   570,   277,   -34}, {   -67,  -329,  -639},
01220  {  -157,  -272,   462}, {  -177,  -462,   198},
01221  {   322,   179,   115}, {  -386,   171,    19},
01222  {    19,   -12,   195}, {  -120,  -252,   201},
01223  {   304,    36,  -336}, {  -128,  -221,  -380},
01224  {   171,  -185,   296}, {  -242,  -312,    23},
01225  {   198,    39,    16}, {    -3,  -177,  -111},
01226  {   111,   -93,    76}, {   -92,  -223,     4},
01227  {   177,   406,   -44}, {  -168,   380,  -149},
01228  {    -4,   273,   331}, {  -420,   513,   277},
01229  {    21,   247,    47}, {   -58,   131,    -2},
01230  {    -3,   134,   180}, {  -145,    40,   175},
01231  {   189,    74,  -145}, {   -27,   -45,  -325},
01232  {   370,  -114,   -21}, {   -83,  -415,  -173},
01233  {    77,    95,   -51}, {   -40,   -30,   -67},
01234  {    71,    88,    86}, {   -35,   -98,    14},
01235  {    69,   197,  -334}, {  -196,    79,  -231},
01236  {  -348,  -137,   218}, {  -352,   -89,   -85},
01237  {    47,   201,  -130}, {  -165,    37,   -15},
01238  {   -43,     3,    86}, {  -161,  -108,    79},
01239  {    83,    21,  -237}, {   -81,  -149,  -238},
01240  {   150,  -186,  -251}, {  -186,  -249,  -162},
01241  {   -19,    66,  -139}, {   -26,   -50,  -181},
01242  {    24,    11,     0}, {  -130,  -105,   -98}
01243 };
01244 
01245 static const int16_t dico22_isf[128][3] = {
01246  {  -127,   310,    42}, {  -242,   197,     5},
01247  {  -151,    84,   -17}, {  -214,   127,  -149},
01248  {  -247,  -131,   159}, {  -268,  -267,   -95},
01249  {  -217,     1,   -79}, {  -271,   -80,  -185},
01250  {   -45,   436,   159}, {   165,   199,   391},
01251  {   -33,    81,   187}, {   -66,   -42,   355},
01252  {  -298,   -57,   343}, {  -108,  -537,   226},
01253  {  -144,   -23,   193}, {   176,  -402,    87},
01254  {    53,   296,    25}, {   -84,   253,  -104},
01255  {   -58,   105,  -126}, {  -169,   174,  -314},
01256  {   -48,    44,  -294}, {  -164,  -417,  -242},
01257  {  -139,     3,  -194}, {  -155,  -207,  -211},
01258  {   119,   322,   213}, {   333,    50,   380},
01259  {   237,   247,    -2}, {   466,   -16,   201},
01260  {   238,  -255,  -107}, {    67,  -440,  -149},
01261  {   122,   -88,  -139}, {    88,  -247,   -73},
01262  {   -41,   231,   167}, {   -62,   155,    16},
01263  {   -65,    16,    77}, {   -68,    -2,   -63},
01264  {  -151,  -300,   160}, {   -18,  -333,    54},
01265  {   -56,   -94,     5}, {     2,  -190,    14},
01266  {    92,   148,   209}, {   108,     9,   272},
01267  {   108,    35,   110}, {   142,   -85,   145},
01268  {    47,  -157,   279}, {     3,  -320,   246},
01269  {    43,   -72,    68}, {    86,  -217,   135},
01270  {    36,   140,    79}, {    56,   175,   -49},
01271  {    26,    45,     3}, {    73,    55,  -101},
01272  {   109,  -183,  -242}, {    -4,  -283,  -242},
01273  {    48,   -68,   -48}, {    -6,  -153,  -122},
01274  {   161,   196,    96}, {   232,    80,   190},
01275  {   165,    97,    11}, {   258,   -31,    71},
01276  {   267,   -77,   -91}, {   311,  -209,    87},
01277  {   152,   -14,   -22}, {   150,  -149,     9},
01278  {  -324,   557,   187}, {  -384,   307,    46},
01279  {  -251,    27,    77}, {  -365,    77,   -52},
01280  {  -482,   -84,   160}, {  -424,  -515,   -64},
01281  {  -294,  -120,    -4}, {  -476,  -116,  -109},
01282  {   -97,   318,   365}, {   106,   627,   445},
01283  {  -190,   120,   287}, {  -146,    65,   619},
01284  {  -427,   242,   363}, {  -361,  -371,   432},
01285  {  -347,   102,   168}, {  -629,   195,   -14},
01286  {   -65,   476,   -47}, {  -297,   320,  -168},
01287  {   -55,   356,  -264}, {  -391,    82,  -286},
01288  {   -51,   -31,  -556}, {  -178,  -399,  -586},
01289  {  -205,   -49,  -360}, {  -343,  -238,  -337},
01290  {   220,   457,    58}, {   561,   467,   259},
01291  {   340,   270,  -168}, {   450,    77,  -280},
01292  {    60,   167,  -413}, {   133,  -252,  -492},
01293  {   216,   157,  -290}, {   282,     0,  -495},
01294  {  -226,   293,   183}, {  -157,   135,   122},
01295  {  -158,   -59,    39}, {  -133,  -118,   -97},
01296  {  -332,  -309,   113}, {  -160,  -425,    -6},
01297  {  -149,  -211,    24}, {   -80,  -277,   -90},
01298  {   -11,   125,   338}, {   130,   -71,   465},
01299  {     5,   -45,   184}, {   237,   -95,   253},
01300  {  -139,  -197,   297}, {   -19,  -300,   511},
01301  {   -63,  -152,   139}, {   250,  -289,   336},
01302  {   124,   339,  -150}, {    34,   176,  -208},
01303  {   171,   166,  -116}, {    94,    38,  -229},
01304  {    75,   -65,  -339}, {   -78,  -205,  -385},
01305  {     0,   -30,  -163}, {   -56,  -110,  -242},
01306  {   321,   244,   194}, {   505,   238,    -1},
01307  {   317,   116,    65}, {   309,    88,   -74},
01308  {   452,   -51,   -50}, {   334,  -217,  -290},
01309  {   211,    41,  -152}, {   238,   -55,  -260}
01310 };
01311 
01312 static const int16_t dico23_isf[128][3] = {
01313  {   -10,   151,   359}, {   136,   298,   223},
01314  {   255,  -104,   290}, {   423,     6,   183},
01315  {  -270,  -269,   -98}, {   -52,   -82,    13},
01316  {   -82,  -274,   -97}, {    90,  -246,   -72},
01317  {  -299,   -70,   421}, {   -88,   365,   430},
01318  {   187,  -318,   381}, {   380,    37,   488},
01319  {  -373,  -316,    79}, {  -308,  -101,     5},
01320  {  -135,  -451,     8}, {    72,  -421,  -154},
01321  {   180,   170,  -121}, {    62,   177,   -40},
01322  {   326,    80,  -105}, {   248,   263,    -5},
01323  {  -168,  -181,  -221}, {    -2,   -23,  -158},
01324  {   -14,  -149,  -121}, {   119,   -91,  -147},
01325  {   119,   332,  -153}, {    49,   303,    34},
01326  {   442,   -55,   -69}, {   217,   454,    58},
01327  {  -359,  -187,  -375}, {   -42,    50,  -274},
01328  {    -8,  -267,  -249}, {    85,   -86,  -346},
01329  {   -77,   -40,   345}, {    89,   134,   219},
01330  {   156,   -80,   160}, {   108,    40,   116},
01331  {  -158,  -206,    29}, {     5,   -32,   175},
01332  {   -65,  -158,   146}, {    55,   -78,    73},
01333  {  -114,  -222,   353}, {   -47,    81,   211},
01334  {    49,  -151,   268}, {   105,     4,   302},
01335  {  -263,  -132,   183}, {  -151,   -28,   201},
01336  {  -177,  -307,   166}, {   101,  -221,   130},
01337  {    74,    58,   -98}, {    32,    44,    13},
01338  {   194,    30,  -142}, {   170,    96,     8},
01339  {  -136,  -119,   -91}, {   -65,     8,   -55},
01340  {     3,  -188,    12}, {    45,   -63,   -49},
01341  {   149,   -21,   -19}, {    24,   144,    95},
01342  {   254,   -22,    60}, {   161,   196,    96},
01343  {  -158,   -61,    48}, {   -70,    33,    82},
01344  {   -23,  -321,    58}, {   155,  -147,     5},
01345  {  -364,   328,    77}, {   -21,   453,   173},
01346  {  -108,    82,   630}, {   367,   263,   208},
01347  {  -300,   -62,  -176}, {  -205,   143,  -158},
01348  {  -169,  -410,  -264}, {   257,  -269,  -100},
01349  {  -636,   289,    -2}, {  -292,   627,   173},
01350  {  -382,  -363,   387}, {   248,   524,   447},
01351  {  -521,  -111,  -107}, {  -395,   118,  -274},
01352  {  -343,  -680,  -125}, {  -172,  -447,  -663},
01353  {    75,   148,  -367}, {   -79,   263,   -94},
01354  {   249,   148,  -286}, {   380,   271,  -162},
01355  {  -142,    -4,  -186}, {   -57,   111,  -125},
01356  {   -35,  -108,  -254}, {   100,    29,  -242},
01357  {   -80,   303,  -264}, {   -78,   464,   -57},
01358  {   248,   -22,  -494}, {   661,   662,    44},
01359  {  -193,   -40,  -330}, {  -178,   145,  -337},
01360  {   -90,  -199,  -400}, {   -40,   -23,  -498},
01361  {  -192,   114,   315}, {   -41,   244,   190},
01362  {    88,   -97,   485}, {   241,    80,   212},
01363  {  -246,    40,    87}, {  -156,   147,   134},
01364  {    -2,  -334,   239}, {   308,  -203,   110},
01365  {  -459,   251,   422}, {  -218,   310,   228},
01366  {   -86,  -346,   654}, {   184,   175,   425},
01367  {  -481,   -63,   169}, {  -349,   117,   188},
01368  {  -125,  -560,   310}, {   158,  -416,    94},
01369  {    46,   171,  -192}, {   -63,   157,    14},
01370  {   256,   -35,  -271}, {   322,   123,    53},
01371  {  -214,     4,   -76}, {  -156,    86,   -18},
01372  {   128,  -197,  -232}, {   265,   -90,   -98},
01373  {  -308,   332,  -145}, {  -131,   308,    58},
01374  {   509,    59,  -339}, {   562,   196,   -14},
01375  {  -378,   100,   -47}, {  -234,   202,     1},
01376  {   104,  -270,  -493}, {   319,  -210,  -325}
01377 };
01378 
01379 static const int16_t dico24_isf[32][3] = {
01380  {   -79,   -89,    -4}, {  -171,    77,  -211},
01381  {   160,  -193,    98}, {   120,  -103,   323},
01382  {    32,   -22,  -129}, {    72,    78,  -268},
01383  {   182,   -76,   -66}, {   309,    99,  -145},
01384  {  -229,  -157,   -84}, {  -383,    98,   -71},
01385  {   -90,  -352,    12}, {  -284,  -178,   178},
01386  {   -65,  -125,  -166}, {   -87,  -175,  -351},
01387  {    42,  -198,   -48}, {   154,  -140,  -243},
01388  {   -77,    18,   108}, {   -39,   355,    91},
01389  {    87,     8,   155}, {    -4,   158,   239},
01390  {   128,    95,   -54}, {     7,   246,  -124},
01391  {   258,    15,    89}, {   206,   216,    98},
01392  {  -201,     9,    18}, {  -312,   233,   204},
01393  {   -39,  -174,   155}, {  -144,    -9,   284},
01394  {   -57,    70,   -69}, {  -157,   187,    18},
01395  {    54,   -30,    23}, {    24,   135,    55}
01396 };
01397 
01398 static const int16_t dico25_isf[32][4] = {
01399  {   169,   142,  -119,   115}, {   206,   -20,    94,   226},
01400  {  -106,   313,   -21,    16}, {   -62,   161,    71,   255},
01401  {   -89,   101,  -185,   125}, {    72,   -30,  -201,   344},
01402  {  -258,    33,    -8,    81}, {  -104,  -154,    72,   296},
01403  {   144,   -68,  -268,   -25}, {    81,   -78,   -87,   106},
01404  {    22,   155,  -186,  -119}, {   -46,   -28,    27,    91},
01405  {  -114,   -37,  -175,   -33}, {   -94,  -222,  -189,   122},
01406  {  -132,  -119,  -191,  -270}, {  -172,  -173,    18,   -43},
01407  {   279,   135,   -42,  -128}, {   187,   -86,   229,  -138},
01408  {   159,   240,   140,    46}, {    69,    25,   227,    77},
01409  {    21,   115,    13,     8}, {    68,  -248,   126,    81},
01410  {  -150,   137,   207,    -9}, {  -154,  -133,   289,    67},
01411  {   143,   -37,   -86,  -326}, {   180,   -32,    19,   -23},
01412  {    26,   168,   116,  -233}, {   -32,   -26,   118,   -78},
01413  {     3,    -8,   -45,  -115}, {    57,  -215,   -54,   -83},
01414  {  -209,   112,   -22,  -167}, {   -91,  -151,   168,  -262}
01415 };
01416 
01417 static const int16_t dico21_isf_36b[128][5] = {
01418  {   -52,   -96,   212,   315,   -73}, {    82,  -204,   363,   136,  -197},
01419  {  -126,  -331,   183,   218,   143}, {   -49,   -41,   557,   230,    72},
01420  {     2,   -73,   163,   377,   221}, {   133,   111,   278,   215,  -110},
01421  {  -102,   -20,   284,   113,   273}, {    84,   319,   290,    18,    85},
01422  {   -25,    -5,   125,   132,  -204}, {   -38,    -5,   286,    -9,  -356},
01423  {  -140,  -256,    92,   117,  -189}, {  -144,   191,   313,    51,   -98},
01424  {   167,   -10,    44,   247,    36}, {   381,   197,   238,    74,     6},
01425  {    38,  -408,    29,    -3,   -85}, {    92,   266,   157,   -25,  -200},
01426  {   161,  -121,    70,    84,  -140}, {   -16,   -86,   112,   -94,  -189},
01427  {  -269,  -270,   351,   107,   -24}, {   -68,   -67,   492,  -103,  -155},
01428  {   -53,  -131,    62,   122,    10}, {   135,    84,   283,   -55,  -120},
01429  {   -12,  -219,   331,   -81,   167}, {   220,  -136,   147,  -172,   -42},
01430  {   140,   -95,  -109,   -88,  -194}, {     0,    -2,    -4,   -33,  -381},
01431  {   -66,  -217,   152,  -186,  -402}, {   244,   108,   156,  -140,  -395},
01432  {   113,  -136,  -196,   110,   -24}, {   214,   118,    11,   -64,  -131},
01433  {  -110,  -286,    -6,  -332,    16}, {    94,    97,    79,  -291,  -205},
01434  {    -5,   -39,   -20,   252,   -96}, {    76,   174,   101,   163,    61},
01435  {   -69,  -239,   -55,   399,     6}, {  -115,   319,   164,   275,   196},
01436  {   -15,    36,   -47,   331,   121}, {   226,   209,   271,   325,   184},
01437  {    13,   -80,  -218,   471,   353}, {   288,   378,    16,   -51,   251},
01438  {   174,   116,    52,   149,  -279}, {   235,   276,    39,   120,   -48},
01439  {     0,  -108,  -108,   241,  -339}, {   -93,   534,    45,    33,   -87},
01440  {   194,   149,   -71,   405,   -44}, {   409,   370,    81,  -186,  -154},
01441  {    25,  -102,  -448,   124,  -173}, {    22,   408,  -110,  -310,  -214},
01442  {   -26,    23,   -83,   114,    14}, {  -110,   164,    52,   223,   -82},
01443  {    37,   -25,  -263,   306,   -15}, {  -466,   415,   292,   165,   -18},
01444  {    29,   -19,  -171,   155,   182}, {   179,   144,   -27,   231,   258},
01445  {  -103,  -247,  -396,   238,   113}, {   375,  -154,  -109,    -4,   156},
01446  {    98,    85,  -292,    -5,  -124}, {   116,   139,  -116,   -98,  -294},
01447  {   -14,   -83,  -278,  -117,  -378}, {   106,    33,  -106,  -344,  -484},
01448  {   119,    17,  -412,   138,   166}, {   384,   101,  -204,    88,  -156},
01449  {  -121,  -284,  -300,    -1,  -166}, {   280,    33,  -152,  -313,   -81},
01450  {   -37,    22,   229,   153,    37}, {   -60,   -83,   236,    -8,   -41},
01451  {  -169,  -228,   126,   -20,   363}, {  -235,    17,   364,  -156,   156},
01452  {   -25,   -30,    72,   144,   156}, {   153,   -26,   256,    97,   144},
01453  {   -21,   -37,    48,   -65,   250}, {    63,    77,   273,  -128,   124},
01454  {  -129,   -26,    40,     9,  -115}, {    -6,    82,    38,   -90,  -182},
01455  {  -336,   -13,    28,   158,    91}, {   -30,   241,   137,  -170,   -17},
01456  {   146,    14,   -11,    33,    61}, {   192,   197,    54,   -84,    85},
01457  {    23,  -200,   -78,   -29,   140}, {   122,   237,   106,  -341,   136},
01458  {   -57,  -142,   -85,   -16,   -74}, {   -59,   -90,    -8,  -187,   -20},
01459  {  -211,  -267,   216,  -179,  -110}, {   -50,    -7,   220,  -267,   -70},
01460  {   -57,   -42,   -17,   -15,    71}, {    32,    21,    63,  -137,    33},
01461  {  -137,  -175,   104,   -68,    97}, {   -67,   -43,   133,  -301,   221},
01462  {  -116,  -200,   -81,   -92,  -272}, {   -64,   -41,   -54,  -244,  -220},
01463  {  -287,  -242,   -50,   -87,   -89}, {  -245,   236,   102,  -166,  -295},
01464  {    66,    24,  -162,   -71,    95}, {    66,   136,   -90,  -220,   -36},
01465  {   -98,  -161,  -222,  -188,    29}, {   -18,    18,   -19,  -415,     9},
01466  {    49,    61,   100,    39,   -56}, {  -111,    82,   135,   -31,    52},
01467  {   -90,  -153,   -93,   189,   182}, {  -214,   295,   119,   -74,   284},
01468  {     2,   137,    37,    47,   182}, {    92,   117,   184,   -53,   373},
01469  {   -21,   -14,   -35,   136,   391}, {   146,   129,  -164,   -28,   333},
01470  {    92,    80,   -84,   100,  -134}, {    -8,   217,   -32,     3,   -47},
01471  {  -151,   251,  -215,   142,    92}, {  -224,   310,  -172,  -275,    98},
01472  {   159,   155,  -177,   112,    53}, {   205,    27,     8,  -240,   192},
01473  {   169,   120,  -319,  -201,   106}, {    11,    36,   -86,  -237,   455},
01474  {  -109,  -154,  -163,   174,   -55}, {   -38,    32,  -101,   -78,   -59},
01475  {  -205,  -321,   -97,    69,    79}, {  -310,    44,    18,  -185,    34},
01476  {  -115,   -20,  -148,   -39,   203}, {   -29,   154,   -30,  -158,   166},
01477  {   -45,  -131,  -317,   -24,   363}, {  -165,  -205,  -112,  -222,   265},
01478  {   -32,   -44,  -150,    54,  -193}, {    -6,   -38,  -255,  -169,  -115},
01479  {  -266,    87,  -189,   -36,  -169}, {   -60,   -87,  -266,  -436,  -170},
01480  {   -68,   -81,  -278,    24,    38}, {   -23,   -19,  -155,  -256,   141},
01481  {   -61,  -226,  -565,  -175,    71}, {     9,   -29,  -237,  -515,   263}
01482 };
01483 
01484 static const int16_t dico22_isf_36b[128][4] = {
01485  {  -298,    -6,    95,    31}, {  -213,   -87,  -122,   261},
01486  {     4,   -49,   208,    14}, {  -129,  -110,    30,   118},
01487  {  -214,   258,   110,  -235}, {   -41,   -18,  -126,   120},
01488  {   103,    65,   127,   -37}, {   126,   -36,   -24,    25},
01489  {  -138,   -67,  -278,  -186}, {  -164,  -194,  -201,    78},
01490  {  -211,   -87,   -51,  -221}, {  -174,   -79,   -94,   -39},
01491  {    23,    -6,  -157,  -240}, {    22,  -110,  -153,   -68},
01492  {   148,    -5,    -2,  -149}, {    -1,  -135,   -39,  -179},
01493  {    68,   360,  -117,   -15}, {   137,    47,  -278,   146},
01494  {   136,   260,   135,    65}, {    61,   116,   -45,    97},
01495  {   231,   379,    87,  -120}, {   338,   177,  -272,     3},
01496  {   266,   156,    28,   -69}, {   260,    84,   -85,    86},
01497  {  -266,   154,  -256,  -182}, {   -17,   -65,  -304,    -6},
01498  {   -40,   175,  -151,  -180}, {   -27,    27,   -87,   -63},
01499  {   121,   114,  -166,  -469}, {   159,   -66,  -323,  -231},
01500  {   214,   152,  -141,  -212}, {   137,    36,  -184,   -51},
01501  {  -282,  -237,    40,    10}, {   -48,  -235,   -37,   251},
01502  {   -54,  -323,   136,    29}, {   -88,  -174,   213,   198},
01503  {  -390,    99,   -63,  -375}, {   107,  -169,  -164,   424},
01504  {    69,  -111,   141,  -167}, {    74,  -129,    65,   144},
01505  {  -353,  -207,  -205,  -109}, {  -160,  -386,  -355,    98},
01506  {  -176,  -493,   -20,  -143}, {  -252,  -432,    -2,   216},
01507  {   -90,  -174,  -168,  -411}, {    13,  -284,  -229,  -160},
01508  {   -87,  -279,    34,  -251}, {   -75,  -263,   -58,   -42},
01509  {   420,    53,  -211,  -358}, {   384,   -35,  -374,   396},
01510  {    68,  -228,   323,    -2}, {   167,  -307,   192,   194},
01511  {   459,   329,    -5,  -332}, {   375,    79,    -7,   313},
01512  {   282,  -124,   200,   -92}, {   271,  -162,   -70,   180},
01513  {  -157,  -298,  -514,  -309}, {    58,  -163,  -546,    18},
01514  {   124,  -364,   167,  -238}, {    83,  -411,  -117,    96},
01515  {   140,  -112,  -388,  -624}, {   259,  -133,  -317,    41},
01516  {   163,  -130,   -64,  -334}, {   226,  -165,  -124,  -110},
01517  {  -466,   -61,     6,   229}, {  -153,   205,  -145,   242},
01518  {  -159,    48,   195,   148}, {   -58,    28,    31,   279},
01519  {  -303,   185,   279,    -4}, {   -61,   197,    59,    86},
01520  {  -114,   123,   168,   -52}, {    35,    36,   100,   126},
01521  {  -407,   102,   -77,   -40}, {  -338,    -1,  -342,   156},
01522  {  -179,   105,   -34,   -97}, {  -185,    84,   -35,   108},
01523  {  -133,   107,   -91,  -357}, {  -180,    54,  -229,    24},
01524  {   -44,    47,    47,  -182}, {   -66,    13,    45,     4},
01525  {  -339,   251,    64,   226}, {   -42,   101,  -350,   275},
01526  {   -99,   398,   142,   121}, {   111,    12,  -102,   260},
01527  {     0,   505,   260,   -94}, {   161,   285,   -96,   224},
01528  {    -4,   206,   314,    33}, {   167,   139,    88,   204},
01529  {  -235,   316,   -60,   -25}, {    -8,  -150,  -312,   201},
01530  {   -36,   292,    61,  -104}, {   -40,   174,  -162,    42},
01531  {   -21,   402,   -29,  -351}, {    21,   152,  -360,   -93},
01532  {    57,   191,   212,  -196}, {    76,   158,   -21,   -69},
01533  {  -328,  -185,   331,   119}, {   -53,   285,    56,   337},
01534  {  -107,   -24,   405,    29}, {   -18,   137,   272,   277},
01535  {  -255,    22,   173,  -191}, {   295,   322,   325,   302},
01536  {    21,   -27,   332,  -178}, {   119,    13,   271,   129},
01537  {  -455,  -180,   116,  -191}, {  -227,    62,  -148,   524},
01538  {  -176,  -287,   282,  -157}, {  -243,    13,   199,   430},
01539  {   -59,   -49,   115,  -365}, {    72,  -172,  -137,    93},
01540  {  -138,  -126,   141,   -84}, {     5,  -124,    38,   -20},
01541  {  -258,   311,   601,   213}, {    94,   130,   -61,   502},
01542  {    -1,  -157,   485,   313}, {   146,   -74,   158,   345},
01543  {   276,   135,   280,   -57}, {   490,   252,    99,    43},
01544  {   267,   -74,   429,   105}, {   278,   -23,   119,    94},
01545  {  -542,   488,   257,  -115}, {   -84,  -244,  -438,   478},
01546  {  -113,  -545,   387,   101}, {   -95,  -306,   111,   498},
01547  {    95,   166,    22,  -301}, {   420,   -15,   -58,   -78},
01548  {   270,    29,   122,  -282}, {   160,  -240,    50,   -38}
01549 };
01550 
01551 static const int16_t dico23_isf_36b[64][7] = {
01552  {    81,   -18,    68,   -27,  -122,  -280,    -4},
01553  {    45,  -177,   209,   -30,  -136,   -74,   131},
01554  {   -44,   101,   -75,   -88,   -48,  -137,   -54},
01555  {  -245,   -28,    63,   -18,  -112,  -103,    58},
01556  {   -79,    -6,   220,   -65,   114,   -35,   -50},
01557  {   109,   -65,   143,  -114,   129,    76,   125},
01558  {   166,    90,   -61,  -242,   186,   -74,   -43},
01559  {   -46,   -92,    49,  -227,    24,  -155,    39},
01560  {    67,    85,    99,   -42,    53,  -184,  -281},
01561  {   142,  -122,     0,    21,  -142,   -15,   -17},
01562  {   223,    92,   -21,   -48,   -82,   -14,  -167},
01563  {    51,   -37,  -243,   -30,   -90,    18,   -56},
01564  {    54,   105,    74,    86,    69,    13,  -101},
01565  {   196,    72,   -89,    43,    65,    19,    39},
01566  {   121,    34,   131,   -82,    25,   213,  -156},
01567  {   101,  -102,  -136,   -21,    57,   214,    22},
01568  {    36,  -124,   205,   204,    58,  -156,   -83},
01569  {    83,  -117,   137,   137,    85,   116,    44},
01570  {   -92,  -148,   -68,    11,  -102,  -197,  -220},
01571  {   -76,  -185,   -58,   132,   -26,  -183,    85},
01572  {    -7,   -31,    -2,    23,   205,  -151,    10},
01573  {   -27,   -37,    -5,   -18,   292,   131,     1},
01574  {   117,  -168,     9,   -93,    80,   -59,  -125},
01575  {  -182,  -244,    98,   -24,   135,   -22,    94},
01576  {   221,    97,   106,    42,    43,  -160,    83},
01577  {    25,   -64,   -21,     6,    14,   -15,   154},
01578  {   126,    15,  -140,   150,   -10,  -207,  -114},
01579  {    79,   -63,  -211,   -70,   -28,  -217,   165},
01580  {    46,    38,   -22,   281,   132,   -62,   109},
01581  {   112,    54,  -112,   -93,   208,    27,   296},
01582  {   115,    10,  -147,    41,   216,    42,  -276},
01583  {    50,  -115,  -254,   167,   117,    -2,    61},
01584  {    17,   144,    34,   -72,  -186,  -150,   272},
01585  {   -29,   -66,   -89,   -95,  -149,   129,   251},
01586  {   122,     0,   -50,  -234,   -91,    36,    26},
01587  {  -105,  -102,   -88,  -121,  -236,    -7,   -11},
01588  {  -204,   109,     5,  -191,   105,   -15,   163},
01589  {   -80,    32,   -24,  -209,    41,   294,    70},
01590  {  -106,   -94,  -204,  -118,   120,   -50,   -37},
01591  {   -82,  -241,    46,  -131,   -29,   150,   -55},
01592  {    33,   155,   120,   -89,    -8,     7,    62},
01593  {   213,    82,    61,    18,  -161,   144,   152},
01594  {    30,   131,    65,   -87,  -255,   -17,  -107},
01595  {    -8,    85,   -64,    51,  -162,   223,   -53},
01596  {  -134,   261,    69,   -56,   218,    72,  -111},
01597  {     2,   155,  -113,   -87,    49,    85,   -28},
01598  {  -163,    42,    -1,  -196,     7,    39,  -245},
01599  {    14,  -137,   -79,    11,  -160,   202,  -293},
01600  {   -94,    33,   208,   100,    56,   -44,   326},
01601  {   -78,   -41,   232,    13,  -142,   227,    80},
01602  {   -16,   -87,   201,    33,  -133,    15,  -183},
01603  {   -58,  -192,   -47,   184,  -128,   133,    99},
01604  {  -205,    11,  -155,    78,    52,    72,   141},
01605  {  -246,    26,    99,   151,    59,   115,   -64},
01606  {   -79,   -47,   -16,   -14,     6,    47,   -43},
01607  {   -72,  -178,   -27,   162,   112,    43,  -174},
01608  {  -175,   238,   186,    71,   -54,  -188,   -76},
01609  {  -225,   233,    39,   -39,  -158,   122,    44},
01610  {   -26,    43,    84,   130,   -93,   -51,    22},
01611  {     3,    92,  -150,   136,  -182,   -57,    97},
01612  {  -131,   179,   -78,    80,    91,  -165,    90},
01613  {    -2,   148,    15,   130,    65,   175,   117},
01614  {  -138,   114,  -137,   132,     3,   -10,  -186},
01615  {   140,    -4,   -37,   254,   -62,    92,  -109}
01616 };
01617 
01619 static const int16_t isf_mean[LP_ORDER] = {
01620    738,  1326,  2336,  3578,  4596,  5662,  6711,  7730,
01621   8750,  9753, 10705, 11728, 12833, 13971, 15043,  4037
01622 };
01623 
01625 static const int16_t isf_init[LP_ORDER] = {
01626   1024,  2048,  3072,  4096,  5120,  6144,  7168, 8192,
01627   9216, 10240, 11264, 12288, 13312, 14336, 15360, 3840
01628 };
01629 
01631 static const float isfp_inter[4] = { 0.45, 0.8, 0.96, 1.0 };
01632 
01635 static const float ac_inter[65] = {
01636      9.400024e-01,
01637      8.563843e-01,  6.322632e-01,  3.375854e-01,  5.908203e-02,
01638     -1.310425e-01, -1.994019e-01, -1.585693e-01, -5.633545e-02,
01639      4.760742e-02,  1.067505e-01,  1.036987e-01,  5.206299e-02,
01640     -1.519775e-02, -6.372070e-02, -7.366943e-02, -4.650879e-02,
01641     -9.765625e-04,  3.820801e-02,  5.316162e-02,  4.003906e-02,
01642      9.338379e-03, -2.166748e-02, -3.778076e-02, -3.320312e-02,
01643     -1.300049e-02,  1.068115e-02,  2.587891e-02,  2.630615e-02,
01644      1.379395e-02, -3.662109e-03, -1.678467e-02, -1.983643e-02,
01645     -1.275635e-02, -5.493164e-04,  1.007080e-02,  1.409912e-02,
01646      1.068115e-02,  2.624512e-03, -5.371094e-03, -9.338379e-03,
01647     -8.117676e-03, -3.173828e-03,  2.319336e-03,  5.615234e-03,
01648      5.554199e-03,  2.868652e-03, -6.103516e-04, -2.990723e-03,
01649     -3.356934e-03, -2.014160e-03, -1.220703e-04,  1.342773e-03,
01650      1.708984e-03,  1.159668e-03,  2.441406e-04, -4.272461e-04,
01651     -6.103516e-04, -4.272461e-04, -1.220703e-04,  6.103516e-05,
01652      1.220703e-04,  6.103516e-05,  0.000000e+00,  0.000000e+00
01653 };
01654 
01656 static const uint8_t pulses_nb_per_mode_tr[][4] = {
01657     {1, 1, 0, 0}, {1, 1, 1, 1}, {2, 2, 2, 2},
01658     {3, 3, 2, 2}, {3, 3, 3, 3}, {4, 4, 4, 4},
01659     {5, 5, 4, 4}, {6, 6, 6, 6}, {6, 6, 6, 6}
01660 };
01661 
01663 static const int16_t qua_gain_6b[64][2] = {
01664     {  1566,  1332},    {  1577,  3557},
01665     {  3071,  6490},    {  4193, 10163},
01666     {  4496,  2534},    {  5019,  4488},
01667     {  5586, 15614},    {  5725,  1422},
01668     {  6453,   580},    {  6724,  6831},
01669     {  7657,  3527},    {  8072,  2099},
01670     {  8232,  5319},    {  8827,  8775},
01671     {  9740,  2868},    {  9856,  1465},
01672     { 10087, 12488},    { 10241,  4453},
01673     { 10859,  6618},    { 11321,  3587},
01674     { 11417,  1800},    { 11643,  2428},
01675     { 11718,   988},    { 12312,  5093},
01676     { 12523,  8413},    { 12574, 26214},
01677     { 12601,  3396},    { 13172,  1623},
01678     { 13285,  2423},    { 13418,  6087},
01679     { 13459, 12810},    { 13656,  3607},
01680     { 14111,  4521},    { 14144,  1229},
01681     { 14425,  1871},    { 14431,  7234},
01682     { 14445,  2834},    { 14628, 10036},
01683     { 14860, 17496},    { 15161,  3629},
01684     { 15209,  5819},    { 15299,  2256},
01685     { 15518,  4722},    { 15663,  1060},
01686     { 15759,  7972},    { 15939, 11964},
01687     { 16020,  2996},    { 16086,  1707},
01688     { 16521,  4254},    { 16576,  6224},
01689     { 16894,  2380},    { 16906,   681},
01690     { 17213,  8406},    { 17610,  3418},
01691     { 17895,  5269},    { 18168, 11748},
01692     { 18230,  1575},    { 18607, 32767},
01693     { 18728, 21684},    { 19137,  2543},
01694     { 19422,  6577},    { 19446,  4097},
01695     { 19450,  9056},    { 20371, 14885}
01696 };
01697 
01698 static const int16_t qua_gain_7b[128][2] = {
01699     {   204,   441},    {   464,  1977},
01700     {   869,  1077},    {  1072,  3062},
01701     {  1281,  4759},    {  1647,  1539},
01702     {  1845,  7020},    {  1853,   634},
01703     {  1995,  2336},    {  2351, 15400},
01704     {  2661,  1165},    {  2702,  3900},
01705     {  2710, 10133},    {  3195,  1752},
01706     {  3498,  2624},    {  3663,   849},
01707     {  3984,  5697},    {  4214,  3399},
01708     {  4415,  1304},    {  4695,  2056},
01709     {  5376,  4558},    {  5386,   676},
01710     {  5518, 23554},    {  5567,  7794},
01711     {  5644,  3061},    {  5672,  1513},
01712     {  5957,  2338},    {  6533,  1060},
01713     {  6804,  5998},    {  6820,  1767},
01714     {  6937,  3837},    {  7277,   414},
01715     {  7305,  2665},    {  7466, 11304},
01716     {  7942,   794},    {  8007,  1982},
01717     {  8007,  1366},    {  8326,  3105},
01718     {  8336,  4810},    {  8708,  7954},
01719     {  8989,  2279},    {  9031,  1055},
01720     {  9247,  3568},    {  9283,  1631},
01721     {  9654,  6311},    {  9811,  2605},
01722     { 10120,   683},    { 10143,  4179},
01723     { 10245,  1946},    { 10335,  1218},
01724     { 10468,  9960},    { 10651,  3000},
01725     { 10951,  1530},    { 10969,  5290},
01726     { 11203,  2305},    { 11325,  3562},
01727     { 11771,  6754},    { 11839,  1849},
01728     { 11941,  4495},    { 11954,  1298},
01729     { 11975, 15223},    { 11977,   883},
01730     { 11986,  2842},    { 12438,  2141},
01731     { 12593,  3665},    { 12636,  8367},
01732     { 12658,  1594},    { 12886,  2628},
01733     { 12984,  4942},    { 13146,  1115},
01734     { 13224,   524},    { 13341,  3163},
01735     { 13399,  1923},    { 13549,  5961},
01736     { 13606,  1401},    { 13655,  2399},
01737     { 13782,  3909},    { 13868, 10923},
01738     { 14226,  1723},    { 14232,  2939},
01739     { 14278,  7528},    { 14439,  4598},
01740     { 14451,   984},    { 14458,  2265},
01741     { 14792,  1403},    { 14818,  3445},
01742     { 14899,  5709},    { 15017, 15362},
01743     { 15048,  1946},    { 15069,  2655},
01744     { 15405,  9591},    { 15405,  4079},
01745     { 15570,  7183},    { 15687,  2286},
01746     { 15691,  1624},    { 15699,  3068},
01747     { 15772,  5149},    { 15868,  1205},
01748     { 15970,   696},    { 16249,  3584},
01749     { 16338,  1917},    { 16424,  2560},
01750     { 16483,  4438},    { 16529,  6410},
01751     { 16620, 11966},    { 16839,  8780},
01752     { 17030,  3050},    { 17033, 18325},
01753     { 17092,  1568},    { 17123,  5197},
01754     { 17351,  2113},    { 17374,   980},
01755     { 17566, 26214},    { 17609,  3912},
01756     { 17639, 32767},    { 18151,  7871},
01757     { 18197,  2516},    { 18202,  5649},
01758     { 18679,  3283},    { 18930,  1370},
01759     { 19271, 13757},    { 19317,  4120},
01760     { 19460,  1973},    { 19654, 10018},
01761     { 19764,  6792},    { 19912,  5135},
01762     { 20040,  2841},    { 21234, 19833}
01763 };
01764 
01766 static const float energy_pred_fac[4] = { 0.2, 0.3, 0.4, 0.5 };
01767 
01770 static const float ir_filter_str[64] = {
01771      6.159058e-01,  2.958069e-01,  9.979248e-02, -1.048889e-01,
01772      8.740234e-02, -1.599121e-01,  4.849243e-02, -4.141235e-02,
01773      1.831055e-02,  1.188049e-01, -4.568481e-02, -2.130127e-02,
01774      3.671265e-02, -1.601868e-01,  3.659058e-02,  1.639099e-01,
01775     -4.541016e-02, -2.151489e-02, -8.810425e-02,  6.030273e-02,
01776      2.740479e-02,  2.200317e-02, -1.182861e-01,  1.289978e-01,
01777     -1.560059e-01,  1.953125e-01, -3.149414e-02, -1.441956e-01,
01778      1.249084e-01, -1.328125e-01,  9.780884e-02,  6.500244e-02,
01779     -6.091309e-02, -5.599976e-02,  8.081055e-02, -5.450439e-02,
01780     -1.239014e-02,  1.748657e-02,  7.580566e-02, -1.101074e-01,
01781      9.579468e-02, -4.159546e-02, -7.830811e-02,  1.162109e-01,
01782     -1.950073e-02, -6.259155e-02, -1.651001e-02,  7.250977e-02,
01783      1.199951e-01, -1.911011e-01,  4.370117e-02, -1.098938e-01,
01784      1.492004e-01,  1.129150e-02,  1.730347e-02, -3.549194e-02,
01785     -8.709717e-02,  5.841064e-02,  1.190186e-03, -7.379150e-02,
01786      1.054077e-01,  9.078979e-02, -1.227112e-01,  1.047058e-01
01787 };
01788 
01789 static const float ir_filter_mid[64] = {
01790      7.354126e-01,  3.192139e-01, -1.606140e-01, -2.328491e-02,
01791      6.250000e-02, -2.828979e-02,  5.349731e-02, -1.014099e-01,
01792      6.750488e-02,  1.989746e-02, -6.549072e-02,  7.589722e-02,
01793     -1.080017e-01,  1.253967e-01, -6.430054e-02, -1.141357e-02,
01794     -1.910400e-02,  1.303101e-01, -1.673889e-01,  6.820679e-02,
01795      5.670166e-02, -8.450317e-02,  2.270508e-02,  3.479004e-02,
01796     -2.328491e-02, -4.928589e-02,  1.239014e-01, -1.395874e-01,
01797      9.100342e-02, -3.549194e-02,  2.230835e-02, -3.350830e-02,
01798      2.450562e-02,  5.096436e-03, -2.178955e-02,  1.849365e-02,
01799     -1.708984e-02,  1.950073e-02,  1.312256e-03, -5.389404e-02,
01800      9.851074e-02, -8.489990e-02,  2.029419e-02,  2.328491e-02,
01801      7.110596e-03, -6.109619e-02,  3.939819e-02,  5.709839e-02,
01802     -1.058960e-01,  3.149414e-02,  8.270264e-02, -1.232910e-01,
01803      1.105957e-01, -1.286011e-01,  1.614990e-01, -1.303101e-01,
01804      4.769897e-02,  3.295898e-03, -1.770020e-02,  5.010986e-02,
01805     -7.501221e-02,  2.920532e-02,  1.660156e-02,  7.751465e-02
01806 };
01807 
01808 static const float * const ir_filters_lookup[2] = {
01809     ir_filter_str, ir_filter_mid
01810 };
01811 
01813 static const float hpf_zeros[2]     = { -2.0, 1.0 };
01814 static const float hpf_31_poles[2]  = { -1.978881836, 0.979125977 };
01815 static const float hpf_31_gain      = 0.989501953;
01816 
01817 static const float hpf_400_poles[2] = { -1.787109375, 0.864257812 };
01818 static const float hpf_400_gain     = 0.893554687;
01819 
01822 static const float upsample_fir[4][24] = {
01823     { -6.103516e-05,  7.324219e-04, -2.014160e-03,  4.150391e-03,
01824       -7.263184e-03,  1.165771e-02, -1.776123e-02,  2.624512e-02,
01825       -3.869629e-02,  5.877686e-02, -9.863281e-02,  2.314453e-01,
01826        9.348755e-01, -1.523438e-01,  7.861328e-02, -4.937744e-02,
01827        3.308105e-02, -2.252197e-02,  1.507568e-02, -9.765625e-03,
01828        5.859375e-03, -3.173828e-03,  1.403809e-03, -3.662109e-04  },
01829     { -2.441406e-04,  1.464844e-03, -3.784180e-03,  7.568359e-03,
01830       -1.300049e-02,  2.062988e-02, -3.112793e-02,  4.589844e-02,
01831       -6.781006e-02,  1.042480e-01, -1.815186e-01,  5.016479e-01,
01832        7.548828e-01, -2.094727e-01,  1.148071e-01, -7.348633e-02,
01833        4.956055e-02, -3.369141e-02,  2.246094e-02, -1.434326e-02,
01834        8.483887e-03, -4.455566e-03,  1.831055e-03, -4.272461e-04  },
01835     { -4.272461e-04,  1.831055e-03, -4.455566e-03,  8.483887e-03,
01836       -1.434326e-02,  2.246094e-02, -3.369141e-02,  4.956055e-02,
01837       -7.348633e-02,  1.148071e-01, -2.094727e-01,  7.548828e-01,
01838        5.016479e-01, -1.815186e-01,  1.042480e-01, -6.781006e-02,
01839        4.589844e-02, -3.112793e-02,  2.062988e-02, -1.300049e-02,
01840        7.568359e-03, -3.784180e-03,  1.464844e-03, -2.441406e-04  },
01841     { -3.662109e-04,  1.403809e-03, -3.173828e-03,  5.859375e-03,
01842       -9.765625e-03,  1.507568e-02, -2.252197e-02,  3.308105e-02,
01843       -4.937744e-02,  7.861328e-02, -1.523438e-01,  9.348755e-01,
01844        2.314453e-01, -9.863281e-02,  5.877686e-02, -3.869629e-02,
01845        2.624512e-02, -1.776123e-02,  1.165771e-02, -7.263184e-03,
01846        4.150391e-03, -2.014160e-03,  7.324219e-04, -6.103516e-05  }
01847 };
01848 
01850 static const uint16_t qua_hb_gain[16] = {
01851    3624, 4673, 5597, 6479, 7425, 8378, 9324, 10264,
01852    11210, 12206, 13391, 14844, 16770, 19655, 24289, 32728
01853 };
01854 
01856 static const float bpf_6_7_coef[31] = { // band pass, 6kHz and 7kHz cutoffs
01857     -2.441406e-04,  3.585815e-04,  2.441406e-04,
01858     -2.059937e-04, -2.815248e-03,  8.560180e-03,
01859     -1.084137e-02,  0.000000e+00,  2.897645e-02,
01860     -6.774902e-02,  9.421540e-02, -8.380128e-02,
01861      2.706910e-02,  5.924987e-02, -1.373367e-01,
01862      1.687469e-01,
01863     -1.373367e-01,  5.924987e-02,  2.706910e-02,
01864     -8.380128e-02,  9.421540e-02, -6.774902e-02,
01865      2.897645e-02,  0.000000e+00, -1.084137e-02,
01866      8.560180e-03, -2.815248e-03, -2.059937e-04,
01867      2.441406e-04,  3.585815e-04, -2.441406e-04
01868 };
01869 
01870 static const float lpf_7_coef[31] = { // low pass, 7kHz cutoff
01871     -6.408691e-04,  1.434326e-03, -2.716064e-03,
01872      4.455566e-03, -6.195068e-03,  6.988525e-03,
01873     -5.401611e-03,  0.000000e+00,  1.022339e-02,
01874     -2.560425e-02,  4.531860e-02, -6.747437e-02,
01875      8.944702e-02, -1.080933e-01,  1.206360e-01,
01876      8.753052e-01,
01877      1.206360e-01, -1.080933e-01,  8.944702e-02,
01878     -6.747437e-02,  4.531860e-02, -2.560425e-02,
01879      1.022339e-02,  0.000000e+00, -5.401611e-03,
01880      6.988525e-03, -6.195068e-03,  4.455566e-03,
01881     -2.716064e-03,  1.434326e-03, -6.408691e-04
01882 };
01883 
01885 static const uint16_t cf_sizes_wb[] = {
01886     132, 177, 253, 285, 317, 365, 397, 461, 477,
01887     40 
01888 };
01889 
01890 #endif /* AVCODEC_AMRWBDATA_H */