forked from len0rd/rockbox
		
	
		
			
				
	
	
		
			96 lines
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***********************************************************************
 | |
| Copyright (c) 2006-2011, Skype Limited. All rights reserved.
 | |
| Redistribution and use in source and binary forms, with or without
 | |
| modification, are permitted provided that the following conditions
 | |
| are met:
 | |
| - Redistributions of source code must retain the above copyright notice,
 | |
| this list of conditions and the following disclaimer.
 | |
| - Redistributions in binary form must reproduce the above copyright
 | |
| notice, this list of conditions and the following disclaimer in the
 | |
| documentation and/or other materials provided with the distribution.
 | |
| - Neither the name of Internet Society, IETF or IETF Trust, nor the
 | |
| names of specific contributors, may be used to endorse or promote
 | |
| products derived from this software without specific prior written
 | |
| permission.
 | |
| THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | |
| AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | |
| IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 | |
| ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
 | |
| LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 | |
| CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 | |
| SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 | |
| INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 | |
| CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 | |
| ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 | |
| POSSIBILITY OF SUCH DAMAGE.
 | |
| ***********************************************************************/
 | |
| 
 | |
| #ifdef HAVE_CONFIG_H
 | |
| #include "config.h"
 | |
| #endif
 | |
| 
 | |
| /* Filter coefficients for IIR/FIR polyphase resampling     *
 | |
|  * Total size: 179 Words (358 Bytes)                        */
 | |
| 
 | |
| #include "resampler_private.h"
 | |
| 
 | |
| /* Matlab code for the notch filter coefficients: */
 | |
| /* B = [1, 0.147, 1];  A = [1, 0.107, 0.89]; G = 0.93; freqz(G * B, A, 2^14, 16e3); axis([0, 8000, -10, 1]) */
 | |
| /* fprintf('\t%6d, %6d, %6d, %6d\n', round(B(2)*2^16), round(-A(2)*2^16), round((1-A(3))*2^16), round(G*2^15)) */
 | |
| /* const opus_int16 silk_resampler_up2_hq_notch[ 4 ] = { 9634,  -7012,   7209,  30474 }; */
 | |
| 
 | |
| /* Tables with IIR and FIR coefficients for fractional downsamplers (123 Words) */
 | |
| silk_DWORD_ALIGN const opus_int16 silk_Resampler_3_4_COEFS[ 2 + 3 * RESAMPLER_DOWN_ORDER_FIR0 / 2 ] = {
 | |
| 	-20694, -13867,
 | |
| 	   -49,     64,     17,   -157,    353,   -496,    163,  11047,  22205,
 | |
| 	   -39,      6,     91,   -170,    186,     23,   -896,   6336,  19928,
 | |
| 	   -19,    -36,    102,    -89,    -24,    328,   -951,   2568,  15909,
 | |
| };
 | |
| 
 | |
| silk_DWORD_ALIGN const opus_int16 silk_Resampler_2_3_COEFS[ 2 + 2 * RESAMPLER_DOWN_ORDER_FIR0 / 2 ] = {
 | |
| 	-14457, -14019,
 | |
| 	    64,    128,   -122,     36,    310,   -768,    584,   9267,  17733,
 | |
| 	    12,    128,     18,   -142,    288,   -117,   -865,   4123,  14459,
 | |
| };
 | |
| 
 | |
| silk_DWORD_ALIGN const opus_int16 silk_Resampler_1_2_COEFS[ 2 + RESAMPLER_DOWN_ORDER_FIR1 / 2 ] = {
 | |
| 	   616, -14323,
 | |
| 	   -10,     39,     58,    -46,    -84,    120,    184,   -315,   -541,   1284,   5380,   9024,
 | |
| };
 | |
| 
 | |
| silk_DWORD_ALIGN const opus_int16 silk_Resampler_1_3_COEFS[ 2 + RESAMPLER_DOWN_ORDER_FIR2 / 2 ] = {
 | |
| 	 16102, -15162,
 | |
| 	   -13,      0,     20,     26,      5,    -31,    -43,     -4,     65,     90,      7,   -157,   -248,    -44,    593,   1583,   2612,   3271,
 | |
| };
 | |
| 
 | |
| silk_DWORD_ALIGN const opus_int16 silk_Resampler_1_4_COEFS[ 2 + RESAMPLER_DOWN_ORDER_FIR2 / 2 ] = {
 | |
| 	 22500, -15099,
 | |
| 	     3,    -14,    -20,    -15,      2,     25,     37,     25,    -16,    -71,   -107,    -79,     50,    292,    623,    982,   1288,   1464,
 | |
| };
 | |
| 
 | |
| silk_DWORD_ALIGN const opus_int16 silk_Resampler_1_6_COEFS[ 2 + RESAMPLER_DOWN_ORDER_FIR2 / 2 ] = {
 | |
| 	 27540, -15257,
 | |
| 	    17,     12,      8,      1,    -10,    -22,    -30,    -32,    -22,      3,     44,    100,    168,    243,    317,    381,    429,    455,
 | |
| };
 | |
| 
 | |
| silk_DWORD_ALIGN const opus_int16 silk_Resampler_2_3_COEFS_LQ[ 2 + 2 * 2 ] = {
 | |
|      -2797,  -6507,
 | |
|       4697,  10739,
 | |
|       1567,   8276,
 | |
| };
 | |
| 
 | |
| /* Table with interplation fractions of 1/24, 3/24, 5/24, ... , 23/24 : 23/24 (46 Words) */
 | |
| silk_DWORD_ALIGN const opus_int16 silk_resampler_frac_FIR_12[ 12 ][ RESAMPLER_ORDER_FIR_12 / 2 ] = {
 | |
| 	{  189,  -600,   617, 30567 },
 | |
| 	{  117,  -159, -1070, 29704 },
 | |
| 	{   52,   221, -2392, 28276 },
 | |
| 	{   -4,   529, -3350, 26341 },
 | |
| 	{  -48,   758, -3956, 23973 },
 | |
| 	{  -80,   905, -4235, 21254 },
 | |
| 	{  -99,   972, -4222, 18278 },
 | |
| 	{ -107,   967, -3957, 15143 },
 | |
| 	{ -103,   896, -3487, 11950 },
 | |
| 	{  -91,   773, -2865,  8798 },
 | |
| 	{  -71,   611, -2143,  5784 },
 | |
| 	{  -46,   425, -1375,  2996 },
 | |
| };
 |