rematrix.c
上传用户:aoeyumen
上传日期:2007-01-06
资源大小:3329k
文件大小:2k
源码类别:

DVD

开发平台:

Unix_Linux

  1. /* 
  2.  *    rematrix.c
  3.  *
  4.  * Copyright (C) Aaron Holtzman - July 1999
  5.  *
  6.  *  This file is part of ac3dec, a free Dolby AC-3 stream decoder.
  7.  *
  8.  *  ac3dec is free software; you can redistribute it and/or modify
  9.  *  it under the terms of the GNU General Public License as published by
  10.  *  the Free Software Foundation; either version 2, or (at your option)
  11.  *  any later version.
  12.  *   
  13.  *  ac3dec is distributed in the hope that it will be useful,
  14.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  15.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16.  *  GNU General Public License for more details.
  17.  *   
  18.  *  You should have received a copy of the GNU General Public License
  19.  *  along with GNU Make; see the file COPYING.  If not, write to
  20.  *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. 
  21.  *
  22.  *
  23.  */
  24. #include <stdlib.h>
  25. #include <stdio.h>
  26. #include "ac3.h"
  27. #include "decode.h"
  28. #include "rematrix.h"
  29. struct rematrix_band_s
  30. {
  31. uint_32 start;
  32. uint_32 end;
  33. };
  34. struct rematrix_band_s rematrix_band[] = { {13,24}, {25,36}, {37 ,60}, {61,252}};
  35. static inline uint_32 min(uint_32 a,uint_32 b);
  36. static inline uint_32
  37. min(uint_32 a,uint_32 b)
  38. {
  39. return (a < b ? a : b);
  40. }
  41. /* This routine simply does stereo rematixing for the 2 channel 
  42.  * stereo mode */
  43. void rematrix(audblk_t *audblk, stream_coeffs_t *coeffs)
  44. {
  45. uint_32 num_bands;
  46. uint_32 start;
  47. uint_32 end;
  48. uint_32 i,j;
  49. float left,right;
  50. if(audblk->cplinu || audblk->cplbegf > 2)
  51. num_bands = 4;
  52. else if (audblk->cplbegf > 0)
  53. num_bands = 3;
  54. else
  55. num_bands = 2;
  56. for(i=0;i < num_bands; i++)
  57. {
  58. if(!audblk->rematflg[i])
  59. continue;
  60. start = rematrix_band[i].start;
  61. end = min(rematrix_band[i].end ,12 * audblk->cplbegf + 36);
  62. for(j=start;j < end; j++)
  63. {
  64. left  = 0.5 * (coeffs->fbw[0][j] + coeffs->fbw[1][j]);
  65. right = 0.5 * (coeffs->fbw[0][j] - coeffs->fbw[1][j]);
  66. coeffs->fbw[0][j] = left;
  67. coeffs->fbw[1][j] = right;
  68. }
  69. }
  70. }