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

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

?? mathhalf.c

?? GSM半數率源代碼(VSELP) GSM半數率源代碼(VSELP)
?? C
?? 第 1 頁 / 共 4 頁
字號:
 *     Put the 16 bit input into the 16 MSB's of the output Longword.  The
 *     LS 16 bits are zeroed.
 *
 *   INPUTS:
 *
 *     var1
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var1 <= 0x0000 7fff.
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_Out
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff 0000.
 *
 *
 *   KEYWORDS: deposit, assign, fractional assign
 *
 *************************************************************************/

Longword L_deposit_h(Shortword var1)
{
  Longword L_var2;

  L_var2 = (Longword) var1 << 16;
  return (L_var2);
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_deposit_l
 *
 *   PURPOSE:
 *
 *     Put the 16 bit input into the 16 LSB's of the output Longword with
 *     sign extension i.e. the top 16 bits are set to either 0 or 0xffff.
 *
 *   INPUTS:
 *
 *     var1
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var1 <= 0x0000 7fff.
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_Out
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0xffff 8000 <= L_var1 <= 0x0000 7fff.
 *
 *   KEYWORDS: deposit, assign
 *
 *************************************************************************/

Longword L_deposit_l(Shortword var1)
{
  Longword L_Out;

  L_Out = var1;
  return (L_Out);
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_mac
 *
 *   PURPOSE:
 *
 *     Multiply accumulate.  Fractionally multiply two 16 bit
 *     numbers together with saturation.  Add that result to the
 *     32 bit input with saturation.  Return the 32 bit result.
 *
 *   INPUTS:
 *
 *     var1
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var1 <= 0x0000 7fff.
 *     var2
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var2 <= 0x0000 7fff.
 *     L_var3
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var2 <= 0x7fff ffff.
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_Out
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *
 *   IMPLEMENTATION:
 *
 *     Fractionally multiply two 16 bit numbers together with
 *     saturation.  The only numbers which will cause saturation on
 *     the multiply are 0x8000 * 0x8000.
 *
 *     Add that result to the 32 bit input with saturation.
 *     Return the 32 bit result.
 *
 *     Please note that this is not a true multiply accumulate as
 *     most processors would implement it.  The 0x8000*0x8000
 *     causes and overflow for this instruction.  On most
 *     processors this would cause an overflow only if the 32 bit
 *     input added to it were positive or zero.
 *
 *   KEYWORDS: mac, multiply accumulate
 *
 *************************************************************************/

Longword L_mac(Longword L_var3, Shortword var1, Shortword var2)
{
  return (L_add(L_var3, L_mult(var1, var2)));
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_msu
 *
 *   PURPOSE:
 *
 *     Multiply and subtract.  Fractionally multiply two 16 bit
 *     numbers together with saturation.  Subtract that result from
 *     the 32 bit input with saturation.  Return the 32 bit result.
 *
 *   INPUTS:
 *
 *     var1
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var1 <= 0x0000 7fff.
 *     var2
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var2 <= 0x0000 7fff.
 *     L_var3
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var2 <= 0x7fff ffff.
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_Out
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *
 *   IMPLEMENTATION:
 *
 *     Fractionally multiply two 16 bit numbers together with
 *     saturation.  The only numbers which will cause saturation on
 *     the multiply are 0x8000 * 0x8000.
 *
 *     Subtract that result from the 32 bit input with saturation.
 *     Return the 32 bit result.
 *
 *     Please note that this is not a true multiply accumulate as
 *     most processors would implement it.  The 0x8000*0x8000
 *     causes and overflow for this instruction.  On most
 *     processors this would cause an overflow only if the 32 bit
 *     input added to it were negative or zero.
 *
 *   KEYWORDS: mac, multiply accumulate, msu
 *
 *************************************************************************/

Longword L_msu(Longword L_var3, Shortword var1, Shortword var2)
{
  return (L_sub(L_var3, L_mult(var1, var2)));
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_mult
 *
 *   PURPOSE:
 *
 *     Perform a fractional multipy of the two 16 bit input numbers
 *     with saturation.  Output a 32 bit number.
 *
 *   INPUTS:
 *
 *     var1
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var1 <= 0x0000 7fff.
 *     var2
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var2 <= 0x0000 7fff.
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_Out
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *
 *   IMPLEMENTATION:
 *
 *     Multiply the two the two 16 bit input numbers. If the
 *     result is within this range, left shift the result by one
 *     and output the 32 bit number.  The only possible overflow
 *     occurs when var1==var2==-0x8000.  In this case output
 *     0x7fff ffff.
 *
 *   KEYWORDS: multiply, mult, mpy
 *
 *************************************************************************/

Longword L_mult(Shortword var1, Shortword var2)
{
  Longword L_product;

  if (var1 == SW_MIN && var2 == SW_MIN)
    L_product = LW_MAX;                /* overflow */
  else
  {
    L_product = (Longword) var1 *var2; /* integer multiply */

    L_product = L_product << 1;
  }
  return (L_product);
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_negate
 *
 *   PURPOSE:
 *
 *     Negate the 32 bit input. 0x8000 0000's negated value is
 *     0x7fff ffff.
 *
 *   INPUTS:
 *
 *     L_var1
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_Out
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0001 <= L_var1 <= 0x7fff ffff.
 *
 *   KEYWORDS: negate, negative
 *
 *************************************************************************/

Longword L_negate(Longword L_var1)
{
  Longword L_Out;

  if (L_var1 == LW_MIN)
    L_Out = LW_MAX;
  else
    L_Out = -L_var1;
  return (L_Out);
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_shift_r
 *
 *   PURPOSE:
 *
 *     Shift and round.  Perform a shift right. After shifting, use
 *     the last bit shifted out of the LSB to round the result up
 *     or down.
 *
 *   INPUTS:
 *
 *     L_var1
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *     var2
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var2 <= 0x0000 7fff.
 *
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_var1
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *
 *
 *   IMPLEMENTATION:
 *
 *     Shift and round.  Perform a shift right. After shifting, use
 *     the last bit shifted out of the LSB to round the result up
 *     or down.  This is just like shift_r above except that the
 *     input/output is 32 bits as opposed to 16.
 *
 *     if var2 is positve perform a arithmetic left shift
 *     with saturation (see L_shl() above).
 *
 *     If var2 is zero simply return L_var1.
 *
 *     If var2 is negative perform a arithmetic right shift (L_shr)
 *     of L_var1 by (-var2)+1.  Add the LS bit of the result to
 *     L_var1 shifted right (L_shr) by -var2.
 *
 *     Note that there is no constraint on var2, so if var2 is
 *     -0xffff 8000 then -var2 is 0x0000 8000, not 0x0000 7fff.
 *     This is the reason the L_shl function is used.
 *
 *
 *   KEYWORDS:
 *
 *************************************************************************/

Longword L_shift_r(Longword L_var1, Shortword var2)
{
  Longword L_Out,
         L_rnd;

  if (var2 < -31)
  {
    L_Out = 0;
  }
  else if (var2 < 0)
  {
    /* right shift */
    L_rnd = L_shl(L_var1, var2 + 1) & 0x1;
    L_Out = L_add(L_shl(L_var1, var2), L_rnd);
  }
  else
    L_Out = L_shl(L_var1, var2);

  return (L_Out);
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_shl
 *
 *   PURPOSE:
 *
 *     Arithmetic shift left (or right).
 *     Arithmetically shift the input left by var2.   If var2 is
 *     negative then an arithmetic shift right (L_shr) of L_var1 by
 *     -var2 is performed.
 *
 *   INPUTS:
 *
 *     var2
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var2 <= 0x0000 7fff.
 *     L_var1
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *   OUTPUTS:
 *
 *     none
 *
 *   RETURN VALUE:
 *
 *     L_Out
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range
 *                     0x8000 0000 <= L_var1 <= 0x7fff ffff.
 *
 *
 *   IMPLEMENTATION:
 *
 *     Arithmetically shift the 32 bit input left by var2.  This
 *     operation maintains the sign of the input number. If var2 is
 *     negative then an arithmetic shift right (L_shr) of L_var1 by
 *     -var2 is performed.  See description of L_shr for details.
 *
 *     Equivalent to the Full-Rate GSM ">> n" operation.  Note that
 *     ANSI-C does not guarantee operation of the C ">>" or "<<"
 *     operator for negative numbers.
 *
 *   KEYWORDS: shift, arithmetic shift left,
 *
 *************************************************************************/

Longword L_shl(Longword L_var1, Shortword var2)
{

  Longword L_Mask,
         L_Out;
  int    i,
         iOverflow = 0;

  if (var2 == 0 || L_var1 == 0)
  {
    L_Out = L_var1;
  }
  else if (var2 < 0)
  {
    if (var2 <= -31)
    {
      if (L_var1 > 0)
        L_Out = 0;
      else
        L_Out = 0xffffffffL;
    }
    else
      L_Out = L_shr(L_var1, -var2);
  }
  else
  {

    if (var2 >= 31)
      iOverflow = 1;

    else
    {

      if (L_var1 < 0)
        L_Mask = LW_SIGN;              /* sign bit mask */
      else
        L_Mask = 0x0;
      L_Out = L_var1;
      for (i = 0; i < var2 && !iOverflow; i++)
      {
        /* check the sign bit */
        L_Out = (L_Out & 0x7fffffffL) << 1;
        if ((L_Mask ^ L_Out) & LW_SIGN)
          iOverflow = 1;
      }
    }

    if (iOverflow)
    {
      /* saturate */
      if (L_var1 > 0)
        L_Out = LW_MAX;
      else
        L_Out = LW_MIN;
    }
  }

  return (L_Out);
}

/***************************************************************************
 *
 *   FUNCTION NAME: L_shr
 *
 *   PURPOSE:
 *
 *     Arithmetic shift right (or left).
 *     Arithmetically shift the input right by var2.   If var2 is
 *     negative then an arithmetic shift left (shl) of var1 by
 *     -var2 is performed.
 *
 *   INPUTS:
 *
 *     var2
 *                     16 bit short signed integer (Shortword) whose value
 *                     falls in the range 0xffff 8000 <= var2 <= 0x0000 7fff.
 *     L_var1
 *                     32 bit long signed integer (Longword) whose value
 *                     falls in the range

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合综合久久综合| 国产很黄免费观看久久| 国产精一区二区三区| 在线电影院国产精品| 综合久久国产九一剧情麻豆| 成人妖精视频yjsp地址| 精品第一国产综合精品aⅴ| 日日摸夜夜添夜夜添精品视频| 色综合久久综合网97色综合| 国产精品欧美极品| av网站一区二区三区| 亚洲精品自拍动漫在线| 精品视频1区2区3区| 亚洲图片欧美一区| 欧美精品丝袜久久久中文字幕| 亚洲电影你懂得| 欧美一级片在线看| 国产米奇在线777精品观看| 久久亚洲综合色| fc2成人免费人成在线观看播放| 国产精品蜜臀在线观看| 91九色02白丝porn| 久久国产人妖系列| 国产精品灌醉下药二区| 欧美三区免费完整视频在线观看| 无吗不卡中文字幕| 国产欧美一区二区三区在线看蜜臀| 成人av午夜电影| 日本午夜一本久久久综合| 久久久久国产精品麻豆ai换脸| 成人app软件下载大全免费| 日韩精品电影一区亚洲| 国产亚洲综合在线| 欧美日韩精品欧美日韩精品| 国产精品资源网站| 三级在线观看一区二区| 国产精品福利影院| 日韩女优毛片在线| 91久久精品一区二区三| 国产高清成人在线| 免费成人你懂的| 亚洲国产欧美日韩另类综合| 国产日产欧美一区二区三区| 欧美肥妇free| 欧美色视频在线| 在线视频综合导航| 91在线无精精品入口| 不卡视频一二三| 国产成人综合网站| 国产精品一区二区黑丝| 久久er99热精品一区二区| 日本特黄久久久高潮| 一区2区3区在线看| 偷拍自拍另类欧美| 日本视频一区二区| 蜜桃av一区二区三区电影| 日韩av一区二区在线影视| 偷拍与自拍一区| 国内精品嫩模私拍在线| 毛片av一区二区| 国产精品18久久久久| av资源网一区| 欧美性高清videossexo| 欧美一区永久视频免费观看| 欧美一区二区三区视频免费播放| 欧美一区二区不卡视频| 久久综合九色欧美综合狠狠| 国产欧美一区二区三区在线看蜜臀| 久久精品欧美日韩| 夜夜精品视频一区二区| 日日摸夜夜添夜夜添国产精品| 日韩av成人高清| 成人午夜私人影院| 欧美特级限制片免费在线观看| 91精品国产黑色紧身裤美女| 久久久三级国产网站| 亚洲色图色小说| 日本成人在线看| 99久久精品99国产精品| 欧美一区二区精品在线| 国产欧美视频在线观看| 视频一区二区三区在线| 99免费精品视频| 精品美女一区二区| 亚洲成人免费在线观看| 国产.欧美.日韩| 欧美草草影院在线视频| 一区二区三区蜜桃| 成人国产精品免费观看动漫 | 亚洲电影第三页| 成人免费看视频| 久久久久久97三级| 蜜桃精品视频在线| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲激情图片小说视频| 国产精品88av| 久久久久久久久久久电影| 香蕉成人伊视频在线观看| 91国模大尺度私拍在线视频| 国产精品三级久久久久三级| 久久国产精品第一页| 欧美大片在线观看| 国产美女在线精品| 久久你懂得1024| 成人小视频在线观看| 中文字幕 久热精品 视频在线| 国产在线观看免费一区| 精品国产免费一区二区三区香蕉 | 亚洲乱码一区二区三区在线观看| av中文一区二区三区| 国产成人在线免费| 久久精品国产精品亚洲精品| 午夜亚洲国产au精品一区二区| 不卡一区二区三区四区| 中文字幕一区二区三区蜜月 | 欧美一区二区三区小说| 午夜国产不卡在线观看视频| 欧美一区二区三区爱爱| 国内精品不卡在线| 亚洲人成精品久久久久久| 欧美性色欧美a在线播放| 人人超碰91尤物精品国产| 欧美精品一区视频| 91丨porny丨国产| 日韩激情在线观看| 欧美国产精品一区二区| 欧洲精品一区二区三区在线观看| 免费av网站大全久久| 日韩伦理av电影| 亚洲精品在线观| 666欧美在线视频| 91蜜桃免费观看视频| 激情亚洲综合在线| 亚洲高清视频中文字幕| 中文字幕在线不卡一区| 69堂精品视频| 欧美中文字幕一区二区三区| 丰满白嫩尤物一区二区| 久久99精品久久久久久国产越南| 亚洲欧美日韩电影| 国产精品久久久久久久久久久免费看 | 99re视频这里只有精品| 国产在线播放一区三区四| 日本少妇一区二区| 亚洲chinese男男1069| 亚洲影视在线播放| 亚洲免费电影在线| 亚洲精品中文在线| 中文字幕在线免费不卡| 国产精品天干天干在观线| 久久综合色播五月| 欧美xxxxx牲另类人与| 日韩精品专区在线影院观看| 欧美精品自拍偷拍动漫精品| 欧美三级中文字| 在线91免费看| 日韩美女一区二区三区四区| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 亚洲一级在线观看| 丝袜美腿亚洲综合| 久久99久久久欧美国产| 国内久久精品视频| 波多野结衣一区二区三区| 成人动漫av在线| 欧美天天综合网| 精品99一区二区三区| 亚洲国产激情av| 天天影视涩香欲综合网| 韩日av一区二区| 色婷婷综合在线| 欧美精品久久99久久在免费线| 精品国产一区二区在线观看| 国产精品免费人成网站| 日精品一区二区三区| 国产成人免费9x9x人网站视频| a亚洲天堂av| 久久亚洲一级片| 亚洲高清视频中文字幕| youjizz国产精品| 91精品国产福利| 一区二区成人在线视频| 国产美女久久久久| 91精品国产欧美一区二区18 | 国产白丝精品91爽爽久久| 日本伦理一区二区| 欧美激情一区二区三区在线| 日本中文在线一区| 欧美无人高清视频在线观看| 欧美韩国日本不卡| 国内成人精品2018免费看| 538prom精品视频线放| 亚洲精选在线视频| 色菇凉天天综合网| 亚洲品质自拍视频| 99久久婷婷国产精品综合| 国产精品久久久久久久久晋中 | 免费成人av在线| 91精品婷婷国产综合久久| 亚洲国产精品久久人人爱蜜臀| jiyouzz国产精品久久|