annotate Input/aac/libfaad2/pns.h @ 2:6efb9e514224 trunk

[svn] Import AAC stuff.
author nenolod
date Mon, 24 Oct 2005 10:44:27 -0700
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
1 /*
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
2 ** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
3 ** Copyright (C) 2003 M. Bakker, Ahead Software AG, http://www.nero.com
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
4 **
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
5 ** This program is free software; you can redistribute it and/or modify
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
6 ** it under the terms of the GNU General Public License as published by
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
7 ** the Free Software Foundation; either version 2 of the License, or
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
8 ** (at your option) any later version.
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
9 **
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
10 ** This program is distributed in the hope that it will be useful,
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
11 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
12 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
13 ** GNU General Public License for more details.
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
14 **
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
15 ** You should have received a copy of the GNU General Public License
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
16 ** along with this program; if not, write to the Free Software
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
17 ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
18 **
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
19 ** Any non-GPL usage of this software or parts of this software is strictly
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
20 ** forbidden.
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
21 **
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
22 ** Commercial non-GPL licensing of this software is possible.
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
23 ** For more info contact Ahead Software through Mpeg4AAClicense@nero.com.
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
24 **
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
25 ** $Id: pns.h,v 1.17 2003/11/12 20:47:58 menno Exp $
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
26 **/
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
27
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
28 #ifndef __PNS_H__
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
29 #define __PNS_H__
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
30
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
31 #ifdef __cplusplus
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
32 extern "C" {
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
33 #endif
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
34
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
35 #include "common.h"
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
36
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
37 #include "syntax.h"
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
38
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
39 #define NOISE_OFFSET 90
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
40
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
41 void pns_decode(ic_stream *ics_left, ic_stream *ics_right,
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
42 real_t *spec_left, real_t *spec_right, uint16_t frame_len,
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
43 uint8_t channel_pair, uint8_t object_type);
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
44
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
45 static INLINE int32_t random2();
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
46 static void gen_rand_vector(real_t *spec, int16_t scale_factor, uint16_t size,
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
47 uint8_t sub);
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
48
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
49 static INLINE uint8_t is_noise(ic_stream *ics, uint8_t group, uint8_t sfb)
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
50 {
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
51 if (ics->sfb_cb[group][sfb] == NOISE_HCB)
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
52 return 1;
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
53 return 0;
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
54 }
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
55
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
56 #ifdef __cplusplus
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
57 }
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
58 #endif
6efb9e514224 [svn] Import AAC stuff.
nenolod
parents:
diff changeset
59 #endif