亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ilbc_decode.c

?? 基于sip協議的網絡電話源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
   /******************************************************************       iLBC Speech Coder ANSI-C Source Code       iLBC_decode.c       Copyright (C) The Internet Society (2004).       All Rights Reserved.   ******************************************************************/   #include <math.h>   #include <stdlib.h>   #include "iLBC_define.h"   #include "StateConstructW.h"   #include "LPCdecode.h"   #include "iCBConstruct.h"   #include "doCPLC.h"   #include "helpfun.h"   #include "constants.h"   #include "packing.h"   #include "string.h"   #include "enhancer.h"   #include "hpOutput.h"   #include "syntFilter.h"   /*----------------------------------------------------------------*    *  Initiation of decoder instance.    *---------------------------------------------------------------*/   short initDecode(                   /* (o) Number of decoded                                              samples */       iLBC_Dec_Inst_t *iLBCdec_inst,  /* (i/o) Decoder instance */       int mode,                       /* (i) frame size mode */       int use_enhancer                /* (i) 1 to use enhancer                                              0 to run without                                                enhancer */   ){       int i;       iLBCdec_inst->mode = mode;       if (mode==30) {           iLBCdec_inst->blockl = BLOCKL_30MS;           iLBCdec_inst->nsub = NSUB_30MS;           iLBCdec_inst->nasub = NASUB_30MS;           iLBCdec_inst->lpc_n = LPC_N_30MS;           iLBCdec_inst->no_of_bytes = NO_OF_BYTES_30MS;           iLBCdec_inst->no_of_words = NO_OF_WORDS_30MS;           iLBCdec_inst->state_short_len=STATE_SHORT_LEN_30MS;           /* ULP init */           iLBCdec_inst->ULP_inst=&ULP_30msTbl;       }       else if (mode==20) {           iLBCdec_inst->blockl = BLOCKL_20MS;           iLBCdec_inst->nsub = NSUB_20MS;           iLBCdec_inst->nasub = NASUB_20MS;           iLBCdec_inst->lpc_n = LPC_N_20MS;           iLBCdec_inst->no_of_bytes = NO_OF_BYTES_20MS;           iLBCdec_inst->no_of_words = NO_OF_WORDS_20MS;           iLBCdec_inst->state_short_len=STATE_SHORT_LEN_20MS;           /* ULP init */           iLBCdec_inst->ULP_inst=&ULP_20msTbl;       }       else {           exit(2);       }       memset(iLBCdec_inst->syntMem, 0,           LPC_FILTERORDER*sizeof(float));       memcpy((*iLBCdec_inst).lsfdeqold, lsfmeanTbl,           LPC_FILTERORDER*sizeof(float));       memset(iLBCdec_inst->old_syntdenum, 0,           ((LPC_FILTERORDER + 1)*NSUB_MAX)*sizeof(float));       for (i=0; i<NSUB_MAX; i++)           iLBCdec_inst->old_syntdenum[i*(LPC_FILTERORDER+1)]=1.0;       iLBCdec_inst->last_lag = 20;       iLBCdec_inst->prevLag = 120;       iLBCdec_inst->per = 0.0;       iLBCdec_inst->consPLICount = 0;       iLBCdec_inst->prevPLI = 0;       iLBCdec_inst->prevLpc[0] = 1.0;       memset(iLBCdec_inst->prevLpc+1,0,           LPC_FILTERORDER*sizeof(float));       memset(iLBCdec_inst->prevResidual, 0, BLOCKL_MAX*sizeof(float));       iLBCdec_inst->seed=777;       memset(iLBCdec_inst->hpomem, 0, 4*sizeof(float));       iLBCdec_inst->use_enhancer = use_enhancer;       memset(iLBCdec_inst->enh_buf, 0, ENH_BUFL*sizeof(float));       for (i=0;i<ENH_NBLOCKS_TOT;i++)           iLBCdec_inst->enh_period[i]=(float)40.0;       iLBCdec_inst->prev_enh_pl = 0;       return (short)(iLBCdec_inst->blockl);   }   /*----------------------------------------------------------------*    *  frame residual decoder function (subrutine to iLBC_decode)    *---------------------------------------------------------------*/   void Decode(       iLBC_Dec_Inst_t *iLBCdec_inst,  /* (i/o) the decoder state                                                structure */       float *decresidual,             /* (o) decoded residual frame */       int start,                      /* (i) location of start                                              state */       int idxForMax,                  /* (i) codebook index for the                                              maximum value */       int *idxVec,                /* (i) codebook indexes for the                                              samples  in the start                                              state */       float *syntdenum,               /* (i) the decoded synthesis                                              filter coefficients */       int *cb_index,                  /* (i) the indexes for the                                              adaptive codebook */       int *gain_index,            /* (i) the indexes for the                                              corresponding gains */       int *extra_cb_index,        /* (i) the indexes for the                                              adaptive codebook part                                              of start state */       int *extra_gain_index,          /* (i) the indexes for the                                              corresponding gains */       int state_first                 /* (i) 1 if non adaptive part                                              of start state comes                                              first 0 if that part                                              comes last */   ){       float reverseDecresidual[BLOCKL_MAX], mem[CB_MEML];       int k, meml_gotten, Nfor, Nback, i;       int diff, start_pos;       int subcount, subframe;       diff = STATE_LEN - iLBCdec_inst->state_short_len;       if (state_first == 1) {           start_pos = (start-1)*SUBL;       } else {           start_pos = (start-1)*SUBL + diff;       }       /* decode scalar part of start state */       StateConstructW(idxForMax, idxVec,           &syntdenum[(start-1)*(LPC_FILTERORDER+1)],           &decresidual[start_pos], iLBCdec_inst->state_short_len);       if (state_first) { /* put adaptive part in the end */           /* setup memory */           memset(mem, 0,               (CB_MEML-iLBCdec_inst->state_short_len)*sizeof(float));           memcpy(mem+CB_MEML-iLBCdec_inst->state_short_len,               decresidual+start_pos,               iLBCdec_inst->state_short_len*sizeof(float));           /* construct decoded vector */           iCBConstruct(               &decresidual[start_pos+iLBCdec_inst->state_short_len],               extra_cb_index, extra_gain_index, mem+CB_MEML-stMemLTbl,               stMemLTbl, diff, CB_NSTAGES);       }       else {/* put adaptive part in the beginning */           /* create reversed vectors for prediction */           for (k=0; k<diff; k++) {               reverseDecresidual[k] =                   decresidual[(start+1)*SUBL-1-                           (k+iLBCdec_inst->state_short_len)];           }           /* setup memory */           meml_gotten = iLBCdec_inst->state_short_len;           for (k=0; k<meml_gotten; k++){               mem[CB_MEML-1-k] = decresidual[start_pos + k];           }           memset(mem, 0, (CB_MEML-k)*sizeof(float));           /* construct decoded vector */           iCBConstruct(reverseDecresidual, extra_cb_index,               extra_gain_index, mem+CB_MEML-stMemLTbl, stMemLTbl,               diff, CB_NSTAGES);           /* get decoded residual from reversed vector */           for (k=0; k<diff; k++) {               decresidual[start_pos-1-k] = reverseDecresidual[k];           }       }       /* counter for predicted sub-frames */       subcount=0;       /* forward prediction of sub-frames */       Nfor = iLBCdec_inst->nsub-start-1;       if ( Nfor > 0 ){           /* setup memory */           memset(mem, 0, (CB_MEML-STATE_LEN)*sizeof(float));           memcpy(mem+CB_MEML-STATE_LEN, decresidual+(start-1)*SUBL,               STATE_LEN*sizeof(float));           /* loop over sub-frames to encode */           for (subframe=0; subframe<Nfor; subframe++) {               /* construct decoded vector */               iCBConstruct(&decresidual[(start+1+subframe)*SUBL],                   cb_index+subcount*CB_NSTAGES,                   gain_index+subcount*CB_NSTAGES,                   mem+CB_MEML-memLfTbl[subcount],                   memLfTbl[subcount], SUBL, CB_NSTAGES);               /* update memory */               memcpy(mem, mem+SUBL, (CB_MEML-SUBL)*sizeof(float));               memcpy(mem+CB_MEML-SUBL,                   &decresidual[(start+1+subframe)*SUBL],                   SUBL*sizeof(float));               subcount++;           }       }       /* backward prediction of sub-frames */       Nback = start-1;       if ( Nback > 0 ) {           /* setup memory */           meml_gotten = SUBL*(iLBCdec_inst->nsub+1-start);           if ( meml_gotten > CB_MEML ) {               meml_gotten=CB_MEML;           }           for (k=0; k<meml_gotten; k++) {               mem[CB_MEML-1-k] = decresidual[(start-1)*SUBL + k];           }           memset(mem, 0, (CB_MEML-k)*sizeof(float));           /* loop over subframes to decode */           for (subframe=0; subframe<Nback; subframe++) {               /* construct decoded vector */               iCBConstruct(&reverseDecresidual[subframe*SUBL],                   cb_index+subcount*CB_NSTAGES,                   gain_index+subcount*CB_NSTAGES,                   mem+CB_MEML-memLfTbl[subcount], memLfTbl[subcount],                   SUBL, CB_NSTAGES);               /* update memory */               memcpy(mem, mem+SUBL, (CB_MEML-SUBL)*sizeof(float));               memcpy(mem+CB_MEML-SUBL,                   &reverseDecresidual[subframe*SUBL],                   SUBL*sizeof(float));               subcount++;           }           /* get decoded residual from reversed vector */           for (i=0; i<SUBL*Nback; i++)               decresidual[SUBL*Nback - i - 1] =               reverseDecresidual[i];       }   }   /*----------------------------------------------------------------*    *  main decoder function    *---------------------------------------------------------------*/   void iLBC_decode(       float *decblock,            /* (o) decoded signal block */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文av一区特黄| 欧美日本国产视频| 欧美色图片你懂的| 日韩久久免费av| 一区二区在线观看视频| 久久精品免费观看| 色爱区综合激月婷婷| 精品久久人人做人人爱| 亚洲国产精品人人做人人爽| 成人精品国产福利| 精品久久久久久久久久久院品网 | 99视频有精品| 欧美一区国产二区| 亚洲电影欧美电影有声小说| 91免费国产在线观看| 精品国产sm最大网站免费看| 亚洲一区免费在线观看| 99精品久久免费看蜜臀剧情介绍| 欧美色老头old∨ideo| 国产激情视频一区二区三区欧美 | 国产成人精品免费在线| 中文字幕不卡在线| 一本大道久久a久久精二百| 日日欢夜夜爽一区| 激情图片小说一区| 欧美日本在线观看| 亚洲一区二区三区四区中文字幕| 国产成人精品免费| 久久久久高清精品| 国产成人精品亚洲日本在线桃色| 久久综合九色综合97婷婷| 久久国产精品无码网站| 91精品国产日韩91久久久久久| 亚洲成人高清在线| 日韩欧美一区二区免费| 日韩精品成人一区二区三区| 欧美丰满嫩嫩电影| 奇米影视7777精品一区二区| 日韩精品一区二区三区视频播放 | 国产精品亚洲专一区二区三区| 日韩女优av电影在线观看| 美女网站在线免费欧美精品| 精品国产麻豆免费人成网站| 韩国av一区二区| 国产精品污www在线观看| 91首页免费视频| 三级在线观看一区二区| 91精品国产aⅴ一区二区| 六月丁香综合在线视频| 久久精品亚洲精品国产欧美| av亚洲精华国产精华精华 | 欧美午夜不卡视频| 午夜国产精品一区| 精品国产一区久久| 国产激情一区二区三区四区 | 欧美日韩视频在线观看一区二区三区| 亚洲精品美腿丝袜| 日韩一级高清毛片| www.成人网.com| 日本在线不卡视频一二三区| 久久精品在这里| 欧美这里有精品| 久久97超碰国产精品超碰| 国产精品久久久久影视| 在线观看亚洲a| 久草在线在线精品观看| 国产精品久久久久9999吃药| 欧美日韩一区高清| 精品一区二区三区免费播放| 国产精品久久久久久久岛一牛影视 | 91美女在线看| 秋霞电影网一区二区| 国产精品美女一区二区| 91精品国产乱码| 国产成人8x视频一区二区| 亚洲精品伦理在线| 精品国产凹凸成av人网站| 日本丶国产丶欧美色综合| 久久99久久久欧美国产| 樱桃视频在线观看一区| 久久久久久久久岛国免费| 欧洲精品中文字幕| 盗摄精品av一区二区三区| 婷婷开心激情综合| 中文字幕在线一区免费| 欧美不卡视频一区| 欧美日韩国产欧美日美国产精品| www.欧美亚洲| 国产精品综合在线视频| 人人超碰91尤物精品国产| 亚洲激情在线激情| 国产精品嫩草影院com| 欧美成人激情免费网| 欧美偷拍一区二区| 一本久道久久综合中文字幕| 国产原创一区二区三区| 日韩经典中文字幕一区| 一区二区欧美在线观看| 日本一区二区免费在线观看视频| 91精品欧美福利在线观看| 在线免费观看日本欧美| av成人老司机| 成人av在线资源| 丁香网亚洲国际| 国产91在线|亚洲| 国产一区二区三区免费播放| 美女网站视频久久| 三级不卡在线观看| 视频一区中文字幕国产| 亚洲午夜久久久久| 亚洲大片在线观看| 亚洲国产日韩精品| 亚洲一区二区三区四区在线观看| 亚洲免费在线看| 自拍视频在线观看一区二区| 国产精品理论在线观看| 国产精品丝袜91| 日本一区二区在线不卡| 国产精品久久免费看| 自拍偷自拍亚洲精品播放| 国产精品色哟哟| 最新成人av在线| 一区二区三区欧美久久| 亚洲大型综合色站| 美脚の诱脚舐め脚责91| 国产一区二区三区日韩| 高清shemale亚洲人妖| 成人av在线一区二区三区| 91美女在线看| 欧美另类久久久品| 日韩免费看的电影| 久久久久久久综合狠狠综合| 国产精品久久久久久久久图文区 | 亚洲欧美日韩国产综合在线| 亚洲三级视频在线观看| 亚洲成av人**亚洲成av**| 麻豆精品久久精品色综合| 国产成人精品1024| 91美女在线视频| 91精品久久久久久久久99蜜臂| 欧美v国产在线一区二区三区| 久久久国产精品不卡| 亚洲青青青在线视频| 日韩一区精品视频| 7777精品伊人久久久大香线蕉超级流畅 | 欧洲色大大久久| 欧美在线视频你懂得| 色域天天综合网| 精品1区2区3区| 一区二区久久久| 国产传媒日韩欧美成人| 久久久亚洲高清| 激情综合色丁香一区二区| 91年精品国产| 日韩欧美国产小视频| 亚洲午夜视频在线观看| kk眼镜猥琐国模调教系列一区二区| 9191久久久久久久久久久| 欧美一区二区三区四区五区| 久久午夜免费电影| 精品一区二区三区久久| 欧美一级在线观看| 最近日韩中文字幕| av成人老司机| 亚洲韩国一区二区三区| av成人老司机| 亚洲一区二区视频在线| av网站一区二区三区| 精品区一区二区| 日韩成人午夜精品| 日韩欧美亚洲国产精品字幕久久久| 亚洲午夜影视影院在线观看| 国产一区二区三区免费| 91精品国产综合久久精品麻豆| 欧美成va人片在线观看| 久久99精品国产.久久久久久| 欧美一区二区三区在线观看| 亚洲国产成人高清精品| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 一区二区在线电影| 波多野结衣中文字幕一区二区三区| 91麻豆国产香蕉久久精品| 亚洲高清中文字幕| 久久综合久久综合久久| 一本到高清视频免费精品| 韩国视频一区二区| 奇米色一区二区| 亚洲精品视频自拍| 亚洲女女做受ⅹxx高潮| 欧美精品一区二区不卡| 国产91精品久久久久久久网曝门| 亚洲一区二区不卡免费| 欧美性猛交xxxx乱大交退制版 | 成人午夜免费电影| 偷拍一区二区三区四区| 国产精品99久久久久久似苏梦涵| 欧美伊人久久久久久午夜久久久久| 国产精品女同一区二区三区| 国产乱国产乱300精品| 国产欧美一区二区精品婷婷|