ref: 06e2bdb10725e93bfdfae7c8c5744692d5f5b49b
dir: /quant.h/
/* * Function prototypes for AAC quantization * * Copyright (c) 1999 M. Bakker * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; see the file COPYING. If not, write to * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ /************************************************************************** Version Control Information Method: CVS Identifiers: $Revision: 1.9 $ $Date: 2000/11/10 13:27:06 $ (check in) $Author: menno $ *************************************************************************/ #ifndef QUANT_H #define QUANT_H #include "pulse.h" #include "interface.h" #include "tns.h" #include "ltp_enc.h" #include "bitstream.h" #ifdef __cplusplus extern "C" { #endif /* assumptions for the first run of this quantizer */ #define CHANNEL 1 #define MAGIC_NUMBER 0.4054 #define MAX_QUANT 8192 #define SF_OFFSET 100 #define ABS(A) ((A) < 0 ? (-A) : (A)) #define sgn(A) ((A) > 0 ? (1) : (-1)) #define MAXFAC 121 /* maximum scale factor */ #define MIDFAC (MAXFAC-1)/2 #define SF_OFFSET 100 /* global gain must be positive */ #define LARGE_BITS 100000 #define INTENSITY_HCB 15 #define INTENSITY_HCB2 14 extern int pns_sfb_start; /* lower border for PNS */ /*********************************************************/ /* AACQuantInfo, info for AAC quantization and coding. */ /*********************************************************/ typedef struct _AACQuantInfo { int max_sfb; /* max_sfb, should = nr_of_sfb/num_window_groups */ int nr_of_sfb; /* Number of scalefactor bands, interleaved */ int spectralCount; /* Number of spectral data coefficients */ enum WINDOW_TYPE block_type; /* Block type */ int scale_factor[MAX_SCFAC_BANDS]; /* Scalefactor data array , interleaved */ int sfb_offset[250]; /* Scalefactor spectral offset, interleaved */ int book_vector[MAX_SCFAC_BANDS]; /* Huffman codebook selected for each sf band */ int data[5*BLOCK_LEN_LONG]; /* Data of spectral bitstream elements, for each spectral pair, 5 elements are required: 1*(esc)+2*(sign)+2*(esc value)=5 */ int len[5*BLOCK_LEN_LONG]; /* Lengths of spectral bitstream elements */ int num_window_groups; /* Number of window groups */ int window_group_length[MAX_SHORT_WINDOWS]; /* Length (in windows) of each window group */ int common_scalefac; /* Global gain */ Window_shape window_shape; /* Window shape parameter */ Window_shape prev_window_shape; /* Previous window shape parameter */ short pred_global_flag; /* Global prediction enable flag */ int pred_sfb_flag[MAX_SCFAC_BANDS]; /* Prediction enable flag for each scalefactor band */ int reset_group_number; /* Prediction reset group number */ AACPulseInfo pulseInfo; SR_INFO *sr_info; TNS_INFO tnsInfo; struct _LT_PRED_STATUS ltpInfo; Ch_Info channelInfo; int pns_sfb_nrg[MAX_SCFAC_BANDS]; int pns_sfb_flag[MAX_SCFAC_BANDS]; int profile; int srate_idx; } AACQuantInfo; void quantize(AACQuantInfo *quantInfo, double *pow_spectrum, int quant[BLOCK_LEN_LONG] ); void dequantize(AACQuantInfo *quantInfo, double *p_spectrum, int quant[BLOCK_LEN_LONG], double requant[BLOCK_LEN_LONG], double error_energy[MAX_SCFAC_BANDS] ); int count_bits_long(AACQuantInfo* quantInfo, int quant[BLOCK_LEN_LONG] ); int count_bits(AACQuantInfo* quantInfo, double *pow_spectrum, int quant[BLOCK_LEN_LONG]); /*********************************************************/ /* sort_for_grouping */ /*********************************************************/ int sort_for_grouping(AACQuantInfo* quantInfo, /* ptr to quantization information */ int sfb_width_table[], /* Widths of single window */ double *p_spectrum[], /* Spectral values, noninterleaved */ double *SigMaskRatio, double *PsySigMaskRatio); /*********************************************************/ /* tf_init_encode_spectrum_aac */ /*********************************************************/ void aacQuantizeInit(int quality); /*********************************************************/ /* tf_encode_spectrum_aac */ /*********************************************************/ int aacQuantize(AACQuantInfo* quantInfo, /* AAC quantization information */ double *p_spectrum[MAX_TIME_CHANNELS], double *SigMaksRatio[MAX_TIME_CHANNELS], double allowed_dist[MAX_TIME_CHANNELS][MAX_SCFAC_BANDS], double energy[MAX_TIME_CHANNELS][MAX_SCFAC_BANDS], enum WINDOW_TYPE block_type[MAX_TIME_CHANNELS], int sfb_width_table[MAX_TIME_CHANNELS][MAX_SCFAC_BANDS], int average_block_bits, BsBitStream *fixed_stream, double *p_reconstructed_spectrum[MAX_TIME_CHANNELS] ); #ifdef __cplusplus } #endif #endif