hwin.c
上传用户:zhongxx05
上传日期:2007-06-06
资源大小:33641k
文件大小:11k
- /* ***** BEGIN LICENSE BLOCK *****
- * Version: RCSL 1.0/RPSL 1.0
- *
- * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
- *
- * The contents of this file, and the files included with this file, are
- * subject to the current version of the RealNetworks Public Source License
- * Version 1.0 (the "RPSL") available at
- * http://www.helixcommunity.org/content/rpsl unless you have licensed
- * the file under the RealNetworks Community Source License Version 1.0
- * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
- * in which case the RCSL will apply. You may also obtain the license terms
- * directly from RealNetworks. You may not use this file except in
- * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
- * applicable to this file, the RCSL. Please see the applicable RPSL or
- * RCSL for the rights, obligations and limitations governing use of the
- * contents of the file.
- *
- * This file is part of the Helix DNA Technology. RealNetworks is the
- * developer of the Original Code and owns the copyrights in the portions
- * it created.
- *
- * This file, and the files included with this file, is distributed and made
- * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
- * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
- * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
- * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
- *
- * Technology Compatibility Kit Test Suite(s) Location:
- * http://www.helixcommunity.org/content/tck
- *
- * Contributor(s):
- *
- * ***** END LICENSE BLOCK ***** */
- #include "statname.h"
- #ifdef __cplusplus
- extern "C" {
- #endif
- int hybrid(float xin[], float xprev[], float y[18][32],
- int btype, int nlong, int ntot, int nprev, int band_limit_nsb);
- int hybrid_sum(float xin[], float xin_left[], float y[18][32],
- int btype, int nlong, int ntot);
- void sum_f_bands( float a[], float b[], int n);
- void FreqInvert(float y[18][32], int n);
- #ifdef __cplusplus
- }
- #endif
- typedef float ARRAY36[36];
- /*-- windows by block type --*
- pi = 4.0*atan(1.0);
- ** type 0 **
- for(i=0;i<36;i++) win[0][i] = (float)sin( pi/36 *(i+0.5) );
- ** type 1**
- for(i=0;i<18;i++) win[1][i] = (float)sin( pi/36 *(i+0.5) );
- for(i=18;i<24;i++) win[1][i] = 1.0F;
- for(i=24;i<30;i++) win[1][i] = (float)sin( pi/12 *(i+0.5-18) );
- for(i=30;i<36;i++) win[1][i] = 0.0F;
- ** type 3**
- for(i=0;i<6;i++) win[3][i] = 0.0F;
- for(i=6;i<12;i++) win[3][i] = (float)sin( pi/12 *(i+0.5-6) );
- for(i=12;i<18;i++) win[3][i] = 1.0F;
- for(i=18;i<36;i++) win[3][i] = (float)sin( pi/36*(i+0.5) );
- ** type 2**
- for(i=0;i<12;i++) win[2][i] = (float)sin( pi/12*(i+0.5) ) ;
- for(i=12;i<36;i++) win[2][i] = 0.0F;
- **--- invert signs by region to match mdct 18pt --> 36pt mapping **
- for(j=0;j<4;j++) {
- if( j == 2 ) continue;
- for(i=9;i<36;i++ ) win[j][i] = -win[j][i];
- }
- **-- invert signs for short blocks --**
- for(i=3;i<12;i++ ) win[2][i] = -win[2][i];
- */
- static const float win[4][36] = {
- {
- 4.3619386852e-002f, 1.3052618504e-001f, 2.1643961966e-001f, 3.0070579052e-001f,
- 3.8268342614e-001f, 4.6174860001e-001f, 5.3729963303e-001f, 6.0876142979e-001f,
- 6.7559021711e-001f, -7.3727732897e-001f, -7.9335331917e-001f, -8.4339141846e-001f,
- -8.8701081276e-001f, -9.2387950420e-001f, -9.5371693373e-001f, -9.7629600763e-001f,
- -9.9144488573e-001f, -9.9904823303e-001f, -9.9904823303e-001f, -9.9144488573e-001f,
- -9.7629600763e-001f, -9.5371693373e-001f, -9.2387950420e-001f, -8.8701081276e-001f,
- -8.4339141846e-001f, -7.9335331917e-001f, -7.3727732897e-001f, -6.7559021711e-001f,
- -6.0876142979e-001f, -5.3729963303e-001f, -4.6174860001e-001f, -3.8268342614e-001f,
- -3.0070579052e-001f, -2.1643961966e-001f, -1.3052618504e-001f, -4.3619386852e-002f,
- },
- {
- 4.3619386852e-002f, 1.3052618504e-001f, 2.1643961966e-001f, 3.0070579052e-001f,
- 3.8268342614e-001f, 4.6174860001e-001f, 5.3729963303e-001f, 6.0876142979e-001f,
- 6.7559021711e-001f, -7.3727732897e-001f, -7.9335331917e-001f, -8.4339141846e-001f,
- -8.8701081276e-001f, -9.2387950420e-001f, -9.5371693373e-001f, -9.7629600763e-001f,
- -9.9144488573e-001f, -9.9904823303e-001f, -1.0000000000e+000f, -1.0000000000e+000f,
- -1.0000000000e+000f, -1.0000000000e+000f, -1.0000000000e+000f, -1.0000000000e+000f,
- -9.9144488573e-001f, -9.2387950420e-001f, -7.9335331917e-001f, -6.0876142979e-001f,
- -3.8268342614e-001f, -1.3052618504e-001f, 0.0000000000e+000f, 0.0000000000e+000f,
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- },
- {
- 1.3052618504e-001f, 3.8268342614e-001f, 6.0876142979e-001f, -7.9335331917e-001f,
- -9.2387950420e-001f, -9.9144488573e-001f, -9.9144488573e-001f, -9.2387950420e-001f,
- -7.9335331917e-001f, -6.0876142979e-001f, -3.8268342614e-001f, -1.3052618504e-001f,
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- },
- {
- 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f, 0.0000000000e+000f,
- 0.0000000000e+000f, 0.0000000000e+000f, 1.3052618504e-001f, 3.8268342614e-001f,
- 6.0876142979e-001f, -7.9335331917e-001f, -9.2387950420e-001f, -9.9144488573e-001f,
- -1.0000000000e+000f, -1.0000000000e+000f, -1.0000000000e+000f, -1.0000000000e+000f,
- -1.0000000000e+000f, -1.0000000000e+000f, -9.9904823303e-001f, -9.9144488573e-001f,
- -9.7629600763e-001f, -9.5371693373e-001f, -9.2387950420e-001f, -8.8701081276e-001f,
- -8.4339141846e-001f, -7.9335331917e-001f, -7.3727732897e-001f, -6.7559021711e-001f,
- -6.0876142979e-001f, -5.3729963303e-001f, -4.6174860001e-001f, -3.8268342614e-001f,
- -3.0070579052e-001f, -2.1643961966e-001f, -1.3052618504e-001f, -4.3619386852e-002f,
- }
- };
- /*====================================================================*/
- void imdct18(float f[]); /* 18 point */
- void imdct6_3(float f[]); /* 6 point */
- /*====================================================================*/
- int hybrid(float xin[], float xprev[], float y[18][32],
- int btype, int nlong, int ntot, int nprev, int band_limit_nsb)
- {
- int i, j;
- float *x, *x0;
- float xa, xb;
- int n;
- int nout;
- if( btype == 2 ) btype = 0;
- x = xin;
- x0 = xprev;
- /*-- do long blocks (if any) --*/
- n = (nlong+17)/18; /* number of dct's to do */
- for(i=0;i<n;i++) {
- imdct18(x);
- for(j=0;j<9;j++) {
- y[j][i] = x0[j] + win[btype][j]*x[9+j];
- y[9+j][i] = x0[9+j] + win[btype][9+j]*x[17-j];
- }
- /* window x for next time x0 */
- for(j=0;j<4;j++) {
- xa = x[j];
- xb = x[8-j];
- x[j] = win[btype][18+j]*xb;
- x[8-j] = win[btype][(18+8)-j]*xa;
- x[9+j] = win[btype][(18+9)+j]*xa;
- x[17-j] = win[btype][(18+17)-j]*xb;
- }
- xa = x[j];
- x[j] = win[btype][18+j]*xa;
- x[9+j] = win[btype][(18+9)+j]*xa;
-
- x+=18;
- x0+=18;
- }
- /*-- do short blocks (if any) --*/
- n = (ntot+17)/18; /* number of 6 pt dct's triples to do */
- for( ;i<n;i++) {
- imdct6_3(x);
- for(j=0;j<3;j++) {
- y[j][i] = x0[j];
- y[3+j][i] = x0[3+j];
- y[6+j][i] = x0[6+j] + win[2][j] *x[3+j];
- y[9+j][i] = x0[9+j] + win[2][3+j]*x[5-j];
- y[12+j][i] = x0[12+j] + win[2][6+j]*x[2-j] + win[2][j]*x[(6+3)+j];
- y[15+j][i] = x0[15+j] + win[2][9+j]*x[j] + win[2][3+j]*x[(6+5)-j];
- }
- /* window x for next time x0 */
- for(j=0;j<3;j++) {
- x[j] = win[2][6+j]*x[(6+2)-j] + win[2][j] *x[(12+3)+j];
- x[3+j] = win[2][9+j]*x[6+j] + win[2][3+j]*x[(12+5)-j];
- }
- for(j=0;j<3;j++) {
- x[6+j] = win[2][6+j]*x[(12+2)-j];
- x[9+j] = win[2][9+j]*x[12+j];
- }
- for(j=0;j<3;j++) {
- x[12+j] = 0.0f;
- x[15+j] = 0.0f;
- }
- x+=18;
- x0+=18;
- }
- /*--- overlap prev if prev longer that current --*/
- n = (nprev+17)/18;
- for(;i<n;i++) {
- for(j=0;j<18;j++) y[j][i] = x0[j];
- x0+=18;
- }
- nout = 18*i;
- /*--- clear remaining only to band limit --*/
- for(;i<band_limit_nsb;i++) {
- for(j=0;j<18;j++) y[j][i] = 0.0f;
- }
- return nout;
- }
- /*====================================================================*/
- /*--------------------------------------------------------------------*/
- /*--------------------------------------------------------------------*/
- /*-- convert to mono, add curr result to y,
- window and add next time to current left */
- int hybrid_sum(float xin[], float xin_left[], float y[18][32],
- int btype, int nlong, int ntot)
- {
- int i, j;
- float *x, *x0;
- float xa, xb;
- int n;
- int nout;
- if( btype == 2 ) btype = 0;
- x = xin;
- x0 = xin_left;
- /*-- do long blocks (if any) --*/
- n = (nlong+17)/18; /* number of dct's to do */
- for(i=0;i<n;i++) {
- imdct18(x);
- for(j=0;j<9;j++) {
- y[j][i] += win[btype][j]*x[9+j];
- y[9+j][i] += win[btype][9+j]*x[17-j];
- }
- /* window x for next time x0 */
- for(j=0;j<4;j++) {
- xa = x[j];
- xb = x[8-j];
- x0[j] += win[btype][18+j]*xb;
- x0[8-j] += win[btype][(18+8)-j]*xa;
- x0[9+j] += win[btype][(18+9)+j]*xa;
- x0[17-j] += win[btype][(18+17)-j]*xb;
- }
- xa = x[j];
- x0[j] += win[btype][18+j]*xa;
- x0[9+j] += win[btype][(18+9)+j]*xa;
-
- x+=18;
- x0+=18;
- }
- /*-- do short blocks (if any) --*/
- n = (ntot+17)/18; /* number of 6 pt dct's triples to do */
- for( ;i<n;i++) {
- imdct6_3(x);
- for(j=0;j<3;j++) {
- y[6+j][i] += win[2][j] *x[3+j];
- y[9+j][i] += win[2][3+j]*x[5-j];
- y[12+j][i] += win[2][6+j]*x[2-j] + win[2][j]*x[(6+3)+j];
- y[15+j][i] += win[2][9+j]*x[j] + win[2][3+j]*x[(6+5)-j];
- }
- /* window x for next time */
- for(j=0;j<3;j++) {
- x0[j] += win[2][6+j]*x[(6+2)-j] + win[2][j] *x[(12+3)+j];
- x0[3+j] += win[2][9+j]*x[6+j] + win[2][3+j]*x[(12+5)-j];
- }
- for(j=0;j<3;j++) {
- x0[6+j] += win[2][6+j]*x[(12+2)-j];
- x0[9+j] += win[2][9+j]*x[12+j];
- }
- x+=18;
- x0+=18;
- }
- nout = 18*i;
- return nout;
- }
- /*--------------------------------------------------------------------*/
- void sum_f_bands( float a[], float b[], int n)
- {
- int i;
- for(i=0;i<n;i++) a[i] += b[i];
- }
- /*--------------------------------------------------------------------*/
- /*--------------------------------------------------------------------*/
- void FreqInvert(float y[18][32], int n)
- {
- int i, j;
- n = (n+17)/18;
- for(j=0;j<18;j+=2) {
- for(i=0;i<n; i+=2) {
- y[1+j][1+i] = -y[1+j][1+i];
- }
- }
- }
- /*--------------------------------------------------------------------*/