ms.c

00001 /*
00002 ** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
00003 ** Copyright (C) 2003-2005 M. Bakker, Ahead Software AG, http://www.nero.com
00004 **  
00005 ** This program is free software; you can redistribute it and/or modify
00006 ** it under the terms of the GNU General Public License as published by
00007 ** the Free Software Foundation; either version 2 of the License, or
00008 ** (at your option) any later version.
00009 ** 
00010 ** This program is distributed in the hope that it will be useful,
00011 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
00012 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013 ** GNU General Public License for more details.
00014 ** 
00015 ** You should have received a copy of the GNU General Public License
00016 ** along with this program; if not, write to the Free Software 
00017 ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
00018 **
00019 ** Any non-GPL usage of this software or parts of this software is strictly
00020 ** forbidden.
00021 **
00022 ** Software using this code must display the following message visibly in the
00023 ** software:
00024 ** "FAAD2 AAC/HE-AAC/HE-AACv2/DRM decoder (c) Ahead Software, www.nero.com"
00025 ** in, for example, the about-box or help/startup screen.
00026 **
00027 ** Commercial non-GPL licensing of this software is possible.
00028 ** For more info contact Ahead Software through [email protected].
00029 **
00030 ** $Id: ms.c,v 1.2 2005/11/01 21:41:43 gabest Exp $
00031 **/
00032 
00033 #include "common.h"
00034 #include "structs.h"
00035 
00036 #include "syntax.h"
00037 #include "ms.h"
00038 #include "is.h"
00039 #include "pns.h"
00040 
00041 void ms_decode(ic_stream *ics, ic_stream *icsr, real_t *l_spec, real_t *r_spec,
00042                uint16_t frame_len)
00043 {
00044     uint8_t g, b, sfb;
00045     uint8_t group = 0;
00046     uint16_t nshort = frame_len/8;
00047 
00048     uint16_t i, k;
00049     real_t tmp;
00050 
00051     if (ics->ms_mask_present >= 1)
00052     {
00053         for (g = 0; g < ics->num_window_groups; g++) 
00054         {
00055             for (b = 0; b < ics->window_group_length[g]; b++)
00056             {
00057                 for (sfb = 0; sfb < ics->max_sfb; sfb++)
00058                 {
00059                     /* If intensity stereo coding or noise substitution is on
00060                        for a particular scalefactor band, no M/S stereo decoding
00061                        is carried out.
00062                      */
00063                     if ((ics->ms_used[g][sfb] || ics->ms_mask_present == 2) &&
00064                         !is_intensity(icsr, g, sfb) && !is_noise(ics, g, sfb))
00065                     {
00066                         for (i = ics->swb_offset[sfb]; i < ics->swb_offset[sfb+1]; i++)
00067                         {
00068                             k = (group*nshort) + i;
00069                             tmp = l_spec[k] - r_spec[k];
00070                             l_spec[k] = l_spec[k] + r_spec[k];
00071                             r_spec[k] = tmp;
00072                         }
00073                     }
00074                 }
00075                 group++;
00076             }
00077         }
00078     }
00079 }

Generated on Tue Dec 13 14:47:42 2005 for guliverkli by  doxygen 1.4.5