www.pudn.com > g729.rar > decoder.c
/* ITU-T G.729A Speech Coder ANSI-C Source Code Version 1.1 Last modified: September 1996 Copyright (c) 1996, AT&T, France Telecom, NTT, Universite de Sherbrooke All rights reserved. */ /*-----------------------------------------------------------------* * Main program of the G.729a 8.0 kbit/s decoder. * * * * Usage : decoder bitstream_file synth_file * * * *-----------------------------------------------------------------*/ #include#include #include "typedef.h" #include "basic_op.h" #include "ld8a.h" Word16 bad_lsf; /* bad LSF indicator */ /* This variable should be always set to zero unless transmission errors in LSP indices are detected. This variable is useful if the channel coding designer decides to perform error checking on these important parameters. If an error is detected on the LSP indices, the corresponding flag is set to 1 signalling to the decoder to perform parameter substitution. (The flags should be set back to 0 for correct transmission). */ /*-----------------------------------------------------------------* * Main decoder routine * *-----------------------------------------------------------------*/ #define PCM_WAVE_FORMAT 1 typedef struct { u_long dwSize ; u_short wFormatTag ; u_short wChannels ; u_long dwSamplesPerSec ; u_long dwAvgBytesPerSec ; u_short wBlockAlign ; u_short wBitsPerSample ; } WAVEFORMAT ; typedef struct { char RiffID [4] ; u_long RiffSize ; char WaveID [4] ; char FmtID [4] ; u_long FmtSize ; u_short wFormatTag ; u_short nChannels ; u_long nSamplesPerSec ; u_long nAvgBytesPerSec ; u_short nBlockAlign ; u_short wBitsPerSample ; char DataID [4] ; u_long nDataBytes ; } WAVE_HEADER ; /* static WAVE_HEADER waveheader = { { 'R', 'I', 'F', 'F' }, 0, { 'W', 'A', 'V', 'E' }, { 'f', 'm', 't', ' ' }, 16, PCM_WAVE_FORMAT, 0, 0, 0, 0, 0, { 'd', 'a', 't', 'a' }, 0 } ; */ /* waveheader*/ int main(int argc, char *argv[] ) { Word16 synth_buf[L_FRAME+M], *synth; /* Synthesis */ Word16 parm[PRM_SIZE+1]; /* Synthesis parameters */ Word16 serial[SERIAL_SIZE]; /* Serial stream */ Word16 Az_dec[MP1*2]; /* Decoded Az for post-filter */ Word16 T2[2]; /* Pitch lag for 2 subframes */ WAVE_HEADER mywaveheader; int headerback; Word16 i, frame; FILE *f_syn, *f_serial; int sampbits=16; int channels=1; u_long samplerate=8000; u_long databytes; u_long samples=(80*10000); u_short blockalign ; Word16 serial_temp[5]; printf("\n"); printf("************ G.729a 8.0 KBIT/S SPEECH DECODER ************\n"); printf("\n"); printf("------------------- Fixed point C simulation ----------------\n"); printf("\n"); printf("----------------- Version 1.1 ---------------\n"); printf("\n"); /* Passed arguments */ if ( argc != 3) { printf("Usage :%s bitstream_file outputspeech_file\n",argv[0]); printf("\n"); printf("Format for bitstream_file:\n"); printf(" One (2-byte) synchronization word \n"); printf(" One (2-byte) size word,\n"); printf(" 80 words (2-byte) containing 80 bits.\n"); printf("\n"); printf("Format for outputspeech_file:\n"); printf(" Synthesis is written to a binary file of 16 bits data.\n"); exit( 1 ); } /* Open file for synthesis and packed serial stream */ if( (f_serial = fopen(argv[1],"rb") ) == NULL ) { printf("%s - Error opening file %s !!\n", argv[0], argv[1]); exit(0); } if( (f_syn = fopen(argv[2], "wb") ) == NULL ) { printf("%s - Error opening file %s !!\n", argv[0], argv[2]); fclose(f_serial); exit(0); } printf("Input bitstream file : %s\n",argv[1]); printf("Synthesis speech file : %s\n",argv[2]); /*-----------------------------------------------------------------* * Initialization of decoder * *-----------------------------------------------------------------*/ //int samplebits=16; headerback=0-sizeof(mywaveheader); if((fseek(f_serial,headerback,SEEK_END))==-1) { printf("Error,fail to fseek f_serial from the end!\n"); fclose(f_serial); fclose(f_syn); exit(0); } if((fread(&mywaveheader,sizeof(mywaveheader),1L,f_serial))<1) { printf("Error,fail to get the waveheader of the g729 file!\n"); fclose(f_serial); fclose(f_syn); exit(0); } rewind(f_serial); /*printf("Number of samples is %ld!\n",samples); rewind(f_serial); samples = samples*80; sampbits = (sampbits == 16) ? 16 : 8 ; blockalign = ((sampbits == 16) ? 2 : 1) * channels ; databytes = samples * (u_long) blockalign ; waveheader.RiffSize = sizeof (WAVE_HEADER) + databytes - 8 ; waveheader.wFormatTag = PCM_WAVE_FORMAT ; waveheader.nChannels = channels ; waveheader.nSamplesPerSec = samplerate ; waveheader.nAvgBytesPerSec = samplerate * (u_long) blockalign ; waveheader.nBlockAlign = blockalign ; waveheader.wBitsPerSample = sampbits ; waveheader.nDataBytes = databytes; */ if((fwrite(&mywaveheader,sizeof(mywaveheader),1L,f_syn))<1) { printf("Error: Fail to Write the WaveHeader to the file!\n"); fclose(f_serial); fclose(f_syn); exit(1); } for (i=0; i