mirror of
				https://github.com/cookiengineer/audacity
				synced 2025-10-31 14:13:50 +01:00 
			
		
		
		
	Using LAME 3.10 Windows project files substantially changed from original, and included into audacity solution.
		
			
				
	
	
		
			129 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *	quantize_pvt include file
 | |
|  *
 | |
|  *	Copyright (c) 1999 Takehiro TOMINAGA
 | |
|  *
 | |
|  * This library is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Library General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This library 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
 | |
|  * Library General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Library General Public
 | |
|  * License along with this library; if not, write to the
 | |
|  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 | |
|  * Boston, MA 02111-1307, USA.
 | |
|  */
 | |
| 
 | |
| #ifndef LAME_QUANTIZE_PVT_H
 | |
| #define LAME_QUANTIZE_PVT_H
 | |
| 
 | |
| #define IXMAX_VAL 8206  /* ix always <= 8191+15.    see count_bits() */
 | |
| 
 | |
| /* buggy Winamp decoder cannot handle values > 8191 */
 | |
| /* #define IXMAX_VAL 8191 */
 | |
| 
 | |
| #define PRECALC_SIZE (IXMAX_VAL+2)
 | |
| 
 | |
| 
 | |
| extern const int nr_of_sfb_block[6][3][4];
 | |
| extern const int pretab[SBMAX_l];
 | |
| extern const int slen1_tab[16];
 | |
| extern const int slen2_tab[16];
 | |
| 
 | |
| extern const scalefac_struct sfBandIndex[9];
 | |
| 
 | |
| extern FLOAT pow43[PRECALC_SIZE];
 | |
| #ifdef TAKEHIRO_IEEE754_HACK
 | |
| extern FLOAT adj43asm[PRECALC_SIZE];
 | |
| #else
 | |
| extern FLOAT adj43[PRECALC_SIZE];
 | |
| #endif
 | |
| 
 | |
| #define Q_MAX (256+1)
 | |
| #define Q_MAX2 116      /* minimum possible number of
 | |
|                            -cod_info->global_gain
 | |
|                            + ((scalefac[] + (cod_info->preflag ? pretab[sfb] : 0))
 | |
|                            << (cod_info->scalefac_scale + 1))
 | |
|                            + cod_info->subblock_gain[cod_info->window[sfb]] * 8;
 | |
| 
 | |
|                            for long block, 0+((15+3)<<2) = 18*4 = 72
 | |
|                            for short block, 0+(15<<2)+7*8 = 15*4+56 = 116
 | |
|                          */
 | |
| 
 | |
| extern FLOAT pow20[Q_MAX + Q_MAX2 + 1];
 | |
| extern FLOAT ipow20[Q_MAX];
 | |
| 
 | |
| typedef struct calc_noise_result_t {
 | |
|     FLOAT   over_noise;      /* sum of quantization noise > masking */
 | |
|     FLOAT   tot_noise;       /* sum of all quantization noise */
 | |
|     FLOAT   max_noise;       /* max quantization noise */
 | |
|     int     over_count;      /* number of quantization noise > masking */
 | |
|     int     over_SSD;        /* SSD-like cost of distorted bands */
 | |
|     int     bits;
 | |
| } calc_noise_result;
 | |
| 
 | |
| 
 | |
| /**
 | |
| * allows re-use of previously
 | |
| * computed noise values
 | |
| */
 | |
| typedef struct calc_noise_data_t {
 | |
|     int     global_gain;
 | |
|     int     sfb_count1;
 | |
|     int     step[39];
 | |
|     FLOAT   noise[39];
 | |
|     FLOAT   noise_log[39];
 | |
| } calc_noise_data;
 | |
| 
 | |
| 
 | |
| int     on_pe(lame_internal_flags * gfc, const FLOAT pe[2][2],
 | |
|               int targ_bits[2], int mean_bits, int gr, int cbr);
 | |
| 
 | |
| void    reduce_side(int targ_bits[2], FLOAT ms_ener_ratio, int mean_bits, int max_bits);
 | |
| 
 | |
| 
 | |
| void    iteration_init(lame_internal_flags * gfc);
 | |
| 
 | |
| 
 | |
| int     calc_xmin(lame_internal_flags const *gfc,
 | |
|                   III_psy_ratio const *const ratio, gr_info * const cod_info, FLOAT * l3_xmin);
 | |
| 
 | |
| int     calc_noise(const gr_info * const cod_info,
 | |
|                    const FLOAT * l3_xmin,
 | |
|                    FLOAT * distort, calc_noise_result * const res, calc_noise_data * prev_noise);
 | |
| 
 | |
| void    set_frame_pinfo(lame_internal_flags * gfc, const III_psy_ratio ratio[2][2]);
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| /* takehiro.c */
 | |
| 
 | |
| int     count_bits(lame_internal_flags const *const gfc, const FLOAT * const xr,
 | |
|                    gr_info * const cod_info, calc_noise_data * prev_noise);
 | |
| int     noquant_count_bits(lame_internal_flags const *const gfc,
 | |
|                            gr_info * const cod_info, calc_noise_data * prev_noise);
 | |
| 
 | |
| 
 | |
| void    best_huffman_divide(const lame_internal_flags * const gfc, gr_info * const cod_info);
 | |
| 
 | |
| void    best_scalefac_store(const lame_internal_flags * gfc, const int gr, const int ch,
 | |
|                             III_side_info_t * const l3_side);
 | |
| 
 | |
| int     scale_bitcount(const lame_internal_flags * gfc, gr_info * cod_info);
 | |
| 
 | |
| void    huffman_init(lame_internal_flags * const gfc);
 | |
| 
 | |
| void    init_xrpow_core_init(lame_internal_flags * const gfc);
 | |
| 
 | |
| FLOAT   athAdjust(FLOAT a, FLOAT x, FLOAT athFloor, float ATHfixpoint);
 | |
| 
 | |
| #define LARGE_BITS 100000
 | |
| 
 | |
| #endif /* LAME_QUANTIZE_PVT_H */
 |