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

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

?? sp_frm.c

?? GSM半數率源代碼(VSELP) GSM半數率源代碼(VSELP)
?? C
?? 第 1 頁 / 共 5 頁
字號:

  get_ipjj(pswLagList[0], &siIPLo, &siRemLo);

  get_ipjj(pswLagList[siNumLags - 1], &siIPHi, &siRemHi);

  /* get lag for first and last C and G required */
  /* ------------------------------------------- */

  siLoLag = sub(siIPLo, CG_INT_MACS / 2 - 1);

  if (siRemHi != 0)
  {
    siHiLag = add(siIPHi, CG_INT_MACS / 2);
  }
  else
  {
    siHiLag = add(siIPHi, CG_INT_MACS / 2 - 1);
  }

  /* transfer needed integer C's and G's to temp buffers */
  /* --------------------------------------------------- */

  psw1 = pswCBuf;
  psw2 = pswGBuf;

  if (siRemLo == 0)
  {

    /* first lag in list is integer: don't care about first entries */
    /* (they will be paired with zero tap in interpolating filter)  */
    /* ------------------------------------------------------------ */

    psw1[0] = 0;
    psw2[0] = 0;
    psw1 = &psw1[1];
    psw2 = &psw2[1];
  }

  for (siI = siLoLag; siI <= siHiLag; siI++)
  {
    psw1[siI - siLoLag] = pswCSfrm[siI - LSMIN];
    psw2[siI - siLoLag] = pswGSfrm[siI - LSMIN];
  }

  if (siRemLo == 0)
  {
    /* make siLoLag correspond to first entry in temp buffers */
    /* ------------------------------------------------------ */
    siLoLag = sub(siLoLag, 1);
  }

  /* interpolate to get C's and G's which correspond to lags in list */
  /* --------------------------------------------------------------- */

  CGInterp(pswLagList, siNumLags, pswCBuf, pswGBuf, siLoLag,
           pswCInterp, pswGInterp);

  /* find max C*C*sgn(C)/G */
  /* --------------------- */

  swPeak = maxCCOverGWithSign(pswCInterp, pswGInterp, &swCmaxSqr, &swGmax,
                              siNumLags);

  /* store best lag and corresponding C*C and G */
  /* ------------------------------------------ */

  pswLTraj[siSfrmIndex] = pswLagList[swPeak];
  pswCCTraj[siSfrmIndex] = swCmaxSqr;
  pswGTraj[siSfrmIndex] = swGmax;

}


/***************************************************************************
 *
 *   FUNCTION NAME: CGInterp
 *
 *   PURPOSE:
 *
 *     Given a list of fractional lags, a C(k) array, and a G(k) array
 *     (k integer), this function generates arrays of C's and G's
 *     corresponding to the list of fractional lags by interpolating the
 *     integer C(k) and G(k) arrays.
 *
 *   INPUTS:
 *
 *     pswLIn[0:siNum-1]
 *
 *                     List of valid lags
 *
 *     siNum
 *
 *                     Length of output lists
 *
 *     pswCIn[0:variable]
 *
 *                     C(k) sequence, k integer.  The zero index corresponds
 *                     to k = siLoIntLag.
 *
 *     pswGIn[0:variable]
 *
 *                     G(k) sequence, k integer.  The zero index corresponds
 *                     to k = siLoIntLag.
 *
 *     siLoIntLag
 *
 *                     Integer lag corresponding to the first entry in the
 *                     C(k) and G(k) input arrays.
 *
 *     ppsrCGIntFilt[0:5][0:5]
 *
 *                     The FIR interpolation filter for C's and G's.
 *
 *   OUTPUTS:
 *
 *     pswCOut[0:siNum-1]
 *
 *                     List of interpolated C's corresponding to pswLIn.
 *
 *     pswGOut[0:siNum-1]
 *
 *                     List of interpolated G's corresponding to pswLIn
 *
 *   RETURN VALUE: none
 *
 *   DESCRIPTION:
 *
 *
 *   REFERENCE:  Sub-clause 4.1.8.2, 4.1.8.3 of GSM Recommendation 06.20
 *
 *   KEYWORDS: lag, interpolateCG
 *
 *************************************************************************/

void   CGInterp(Shortword pswLIn[],
                       short siNum,
                       Shortword pswCIn[],
                       Shortword pswGIn[],
                       short siLoIntLag,
                       Shortword pswCOut[],
                       Shortword pswGOut[])
{

/*_________________________________________________________________________
 |                                                                         |
 |                            Automatic Variables                          |
 |_________________________________________________________________________|
*/
  Shortword i,
         swBig,
         swLoIntLag;
  Shortword swLagInt,
         swTempRem,
         swLagRem;
  Longword L_Temp,
         L_Temp1,
         L_Temp2;

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

  swLoIntLag = add(siLoIntLag, (CG_INT_MACS / 2) - 1);

  for (swBig = 0; swBig < siNum; swBig++)
  {

    /* Separate integer and fractional portions of lag */
    /*-------------------------------------------------*/
    L_Temp = L_mult(pswLIn[swBig], INV_OS_FCTR);
    swLagInt = extract_h(L_Temp);

    /* swLagRem = (OS_FCTR - pswLIn[iBig] % OS_FCTR)) */
    /*---------------------------------------------------*/
    swTempRem = extract_l(L_Temp);
    swTempRem = shr(swTempRem, 1);
    swLagRem = swTempRem & SW_MAX;
    swLagRem = mult_r(swLagRem, OS_FCTR);
    swLagRem = sub(OS_FCTR, swLagRem);

    /* Get interpolated C and G values */
    /*--------------------------*/

    L_Temp1 = L_mac(32768, pswCIn[swLagInt - swLoIntLag],
                    ppsrCGIntFilt[0][swLagRem]);
    L_Temp2 = L_mac(32768, pswGIn[swLagInt - swLoIntLag],
                    ppsrCGIntFilt[0][swLagRem]);

    for (i = 1; i <= CG_INT_MACS - 1; i++)
    {
      L_Temp1 = L_mac(L_Temp1, pswCIn[i + swLagInt - swLoIntLag],
                      ppsrCGIntFilt[i][swLagRem]);
      L_Temp2 = L_mac(L_Temp2, pswGIn[i + swLagInt - swLoIntLag],
                      ppsrCGIntFilt[i][swLagRem]);

    }
    pswCOut[swBig] = extract_h(L_Temp1);
    pswGOut[swBig] = extract_h(L_Temp2);
  }
}

/***************************************************************************
 *
 *   FUNCTION NAME: CGInterpValid
 *
 *   PURPOSE:
 *
 *     The purpose of this function is to retrieve the valid (codeable) lags
 *     within one (exclusive) integer sample of the given integer lag, and
 *     interpolate the corresponding C's and G's from the integer arrays
 *
 *   INPUTS:
 *
 *     swFullResLag
 *
 *                     integer lag * OS_FCTR
 *
 *     pswCIn[0:127]
 *
 *                     integer C sequence
 *
 *     pswGIn[0:127]
 *
 *                     integer G sequence
 *
 *     psrLagTbl[0:255]
 *
 *                     reference table of valid (codeable) lags
 *
 *
 *   OUTPUTS:
 *
 *     pswLOut[0:*psiNum-1]
 *
 *                     list of valid lags within 1 of swFullResLag
 *
 *     pswCOut[0:*psiNum-1]
 *
 *                     list of interpolated C's corresponding to pswLOut
 *
 *     pswGOut[0:*psiNum-1]
 *
 *                     list of interpolated G's corresponding to pswLOut
 *
 *   RETURN VALUE:
 *
 *     siNum
 *
 *                     length of output lists
 *
 *   DESCRIPTION:
 *
 *   REFERENCE:  Sub-clause 4.1.8.2, 4.1.9 of GSM Recommendation 06.20
 *
 *   KEYWORDS: CGInterpValid, cginterpvalid, CG_INT_VALID
 *
 *************************************************************************/

short  CGInterpValid(Shortword swFullResLag,
                            Shortword pswCIn[],
                            Shortword pswGIn[],
                            Shortword pswLOut[],
                            Shortword pswCOut[],
                            Shortword pswGOut[])
{

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

  short int siLowerBound,
         siUpperBound,
         siNum,
         siI;
  Shortword swLag;

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

  /* Get lower and upper bounds for valid lags     */
  /* within 1 (exclusive) integer lag of input lag */
  /* --------------------------------------------- */

  swLag = sub(swFullResLag, OS_FCTR);
  swLag = quantLag(swLag, &siLowerBound);
  if (sub(swLag, swFullResLag) != 0)
  {
    siLowerBound = add(siLowerBound, 1);
  }

  swLag = add(swFullResLag, OS_FCTR);
  swLag = quantLag(swLag, &siUpperBound);
  if (sub(swLag, swFullResLag) != 0)
  {
    siUpperBound = sub(siUpperBound, 1);
  }

  /* Get list of full resolution lags whose */
  /* C's and G's will be interpolated       */
  /* -------------------------------------- */

  siNum = sub(siUpperBound, siLowerBound);
  siNum = add(siNum, 1);

  for (siI = 0; siI < siNum; siI++)
  {
    pswLOut[siI] = psrLagTbl[siI + siLowerBound];
  }

  /* Interpolate C's and G's */
  /* ----------------------- */

  CGInterp(pswLOut, siNum, pswCIn, pswGIn, LSMIN, pswCOut,
           pswGOut);

  /* Return the length of the output lists */
  /* ------------------------------------- */

  return (siNum);
}

/***************************************************************************
 *
 *   FUNCTION NAME: compResidEnergy
 *
 *   PURPOSE:
 *
 *     Computes and compares the residual energy from interpolated and
 *     non-interpolated coefficients. From the difference determines
 *     the soft interpolation decision.
 *
 *   INPUTS:
 *
 *     pswSpeech[0:159] ( [0:F_LEN-1] )
 *
 *                     Input speech frame (after high-pass filtering).
 *
 *     ppswInterpCoef[0:3][0:9] ( [0:N_SUB-1][0:NP-1] )
 *
 *                     Set of interpolated LPC direct-form coefficients for
 *                     each subframe.
 *
 *     pswPreviousCoef[0:9} ( [0:NP-1] )
 *
 *                     Set of LPC direct-form coefficients corresponding to
 *                     the previous frame
 *
 *     pswCurrentCoef[0:9} ( [0:NP-1] )
 *
 *                     Set of LPC direct-form coefficients corresponding to
 *                     the current frame
 *
 *     psnsSqrtRs[0:3] ( [0:N_SUB-1] )
 *
 *                     Array of residual energy estimates for each subframe
 *                     based on interpolated coefficients.  Used for scaling.
 *
 *   RETURN:
 *
 *     Returned value indicates the coefficients to use for each subframe:
 *     One indicates interpolated coefficients are to be used, zero indicates
 *     un-interpolated coefficients are to be used.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产片一区二区三区| 婷婷一区二区三区| 亚洲一区二区三区四区五区中文| 日韩精品一区第一页| 国产精品影音先锋| 欧美久久久久中文字幕| 国产女人水真多18毛片18精品视频| 亚洲一区二区三区免费视频| 福利电影一区二区| 欧美成人在线直播| 一区二区三区精密机械公司| 欧美一区二区三区日韩视频| 国产精品入口麻豆原神| 日韩影院免费视频| 欧美在线观看18| 国产精品嫩草影院av蜜臀| 久久国产精品72免费观看| 欧美日本在线播放| 亚洲丝袜制服诱惑| 国产91清纯白嫩初高中在线观看| 精品国产91洋老外米糕| 奇米四色…亚洲| 欧美一级欧美一级在线播放| 亚洲成人高清在线| 精品视频一区二区三区免费| 亚洲免费av网站| 色婷婷av一区二区三区软件| 亚洲三级电影全部在线观看高清| 成人性视频免费网站| 久久人人97超碰com| 精品一区二区久久| 精品久久久久久最新网址| 久久99久久精品欧美| 精品国产区一区| 国产毛片精品国产一区二区三区| 精品毛片乱码1区2区3区| 久久成人久久鬼色| 午夜一区二区三区在线观看| 91免费看`日韩一区二区| 亚洲区小说区图片区qvod| 91热门视频在线观看| 亚洲欧美在线aaa| 91小视频在线观看| 亚洲gay无套男同| 欧美一区午夜视频在线观看 | 精品一区二区三区在线视频| 精品国产一二三区| www.欧美.com| 一二三四区精品视频| 欧美日韩国产首页| 看电视剧不卡顿的网站| 久久综合狠狠综合久久综合88| 成人丝袜视频网| 一区二区三区精品视频| 日韩亚洲欧美在线| 成人美女视频在线观看18| 亚洲欧美在线另类| 欧美一区二区三区色| 国产成人av电影在线| 亚洲欧美成aⅴ人在线观看| 欧美精品日韩综合在线| 国产麻豆一精品一av一免费| 亚洲免费三区一区二区| 正在播放一区二区| 波多野结衣在线一区| 亚洲综合精品久久| 精品91自产拍在线观看一区| 风流少妇一区二区| 视频一区视频二区在线观看| 久久精品无码一区二区三区| 在线视频一区二区三区| 狠狠色丁香久久婷婷综| 亚洲精品一二三四区| 日韩一区二区三区视频| 欧美电视剧免费观看| 色婷婷综合久色| 国精产品一区一区三区mba桃花 | 久久er99热精品一区二区| 国产精品久久久久久久久快鸭 | 91美女在线看| 美女视频黄频大全不卡视频在线播放| 国产精品色哟哟| 日韩欧美国产电影| 在线影院国内精品| 岛国精品一区二区| 激情综合五月婷婷| 亚洲va国产va欧美va观看| 国产欧美日韩视频在线观看| 337p亚洲精品色噜噜噜| 色系网站成人免费| 成人高清视频在线观看| 精品中文字幕一区二区小辣椒| 亚洲妇熟xx妇色黄| 亚洲欧洲一区二区三区| 久久婷婷国产综合国色天香| 欧美人体做爰大胆视频| a亚洲天堂av| 国产福利精品导航| 久久99精品一区二区三区三区| 五月婷婷激情综合网| 亚洲日本欧美天堂| 国产精品国产成人国产三级| 精品999在线播放| 一级日本不卡的影视| 1区2区3区欧美| 中文字幕电影一区| 久久久99精品久久| 久久久精品天堂| 日本一区免费视频| 久久久久国色av免费看影院| 精品sm捆绑视频| 久久精品一区蜜桃臀影院| 久久影院电视剧免费观看| 日韩你懂的在线播放| 日韩色在线观看| 精品久久国产字幕高潮| 2020国产精品自拍| 日本一区二区三区四区| 国产色91在线| 国产精品初高中害羞小美女文| 国产精品美女久久久久久久久| 国产日韩欧美综合在线| 中文字幕成人av| 亚洲日本va在线观看| 亚洲麻豆国产自偷在线| 亚洲视频免费观看| 亚洲国产日产av| 欧美aⅴ一区二区三区视频| 免费高清视频精品| 国内精品伊人久久久久av一坑| 国产精品77777竹菊影视小说| 国产ts人妖一区二区| 色婷婷国产精品久久包臀| 欧美剧情电影在线观看完整版免费励志电影 | 国产精品大尺度| 一区二区三区在线不卡| 日日噜噜夜夜狠狠视频欧美人| 美女在线一区二区| 国产精品一区久久久久| 国产成人精品免费视频网站| 色婷婷国产精品久久包臀| 91精品国产91久久久久久最新毛片| 精品日韩一区二区| 18成人在线观看| 免费观看日韩电影| eeuss鲁片一区二区三区| 欧美在线观看一区二区| 欧美成人精精品一区二区频| 国产精品二区一区二区aⅴ污介绍| 亚洲国产另类av| 国产超碰在线一区| 欧美午夜精品免费| 国产欧美日韩亚州综合| 午夜在线成人av| 国产成人欧美日韩在线电影 | 97久久久精品综合88久久| 欧美日韩不卡在线| 欧美国产日本视频| 无码av免费一区二区三区试看| 岛国av在线一区| 日韩欧美三级在线| 一区二区三区四区精品在线视频| 免费观看日韩av| 91福利视频网站| 国产精品视频一二| 久久99精品国产91久久来源| 欧美亚洲国产一卡| 国产精品传媒在线| 激情小说亚洲一区| 欧美精品九九99久久| 中文字幕永久在线不卡| 麻豆国产欧美日韩综合精品二区 | 93久久精品日日躁夜夜躁欧美| 欧美成人猛片aaaaaaa| 亚洲激情自拍偷拍| 成人黄色小视频| 久久欧美一区二区| 看电视剧不卡顿的网站| 欧美日韩激情一区二区| 亚洲视频每日更新| 97久久精品人人做人人爽| 欧美韩国一区二区| 精品中文字幕一区二区小辣椒| 欧美精品久久99| 五月天亚洲精品| 欧美色图在线观看| 亚洲综合av网| 在线一区二区视频| 亚洲一区成人在线| 91国偷自产一区二区开放时间 | 欧美美女直播网站| 亚洲最快最全在线视频| 色综合久久久久久久| 亚洲色图制服诱惑| 91亚洲精华国产精华精华液| 日韩久久一区二区| 日本道免费精品一区二区三区| 樱桃视频在线观看一区| 91香蕉视频在线| 一个色综合av|