mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-24 21:50:53 +00:00 
			
		
		
		
	
		
			
	
	
		
			111 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			111 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | 
 | ||
|  |    /******************************************************************
 | ||
|  | 
 | ||
|  |        iLBC Speech Coder ANSI-C Source Code | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  |        gainquant.c | ||
|  | 
 | ||
|  |        Copyright (C) The Internet Society (2004). | ||
|  |        All Rights Reserved. | ||
|  | 
 | ||
|  |    ******************************************************************/ | ||
|  | 
 | ||
|  |    #include <string.h>
 | ||
|  |    #include <math.h>
 | ||
|  |    #include "constants.h"
 | ||
|  |    #include "filter.h"
 | ||
|  | 
 | ||
|  |    /*----------------------------------------------------------------*
 | ||
|  |     *  quantizer for the gain in the gain-shape coding of residual | ||
|  |     *---------------------------------------------------------------*/ | ||
|  | 
 | ||
|  |    float gainquant(/* (o) quantized gain value */ | ||
|  |        float in,       /* (i) gain value */ | ||
|  |        float maxIn,/* (i) maximum of gain value */ | ||
|  |        int cblen,      /* (i) number of quantization indices */ | ||
|  |        int *index      /* (o) quantization index */ | ||
|  |    ){ | ||
|  |        int i, tindex; | ||
|  |        float minmeasure,measure, *cb, scale; | ||
|  | 
 | ||
|  |        /* ensure a lower bound on the scaling factor */ | ||
|  | 
 | ||
|  |        scale=maxIn; | ||
|  | 
 | ||
|  |        if (scale<0.1) { | ||
|  |            scale=(float)0.1; | ||
|  |        } | ||
|  | 
 | ||
|  |        /* select the quantization table */ | ||
|  | 
 | ||
|  |        if (cblen == 8) { | ||
|  |            cb = gain_sq3Tbl; | ||
|  |        } else if (cblen == 16) { | ||
|  |            cb = gain_sq4Tbl; | ||
|  |        } else  { | ||
|  |            cb = gain_sq5Tbl; | ||
|  |        } | ||
|  | 
 | ||
|  |        /* select the best index in the quantization table */ | ||
|  | 
 | ||
|  |        minmeasure=10000000.0; | ||
|  |        tindex=0; | ||
|  |        for (i=0; i<cblen; i++) { | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  |            measure=(in-scale*cb[i])*(in-scale*cb[i]); | ||
|  | 
 | ||
|  |            if (measure<minmeasure) { | ||
|  |                tindex=i; | ||
|  |                minmeasure=measure; | ||
|  |            } | ||
|  |        } | ||
|  |        *index=tindex; | ||
|  | 
 | ||
|  |        /* return the quantized value */ | ||
|  | 
 | ||
|  |        return scale*cb[tindex]; | ||
|  |    } | ||
|  | 
 | ||
|  |    /*----------------------------------------------------------------*
 | ||
|  |     *  decoder for quantized gains in the gain-shape coding of | ||
|  |     *  residual | ||
|  |     *---------------------------------------------------------------*/ | ||
|  | 
 | ||
|  |    float gaindequant(  /* (o) quantized gain value */ | ||
|  |        int index,      /* (i) quantization index */ | ||
|  |        float maxIn,/* (i) maximum of unquantized gain */ | ||
|  |        int cblen       /* (i) number of quantization indices */ | ||
|  |    ){ | ||
|  |        float scale; | ||
|  | 
 | ||
|  |        /* obtain correct scale factor */ | ||
|  | 
 | ||
|  |        scale=(float)fabs(maxIn); | ||
|  | 
 | ||
|  |        if (scale<0.1) { | ||
|  |            scale=(float)0.1; | ||
|  |        } | ||
|  | 
 | ||
|  |        /* select the quantization table and return the decoded value */ | ||
|  | 
 | ||
|  |        if (cblen==8) { | ||
|  |            return scale*gain_sq3Tbl[index]; | ||
|  |        } else if (cblen==16) { | ||
|  |            return scale*gain_sq4Tbl[index]; | ||
|  |        } | ||
|  |        else if (cblen==32) { | ||
|  |            return scale*gain_sq5Tbl[index]; | ||
|  |        } | ||
|  | 
 | ||
|  |        return 0.0; | ||
|  |    } |