mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 22:18:07 +00:00 
			
		
		
		
	#72 - Should eliminate probs on VMWI #41 - Dynamic add survives reload #73 - Make festival honor its arguments #93 - Make events on FXO interfaces more logical #26 - Prefer "bindaddr" to logical address for registrations ??? - Record crashes AGI git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1338 65c4cc65-6c06-0410-ace0-fbb531ad65f3
		
			
				
	
	
		
			106 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
|  
 | |
| /****************************************************************** 
 | |
|  
 | |
|     iLBC Speech Coder ANSI-C Source Code 
 | |
|  
 | |
|     iCBConstruct.c  
 | |
|  
 | |
|     Copyright (c) 2001, 
 | |
|     Global IP Sound AB. 
 | |
|     All rights reserved. 
 | |
|  
 | |
| ******************************************************************/ 
 | |
|  
 | |
| #include <math.h> 
 | |
|  
 | |
| #include "iLBC_define.h" 
 | |
| #include "gainquant.h" 
 | |
| #include "getCBvec.h" 
 | |
| #include "iCBConstruct.h"
 | |
|  
 | |
| /*----------------------------------------------------------------* 
 | |
|  *  Convert the codebook indexes to make the search easier 
 | |
|  *---------------------------------------------------------------*/ 
 | |
|  
 | |
| void index_conv_enc( 
 | |
|     int *index          /* (i/o) Codebook indexes */ 
 | |
| ){ 
 | |
|     int k; 
 | |
|  
 | |
|     for (k=1;k<CB_NSTAGES;k++) { 
 | |
|          
 | |
|         if ((index[k]>=108)&&(index[k]<172)) { 
 | |
|             index[k]-=64; 
 | |
|         } else if (index[k]>=236) { 
 | |
|             index[k]-=128; 
 | |
|         } else { 
 | |
|             /* ERROR */ 
 | |
|         } 
 | |
|     } 
 | |
| } 
 | |
|  
 | |
| void index_conv_dec( 
 | |
|     int *index          /* (i/o) Codebook indexes */ 
 | |
| ){ 
 | |
|     int k; 
 | |
|  
 | |
|     for (k=1;k<CB_NSTAGES;k++) { 
 | |
|          
 | |
|         if ((index[k]>=44)&&(index[k]<108)) { 
 | |
|             index[k]+=64; 
 | |
|         } else if ((index[k]>=108)&&(index[k]<128)) { 
 | |
|             index[k]+=128; 
 | |
|         } else { 
 | |
|             /* ERROR */ 
 | |
|         } 
 | |
|     } 
 | |
| } 
 | |
|  
 | |
| /*----------------------------------------------------------------* 
 | |
|  *  Construct decoded vector from codebook and gains. 
 | |
|  *---------------------------------------------------------------*/ 
 | |
|  
 | |
| void iCBConstruct( 
 | |
|     float *decvector,   /* (o) Decoded vector */ 
 | |
|     int *index,         /* (i) Codebook indices */ 
 | |
|     int *gain_index,/* (i) Gain quantization indices */ 
 | |
|     float *mem,         /* (i) Buffer for codevector construction */ 
 | |
|     int lMem,           /* (i) Length of buffer */ 
 | |
|     int veclen,         /* (i) Length of vector */ 
 | |
|     int nStages         /* (i) Number of codebook stages */ 
 | |
| ){ 
 | |
|     int j,k; 
 | |
|     float gain[CB_NSTAGES]; 
 | |
|     float cbvec[SUBL]; 
 | |
|  
 | |
|     /* gain de-quantization */ 
 | |
|  
 | |
|     gain[0] = gaindequant(gain_index[0], 1.0, 32); 
 | |
|     if (nStages > 1) { 
 | |
|         gain[1] = gaindequant(gain_index[1],  
 | |
|             (float)fabs(gain[0]), 16);   
 | |
|     } 
 | |
|     if (nStages > 2) { 
 | |
|         gain[2] = gaindequant(gain_index[2],  
 | |
|             (float)fabs(gain[1]), 8); 
 | |
|     } 
 | |
|  
 | |
|     /* codebook vector construction and construction of  
 | |
|     total vector */ 
 | |
|  
 | |
|     getCBvec(cbvec, mem, index[0], lMem, veclen); 
 | |
|     for (j=0;j<veclen;j++){ 
 | |
|         decvector[j] = gain[0]*cbvec[j]; 
 | |
|     } 
 | |
|     if (nStages > 1) { 
 | |
|         for (k=1; k<nStages; k++) { 
 | |
|             getCBvec(cbvec, mem, index[k], lMem, veclen); 
 | |
|             for (j=0;j<veclen;j++) { 
 | |
|                 decvector[j] += gain[k]*cbvec[j]; 
 | |
|             } 
 | |
|         } 
 | |
|     } 
 | |
| } 
 | |
|  
 | |
|  
 |