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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? poly_l2.c

?? 內(nèi)核是系統(tǒng)的心臟
?? C
字號(hào):
/*---------------------------------------------------------------------------+
 |  poly_l2.c                                                                |
 |                                                                           |
 | Compute the base 2 log of a FPU_REG, using a polynomial approximation.    |
 |                                                                           |
 | Copyright (C) 1992,1993                                                   |
 |                       W. Metzenthen, 22 Parker St, Ormond, Vic 3163,      |
 |                       Australia.  E-mail   billm@vaxc.cc.monash.edu.au    |
 |                                                                           |
 |                                                                           |
 +---------------------------------------------------------------------------*/


#include "exception.h"
#include "reg_constant.h"
#include "fpu_emu.h"
#include "control_w.h"



#define	HIPOWER	9
static unsigned short const	lterms[HIPOWER][4] =
	{
	/* Ideal computation with these coeffs gives about
	   64.6 bit rel accuracy. */
	{ 0xe177, 0xb82f, 0x7652, 0x7154 },
	{ 0xee0f, 0xe80f, 0x2770, 0x7b1c },
	{ 0x0fc0, 0xbe87, 0xb143, 0x49dd },
	{ 0x78b9, 0xdadd, 0xec54, 0x34c2 },
	{ 0x003a, 0x5de9, 0x628b, 0x2909 },
	{ 0x5588, 0xed16, 0x4abf, 0x2193 },
	{ 0xb461, 0x85f7, 0x347a, 0x1c6a },
	{ 0x0975, 0x87b3, 0xd5bf, 0x1876 },
	{ 0xe85c, 0xcec9, 0x84e7, 0x187d }
	};




/*--- poly_l2() -------------------------------------------------------------+
 |   Base 2 logarithm by a polynomial approximation.                         |
 +---------------------------------------------------------------------------*/
void	poly_l2(FPU_REG const *arg, FPU_REG *result)
{
  short		  exponent;
  char		  zero;		/* flag for an Xx == 0 */
  unsigned short  bits, shift;
  unsigned long long       Xsq;
  FPU_REG	  accum, denom, num, Xx;


  exponent = arg->exp - EXP_BIAS;

  accum.tag = TW_Valid;	/* set the tags to Valid */

  if ( arg->sigh > (unsigned)0xb504f334 )
    {
      /* This is good enough for the computation of the polynomial
	 sum, but actually results in a loss of precision for
	 the computation of Xx. This will matter only if exponent
	 becomes zero. */
      exponent++;
      accum.sign = 1;	/* sign to negative */
      num.exp = EXP_BIAS;  /* needed to prevent errors in div routine */
      reg_u_div(&CONST_1, arg, &num, FULL_PRECISION);
    }
  else
    {
      accum.sign = 0;	/* set the sign to positive */
      num.sigl = arg->sigl;		/* copy the mantissa */
      num.sigh = arg->sigh;
    }


  /* shift num left, lose the ms bit */
  num.sigh <<= 1;
  if ( num.sigl & 0x80000000 ) num.sigh |= 1;
  num.sigl <<= 1;

  denom.sigl = num.sigl;
  denom.sigh = num.sigh;
  poly_div4(&significand(&denom));
  denom.sigh += 0x80000000;			/* set the msb */
  Xx.exp = EXP_BIAS;  /* needed to prevent errors in div routine */
  reg_u_div(&num, &denom, &Xx, FULL_PRECISION);

  zero = !(Xx.sigh | Xx.sigl);
  
  mul64(&significand(&Xx), &significand(&Xx), &Xsq);
  poly_div16(&Xsq);

  accum.exp = -1;		/* exponent of accum */

  /* Do the basic fixed point polynomial evaluation */
  polynomial((unsigned *)&accum.sigl, (unsigned *)&Xsq, lterms, HIPOWER-1);

  if ( !exponent )
    {
      /* If the exponent is zero, then we would lose precision by
	 sticking to fixed point computation here */
      /* We need to re-compute Xx because of loss of precision. */
      FPU_REG   lXx;
      char	sign;
      
      sign = accum.sign;
      accum.sign = 0;

      /* make accum compatible and normalize */
      accum.exp = EXP_BIAS + accum.exp;
      normalize(&accum);

      if ( zero )
	{
	  reg_move(&CONST_Z, result);
	}
      else
	{
	  /* we need to re-compute lXx to better accuracy */
	  num.tag = TW_Valid;		/* set the tags to Vaild */
	  num.sign = 0;		/* set the sign to positive */
	  num.exp = EXP_BIAS - 1;
	  if ( sign )
	    {
	      /* The argument is of the form 1-x */
	      /* Use  1-1/(1-x) = x/(1-x) */
	      significand(&num) = - significand(arg);
	      normalize(&num);
	      reg_div(&num, arg, &num, FULL_PRECISION);
	    }
	  else
	    {
	      normalize(&num);
	    }

	  denom.tag = TW_Valid;	/* set the tags to Valid */
	  denom.sign = SIGN_POS;	/* set the sign to positive */
	  denom.exp = EXP_BIAS;
	  
	  reg_div(&num, &denom, &lXx, FULL_PRECISION);

	  reg_u_mul(&lXx, &accum, &accum, FULL_PRECISION);

	  reg_u_add(&lXx, &accum, result, FULL_PRECISION);
	  
	  normalize(result);
	}

      result->sign = sign;
      return;
    }

  mul64(&significand(&accum),
	&significand(&Xx), &significand(&accum));

  significand(&accum) += significand(&Xx);

  if ( Xx.sigh > accum.sigh )
    {
      /* There was an overflow */

      poly_div2(&significand(&accum));
      accum.sigh |= 0x80000000;
      accum.exp++;
    }

  /* When we add the exponent to the accum result later, we will
     require that their signs are the same. Here we ensure that
     this is so. */
  if ( exponent && ((exponent < 0) ^ (accum.sign)) )
    {
      /* signs are different */

      accum.sign = !accum.sign;

      /* An exceptional case is when accum is zero */
      if ( accum.sigl | accum.sigh )
	{
	  /* find 1-accum */
	  /* Shift to get exponent == 0 */
	  if ( accum.exp < 0 )
	    {
	      poly_div2(&significand(&accum));
	      accum.exp++;
	    }
	  /* Just negate, but throw away the sign */
	  significand(&accum) = - significand(&accum);
	  if ( exponent < 0 )
	    exponent++;
	  else
	    exponent--;
	}
    }

  shift = exponent >= 0 ? exponent : -exponent ;
  bits = 0;
  if ( shift )
    {
      if ( accum.exp )
	{
	  accum.exp++;
	  poly_div2(&significand(&accum));
	}
      while ( shift )
	{
	  poly_div2(&significand(&accum));
	  if ( shift & 1)
	    accum.sigh |= 0x80000000;
	  shift >>= 1;
	  bits++;
	}
    }

  /* Convert to 64 bit signed-compatible */
  accum.exp += bits + EXP_BIAS - 1;

  reg_move(&accum, result);
  normalize(result);

  return;
}


/*--- poly_l2p1() -----------------------------------------------------------+
 |   Base 2 logarithm by a polynomial approximation.                         |
 |   log2(x+1)                                                               |
 +---------------------------------------------------------------------------*/
int	poly_l2p1(FPU_REG const *arg, FPU_REG *result)
{
  char		sign = 0;
  unsigned long long     Xsq;
  FPU_REG      	arg_pl1, denom, accum, local_arg, poly_arg;


  sign = arg->sign;

  reg_add(arg, &CONST_1, &arg_pl1, FULL_PRECISION);

  if ( (arg_pl1.sign) | (arg_pl1.tag) )
    {			/* We need a valid positive number! */
      return 1;
    }

  reg_add(&CONST_1, &arg_pl1, &denom, FULL_PRECISION);
  reg_div(arg, &denom, &local_arg, FULL_PRECISION);
  local_arg.sign = 0;	/* Make the sign positive */

  /* Now we need to check that  |local_arg| is less than
     3-2*sqrt(2) = 0.17157.. = .0xafb0ccc0 * 2^-2 */

  if ( local_arg.exp >= EXP_BIAS - 3 )
    {
      if ( (local_arg.exp > EXP_BIAS - 3) ||
	  (local_arg.sigh > (unsigned)0xafb0ccc0) )
	{
	  /* The argument is large */
	  poly_l2(&arg_pl1, result); return 0;
	}
    }

  /* Make a copy of local_arg */
  reg_move(&local_arg, &poly_arg);

  /* Get poly_arg bits aligned as required */
  shrx((unsigned *)&(poly_arg.sigl), -(poly_arg.exp - EXP_BIAS + 3));

  mul64(&significand(&poly_arg), &significand(&poly_arg), &Xsq);
  poly_div16(&Xsq);

  /* Do the basic fixed point polynomial evaluation */
  polynomial(&(accum.sigl), (unsigned *)&Xsq, lterms, HIPOWER-1);

  accum.tag = TW_Valid;	/* set the tags to Valid */
  accum.sign = SIGN_POS;	/* and make accum positive */

  /* make accum compatible and normalize */
  accum.exp = EXP_BIAS - 1;
  normalize(&accum);

  reg_u_mul(&local_arg, &accum, &accum, FULL_PRECISION);

  reg_u_add(&local_arg, &accum, result, FULL_PRECISION);

  /* Multiply the result by 2 */
  result->exp++;

  result->sign = sign;
  
  return 0;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费视频视频在线观看免费 | 一本色道久久综合亚洲aⅴ蜜桃| 国产精品热久久久久夜色精品三区| 91热门视频在线观看| 蜜桃av一区二区三区电影| 亚洲特级片在线| 国产精品私人影院| 欧美色精品天天在线观看视频| 欧美高清hd18日本| 91精品国产麻豆| 亚洲国产高清在线| 日韩精品三区四区| 国产99精品国产| 色哟哟一区二区| 久久久不卡网国产精品二区| 亚洲最新在线观看| 国产a级毛片一区| 日韩免费看网站| 午夜欧美视频在线观看| 国产精品羞羞答答xxdd | 国产欧美日韩在线视频| 亚洲国产精品久久一线不卡| 国产超碰在线一区| 久久女同互慰一区二区三区| 亚洲成av人在线观看| 91久久精品一区二区三区| 国产午夜亚洲精品不卡| 国产精品亚洲一区二区三区妖精| 日韩一区二区三区在线观看| 蜜臀a∨国产成人精品| 欧美肥妇free| 久久精品国产一区二区| 精品国精品国产| 国产黄色91视频| 一区二区三区加勒比av| 91精品欧美久久久久久动漫 | 欧美日韩一区在线观看| 全国精品久久少妇| 国产香蕉久久精品综合网| 成人国产一区二区三区精品| 欧美国产成人精品| 91欧美一区二区| 日本欧美久久久久免费播放网| 精品国产一区二区精华| 色噜噜偷拍精品综合在线| 日韩成人午夜电影| 中文字幕五月欧美| 欧美成人国产一区二区| 国产成人午夜高潮毛片| 亚洲女同ⅹxx女同tv| 欧美一级理论片| 不卡一区中文字幕| 精品亚洲国内自在自线福利| 综合亚洲深深色噜噜狠狠网站| 91精品在线一区二区| 成人黄色免费短视频| 亚洲与欧洲av电影| 欧美一区二区在线观看| 波多野结衣欧美| 日韩av午夜在线观看| 一区二区三区国产| 久久久久国产一区二区三区四区 | 亚洲高清在线精品| 亚洲欧美日韩久久| 亚洲啪啪综合av一区二区三区| 久久久久久一二三区| 欧美日韩国产美女| 欧美一区二区国产| 精品国产免费视频| 久久精品一区二区三区不卡牛牛 | 91国偷自产一区二区三区观看| 成人久久视频在线观看| 亚洲444eee在线观看| 亚洲精品你懂的| 亚洲影视在线播放| 在线视频国内一区二区| 国产精品白丝jk白祙喷水网站| 成人激情免费网站| 在线精品国精品国产尤物884a| 一本大道久久精品懂色aⅴ| 欧美在线观看一区| 国产欧美一区二区精品秋霞影院| 亚洲天天做日日做天天谢日日欢 | 天堂影院一区二区| 风间由美性色一区二区三区| 欧美在线观看视频一区二区 | 国产福利一区二区| 欧美性极品少妇| 久久美女高清视频| 亚洲综合一区二区精品导航| 亚洲午夜私人影院| 国产成人8x视频一区二区| 在线观看91视频| 国产精品久久久久久久久久久免费看| 午夜婷婷国产麻豆精品| 国产.欧美.日韩| 精品国产人成亚洲区| 日本大胆欧美人术艺术动态| 色综合婷婷久久| 成人免费在线视频| 成人丝袜视频网| 国产精品乱码一区二三区小蝌蚪| 麻豆免费精品视频| 日韩视频一区二区三区| 奇米在线7777在线精品| 欧美人xxxx| 丝袜美腿高跟呻吟高潮一区| 欧美网站一区二区| 日韩成人一级片| 26uuu亚洲综合色欧美| 国产在线精品一区二区夜色| 国产日韩欧美精品电影三级在线| 久久av资源网| 亚洲欧美电影院| 色av成人天堂桃色av| 午夜精品久久久久久久蜜桃app| 91在线视频18| 青青草视频一区| 久久九九影视网| 欧美性做爰猛烈叫床潮| 日韩精品福利网| 国产精品久久99| 2024国产精品视频| 色综合久久天天综合网| 7777精品伊人久久久大香线蕉的| 蜜桃视频免费观看一区| 久久蜜桃av一区精品变态类天堂| 国内精品久久久久影院色| 亚洲高清中文字幕| 福利一区在线观看| 色94色欧美sute亚洲线路一久| 91久久国产综合久久| 欧美一卡2卡三卡4卡5免费| 精品av综合导航| 亚洲香肠在线观看| 国产jizzjizz一区二区| 欧美三片在线视频观看| 久久综合九色综合欧美就去吻| 最好看的中文字幕久久| 精彩视频一区二区三区 | 国内精品第一页| 在线免费不卡电影| 欧美国产欧美综合| 日韩国产欧美在线播放| 99re亚洲国产精品| 久久久国际精品| 肉肉av福利一精品导航| 日本福利一区二区| 亚洲天堂成人在线观看| 成人久久视频在线观看| 国产片一区二区| 国产一区二区美女诱惑| 久久综合狠狠综合| 久久激情五月婷婷| 欧美三区免费完整视频在线观看| 亚洲美女精品一区| 欧美日韩精品电影| 精品一区二区av| 久久久久久夜精品精品免费| 国产精品1区2区| 国产精品高潮久久久久无| 成人av网站在线观看| 国产精品久久久久久久久搜平片 | 日韩精品91亚洲二区在线观看| 欧美在线观看视频一区二区| 日韩精品亚洲专区| 久久久久国产免费免费| 99re热视频精品| 丝袜诱惑制服诱惑色一区在线观看 | 欧美一卡在线观看| 国产真实精品久久二三区| 精品久久久久av影院| 99久久久久免费精品国产| 久久久久久影视| 欧美猛男男办公室激情| 蜜臀久久99精品久久久久久9 | 成人性生交大片免费| 亚洲网友自拍偷拍| 国产精品美女久久久久久| 欧美专区在线观看一区| 激情久久久久久久久久久久久久久久| 国产精品美女久久久久久久久久久 | 欧美日韩aaaaaa| 粉嫩13p一区二区三区| 日韩国产高清在线| 亚洲激情一二三区| 中文字幕日韩欧美一区二区三区| 91精品国产高清一区二区三区| 成人免费视频一区二区| 久久99国产精品免费网站| 又紧又大又爽精品一区二区| www亚洲一区| 国产视频在线观看一区二区三区| 在线不卡a资源高清| 日本精品裸体写真集在线观看| 国产1区2区3区精品美女| 国产不卡视频一区| 成人国产精品免费网站| 菠萝蜜视频在线观看一区| 国产成人啪免费观看软件|