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

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

?? dtx.c

?? GSM中半速率語音編解碼源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
        bestQl[iSeg] = bestQl[0];

    }

    /* find the quantized reflection coefficients */
    /*--------------------------------------------*/

    setupQuant(iSeg, bestQl[iSeg].iRCIndex);    /* set up vector ptrs */
    getNextVec((Shortword *) (pswFinalRc - 1));


    /* Update pBarFull and vBarFull for the next Rc-VQ segment, and */
    /* update the pswPBar and pswVBar for the next Rc-VQ segment    */
    /*--------------------------------------------------------------*/

    if (iSeg < LPC_VQ_SEG)
      aflatNewBarRecursionL(&pswFinalRc[psvqIndex[iSeg - 1].l - 1], iSeg,
                            pL_PBarFull, pL_VBarFull, pswPBar, pswVBar);

  }

  /* find the quantizer index (the values to be output in the symbol file) */
  /*-----------------------------------------------------------------*/

  for (iSeg = 1; iSeg <= LPC_VQ_SEG; iSeg++)
    piVQCodewds[iSeg - 1] = bestQl[iSeg].iRCIndex;

}


/*************************************************************************
 *
 *   FUNCTION NAME: getPnBits
 *
 *   PURPOSE:
 *
 *     Generate iBits pseudo-random bits using *pL_PNSeed as the
 *     pn-generators seed.
 *
 *   INPUTS:
 *
 *     iBits - integer indicating how many random bits to return.
 *     range [0,15], 0 yields 1 bit output
 *
 *     *pL_PNSeed - 32 bit seed (changed by function)
 *
 *   OUTPUTS:
 *
 *     *pL_PNSeed - 32 bit seed, modified.
 *
 *   RETURN VALUE:
 *
 *    random bits in iBits LSB's.
 *
 *
 *   IMPLEMENTATION:
 *
 *    implementation of x**31 + x**3 + 1 == PN_XOR_REG | PN_XOR_ADD a
 *    PN sequence generator using Longwords generating a 2**31 -1
 *    length pn-sequence.
 *
 *************************************************************************/

Shortword getPnBits(int iBits, Longword *pL_PNSeed)
{

/*_________________________________________________________________________
 |                                                                         |
 |                            Automatic Variables                          |
 |_________________________________________________________________________|
*/

  Shortword swPnBits = 0;
  Longword L_Taps,
         L_FeedBack;
  int    i;

/*_________________________________________________________________________
 |                                                                         |
 |                              Executable Code                            |
 |_________________________________________________________________________|
*/

  for (i = 0; i < iBits; i++)
  {
    /* update the state */
    /* ---------------- */

    L_Taps = *pL_PNSeed & PN_XOR_REG;
    L_FeedBack = L_Taps;               /* Xor tap bits to yield
                                        * feedback bit */
    L_Taps = L_shr(L_Taps, 1);

    while (L_Taps)
    {
      L_FeedBack = L_FeedBack ^ L_Taps;
      L_Taps = L_shr(L_Taps, 1);
    }

    /* LSB of L_FeedBack is next MSB of PN register */

    *pL_PNSeed = L_shr(*pL_PNSeed, 1);
    if (L_FeedBack & 1)
      *pL_PNSeed = *pL_PNSeed | PN_XOR_ADD;

    /* State update complete.  Get the output bit from the state, add/or it
     * into output */

    swPnBits = shl(swPnBits, 1);
    swPnBits = swPnBits | (extract_l(*pL_PNSeed) & 0x0001);

  }
  return (swPnBits);
}


/*************************************************************************
 *
 *   FUNCTION NAME: rxInterpR0Lpc
 *
 *   PURPOSE:
 *
 *     Perform part of the comfort noise algorithm at the decoder.
 *     LPC and R0 are derived in this routine
 *
 *   INPUTS:
 *
 *     pswOldKs - Last frame's reflection coeffs.
 *
 *     pswNewKs - This frame's decoded/received reflection coeffs.
 *     This will serve a new endpoint in interpolation.
 *
 *     swRxDTXState - primary DTX state variable (at the receiver).  A
 *     modulo 12 counter, which is 0 at SID frame.
 *
 *     swDecoMode - actual mode the decoder: speech decoding mode
 *     or comfort noise insertion mode (SPEECH = speech decoding;
 *     CNIFIRSTSID = comfort noise, 1st SID received; CNICONT = comfort
 *     noise, SID frame received, but not 1st SID; CNIBFI = comfort
 *     noise, bad frame received)
 *
 *     swFrameType - type of the received frame (VALIDSID, INVALIDSID
 *     GOODSPEECH or UNUSABLE)
 *
 *     swOldR0Dec - global variable, the decoded R0 value from the last
 *     frame .  This will be modified.
 *
 *     swR0NewCN - global variable the decoded R0 value from the frame
 *     just received. Valid information if current frame is a SID frame.
 *
 *
 *   OUTPUTS:
 *
 *     pswNewKs - This frames LPC coeffs. modified to reflect
 *     interpolated correlation sequence pL_CorrSeq[].
 *
 *     swR0Dec - global variable, interpolated R0 value
 *
 *     swR0OldCN - global variable, R0 interpolation point to
 *     interpolate from.
 *
 *     swR0NewCN - global variable, R0 interpolation point to
 *     interpolate to.
 *
 *     pL_OldCorrSeq[NP+1] - global variable, starting point for
 *     interpolation of LPC information.
 *
 *     pL_NewCorrSeq[NP+1] - global variable, end point for
 *     interpolation of LPC information.
 *
 *     pL_CorrSeq[NP+1] - global variable, interpolated value of LPC
 *     information to be used in this frame.
 *
 *
 *   RETURN VALUE:
 *
 *     None.
 *
 *   KEYWORDS: interpolation, comfort noise, SID, DTX
 *
 *************************************************************************/

void   rxInterpR0Lpc(Shortword *pswOldKs, Shortword *pswNewKs,
                            Shortword swRxDTXState,
                            Shortword swDecoMode, Shortword swFrameType)
{

/*________________________________________________________________________
 |                                                                        |
 |                        Static Variables                                |
 |________________________________________________________________________|
*/

  static Shortword swR0OldCN;
  static Longword pL_OldCorrSeq[NP + 1],
         pL_NewCorrSeq[NP + 1],
         pL_CorrSeq[NP + 1];


/*_________________________________________________________________________
 |                                                                         |
 |                            Automatic Variables                          |
 |_________________________________________________________________________|
*/

  int    i;


/*_________________________________________________________________________
 |                                                                         |
 |                              Executable Code                            |
 |_________________________________________________________________________|
*/

  if (swDecoMode == CNIFIRSTSID)
  {
    /* first SID frame arrived */
    /* ----------------------- */

    /* use tx'd R0 frame as both endpoints of interp curve. */
    /* i.e. no interpolation for the first frames           */
    /* ---------------------------------------------------- */


    swR0OldCN = swOldR0Dec;            /* last non-SID, received R0 */
    swR0Dec = linInterpSidShort(swR0NewCN, swR0OldCN, swRxDTXState);


    /* generate the LPC end points for interpolation */
    /* --------------------------------------------- */

    rcToCorrDpL(ASHIFT, ASCALE, pswOldKs, pL_OldCorrSeq);
    rcToCorrDpL(ASHIFT, ASCALE, pswNewKs, pL_NewCorrSeq);

    /* linearly interpolate between the two sets of correlation coefs */
    /* -------------------------------------------------------------- */

    for (i = 0; i < NP + 1; i++)
    {
      pL_CorrSeq[i] = linInterpSid(pL_NewCorrSeq[i], pL_OldCorrSeq[i],
                                   swRxDTXState);
    }

    /* Generate this frames K's (overwrite input) */
    /* ------------------------------------------ */

    aFlatRcDp(pL_CorrSeq, pswNewKs);

  }
  else if ((swDecoMode == CNICONT) && (swFrameType == VALIDSID))
  {
    /* new (not the first) SID frame arrived */
    /* ------------------------------------- */

    swR0OldCN = swOldR0Dec;            /* move current state of R0 to old */
    swR0Dec = linInterpSidShort(swR0NewCN, swR0OldCN, swRxDTXState);


    /* LPC: generate new endpoints for interpolation */
    /* --------------------------------------------- */

    for (i = 0; i < NP + 1; i++)
    {
      pL_OldCorrSeq[i] = pL_CorrSeq[i];
    }

    rcToCorrDpL(ASHIFT, ASCALE, pswNewKs, pL_NewCorrSeq);


    /* linearly interpolate between the two sets of correlation coefs */
    /* -------------------------------------------------------------- */

    for (i = 0; i < NP + 1; i++)
    {
      pL_CorrSeq[i] = linInterpSid(pL_NewCorrSeq[i], pL_OldCorrSeq[i],
                                   swRxDTXState);
    }


    /* Use interpolated LPC for this frame, overwrite the input K's */
    /* ------------------------------------------------------------ */

    aFlatRcDp(pL_CorrSeq, pswNewKs);

  }
  else
  {
    /* in between SID frames / invalid SID frames */
    /* ------------------------------------------ */

    swR0Dec = linInterpSidShort(swR0NewCN, swR0OldCN, swRxDTXState);


    /* linearly interpolate between the two sets of correlation coefs */
    /* -------------------------------------------------------------- */

    for (i = 0; i < NP + 1; i++)
    {
      pL_CorrSeq[i] = linInterpSid(pL_NewCorrSeq[i], pL_OldCorrSeq[i],
                                   swRxDTXState);
    }


    /* Use interpolated LPC for this frame, overwrite the input K's */
    /* ------------------------------------------------------------ */

    aFlatRcDp(pL_CorrSeq, pswNewKs);

  }
}


/*************************************************************************
 *
 *   FUNCTION NAME: linInterpSid
 *
 *   PURPOSE:
 *
 *     Linearly interpolate between two input numbers based on what the
 *     current DtxState is.
 *
 *   INPUTS:
 *
 *     L_New - longword more current value
 *
 *     L_Old - longword oldest value
 *
 *     swDtxState - state is 0 at the transmitted SID Frame.
 *
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     A value between old and new inputs with dtxState+1/12 of the new
 *     (dtxState+1)-12/12 of the old
 *
 *
 *************************************************************************/

Longword linInterpSid(Longword L_New, Longword L_Old, Shortword swDtxState)
{

/*_________________________________________________________________________
 |                                                                         |
 |                            Automatic Variables                          |
 |_________________________________________________________________________|
*/

  Shortword swOldFactor;


/*_________________________________________________________________________
 |                                                                         |
 |                              Executable Code                            |
 |_________________________________________________________________________|
*/

  /* old factor = (1.0 - newFactor) */
  /* ------------------------------ */

  swOldFactor = sub(0x7fff, psrCNNewFactor[swDtxState]);
  swOldFactor = add(0x1, swOldFactor);


  /* contributions from new and old */
  /* ------------------------------ */

  L_New = L_mpy_ls(L_New, psrCNNewFactor[swDtxState]);
  L_Old = L_mpy_ls(L_Old, swOldFactor);

  return (L_add(L_New, L_Old));

}


/*************************************************************************
 *
 *   FUNCTION NAME: linInterpSidShort
 *
 *   PURPOSE:
 *
 *     Linearly interpolate between two input numbers based on what
 *     the current DtxState is.
 *
 *   INPUTS:
 *
 *     swNew - 16 bit,  more current value
 *
 *     swOld - 16 bit, oldest value
 *
 *     swDtxState - state is 0 at the transmitted SID Frame.
 *
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     A value between old and new inputs with dtxState+1/12 of the new
 *     (dtxState+1)-12/12 of the old
 *
 *************************************************************************/

Shortword linInterpSidShort(Shortword swNew, Shortword swOld,
                                   Shortword swDtxState)
{

/*_________________________________________________________________________
 |                                                                         |
 |                            Automatic Variables                          |
 |_________________________________________________________________________|
*/

  Shortword swOldFactor;
  Longword L_New,
         L_Old;


/*_________________________________________________________________________
 |                                                                         |
 |                              Executable Code                            |
 |_________________________________________________________________________|
*/

  /* old factor = (1.0 - newFactor) */
  /* ------------------------------ */

  swOldFactor = sub(0x7fff, psrCNNewFactor[swDtxState]);
  swOldFactor = add(0x1, swOldFactor);


  /* contributions from new and old */
  /* ------------------------------ */

  L_New = L_mult(swNew, psrCNNewFactor[swDtxState]);
  L_Old = L_mult(swOld, swOldFactor);


  return (round(L_add(L_New, L_Old)));

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
678五月天丁香亚洲综合网| 26uuu色噜噜精品一区二区| 欧美精品日韩精品| 久久无码av三级| 亚洲国产aⅴ成人精品无吗| 韩国一区二区三区| 欧美系列一区二区| 国产精品久久久久影院色老大 | 麻豆国产精品视频| 日本精品一区二区三区高清| 久久综合九色综合欧美就去吻| 一区二区三区在线视频免费观看| 国产在线精品视频| 欧美精品少妇一区二区三区| 国产精品久久国产精麻豆99网站 | 大尺度一区二区| 欧美一区二区三区人| 一区二区三区中文字幕精品精品 | 国产精品久久一级| 久久爱www久久做| 欧美二区乱c少妇| 亚洲一区二区av在线| 色综合天天综合网天天狠天天| 精品999在线播放| 奇米色一区二区三区四区| 色婷婷亚洲精品| 1024成人网色www| 国产成人在线观看| 国产日韩三级在线| 国产一区二区三区黄视频| 精品国产免费一区二区三区四区 | 日韩精品一区二区三区视频 | 国产不卡视频在线播放| 久久综合久色欧美综合狠狠| 日本最新不卡在线| 日韩欧美在线观看一区二区三区| 婷婷一区二区三区| 欧美久久久久久久久中文字幕| 亚洲一区二区四区蜜桃| 欧美日韩免费高清一区色橹橹 | 美女诱惑一区二区| 精品区一区二区| 国模无码大尺度一区二区三区 | 欧美一区二区三区婷婷月色| 日本欧美在线观看| 日韩午夜电影在线观看| 久久99国产精品久久99果冻传媒| 日韩精品自拍偷拍| 国产在线播精品第三| 中文字幕av不卡| 99精品视频在线免费观看| 亚洲另类春色国产| 欧美日韩精品欧美日韩精品一| 男男视频亚洲欧美| 久久久久久免费| 99久久精品国产导航| 一级女性全黄久久生活片免费| 欧美精品自拍偷拍| 国产一区二区三区黄视频| 国产精品久久久久久久岛一牛影视 | 国产一区二区美女| 国产精品免费观看视频| 91精品国产黑色紧身裤美女| 日本不卡免费在线视频| 久久久久国产精品人| 91在线看国产| 日本不卡1234视频| 欧美国产日韩一二三区| 欧美美女一区二区| 国产福利一区二区三区视频 | 美女一区二区三区在线观看| 欧美国产亚洲另类动漫| 在线观看免费成人| 韩日欧美一区二区三区| 亚洲动漫第一页| 亚洲精品在线免费观看视频| 99久久国产综合精品女不卡| 日日夜夜精品视频免费| 国产精品乱码妇女bbbb| 欧美一级专区免费大片| 91视频你懂的| 极品美女销魂一区二区三区免费| 国产精品视频你懂的| 日韩一级片在线播放| 91视频一区二区三区| 久久爱另类一区二区小说| 一区二区视频在线看| 国产亚洲一区二区三区在线观看| 欧美日韩精品福利| 99精品偷自拍| 粉嫩13p一区二区三区| 五月天中文字幕一区二区| 中文字幕不卡的av| 久久久99精品免费观看不卡| 91精品国产全国免费观看| 91亚洲男人天堂| 国产经典欧美精品| 乱一区二区av| 青青草国产精品亚洲专区无| 一区二区三区中文字幕在线观看| 中文字幕欧美日韩一区| 欧美电影免费观看高清完整版| 欧美在线一二三四区| 99re这里都是精品| 国产不卡高清在线观看视频| 久久国产三级精品| 日韩av一区二区三区四区| 亚洲制服欧美中文字幕中文字幕| 国产精品白丝在线| 亚洲国产精华液网站w| 精品福利二区三区| 日韩欧美一区中文| 欧美不卡一二三| 日韩欧美亚洲国产另类| 欧美一区二区大片| 91精品国产黑色紧身裤美女| 538在线一区二区精品国产| 7777女厕盗摄久久久| 欧美肥妇毛茸茸| 91精品国产高清一区二区三区| 欧美视频一区二区三区| 日本国产一区二区| 色综合久久天天综合网| 色哟哟亚洲精品| 日本福利一区二区| 欧美三区免费完整视频在线观看| 欧美无乱码久久久免费午夜一区 | 丰满亚洲少妇av| 成av人片一区二区| 91视频一区二区三区| 色88888久久久久久影院野外| 在线看日本不卡| 欧美日韩国产影片| 欧美性猛交xxxxxxxx| 欧美亚洲日本国产| 欧美久久久久久蜜桃| 91精品国产综合久久精品性色| 91精品国产综合久久久久久久| 欧美一区二区三区四区久久| 久久嫩草精品久久久精品| 中文字幕国产一区二区| 亚洲色图在线看| 亚洲成人777| 狠狠狠色丁香婷婷综合久久五月| 国产91色综合久久免费分享| 一本大道久久精品懂色aⅴ| 欧美少妇xxx| 亚洲精品一区二区在线观看| 国产精品欧美一区二区三区| 午夜成人免费视频| 国产成人综合在线播放| 91在线国产福利| 337p日本欧洲亚洲大胆精品| 国产欧美日韩卡一| 亚洲一区二区三区免费视频| 激情图片小说一区| 日本电影亚洲天堂一区| 日韩欧美中文字幕精品| 亚洲欧洲日韩av| 亚洲国产精品久久一线不卡| 国产剧情一区在线| 欧美亚男人的天堂| 国产欧美精品一区二区色综合朱莉| 最新国产の精品合集bt伙计| 青青草国产成人av片免费| av在线播放不卡| 精品久久久久久久久久久院品网| 亚洲欧洲99久久| 国内精品视频一区二区三区八戒| 91国偷自产一区二区开放时间| 精品少妇一区二区三区视频免付费| 亚洲男人的天堂网| 国产一区二区0| 欧美一区二区视频在线观看2022| 国产精品视频你懂的| 毛片一区二区三区| 欧美色男人天堂| 亚洲精品网站在线观看| 国产成人精品一区二区三区四区| 欧美精品第一页| 一区二区免费在线| 97久久精品人人爽人人爽蜜臀| 亚洲精品一区二区三区99| 亚洲高清一区二区三区| 色呦呦国产精品| 亚洲欧洲成人自拍| 成人久久视频在线观看| 久久夜色精品一区| 日本亚洲三级在线| 在线电影欧美成精品| 日韩精品视频网站| 在线免费观看日本欧美| 亚洲欧美综合色| 成人激情图片网| 欧美xxxx老人做受| 久99久精品视频免费观看| 日韩午夜av电影| 免费成人在线视频观看| 日韩网站在线看片你懂的| 麻豆精品国产91久久久久久|