⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 frexp.c

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 C
字号:
#include <u.h>#include <libc.h>/* * this is big/little endian non-portable * it gets the endian from the FPdbleword * union in u.h. */#define	MASK	0x7ffL#define	SHIFT	20#define	BIAS	1022Ldoublefrexp(double d, int *ep){	FPdbleword x;	if(d == 0) {		*ep = 0;		return 0;	}	x.x = d;	*ep = ((x.hi >> SHIFT) & MASK) - BIAS;	x.hi &= ~(MASK << SHIFT);	x.hi |= BIAS << SHIFT;	return x.x;}doubleldexp(double d, int deltae){	int e, bits;	FPdbleword x;	ulong z;	if(d == 0)		return 0;	x.x = d;	e = (x.hi >> SHIFT) & MASK;	if(deltae >= 0 || e+deltae >= 1){	/* no underflow */		e += deltae;		if(e >= MASK){		/* overflow */			if(d < 0)				return Inf(-1);			return Inf(1);		}	}else{	/* underflow gracefully */		deltae = -deltae;		/* need to shift d right deltae */		if(e > 1){		/* shift e-1 by exponent manipulation */			deltae -= e-1;			e = 1;		}		if(deltae > 0 && e==1){	/* shift 1 by switch from 1.fff to 0.1ff */			deltae--;			e = 0;			x.lo >>= 1;			x.lo |= (x.hi&1)<<31;			z = x.hi & ((1<<SHIFT)-1);			x.hi &= ~((1<<SHIFT)-1);			x.hi |= (1<<(SHIFT-1)) | (z>>1);		}		while(deltae > 0){		/* shift bits down */			bits = deltae;			if(bits > SHIFT)				bits = SHIFT;			x.lo >>= bits;			x.lo |= (x.hi&((1<<bits)-1)) << (32-bits);			z = x.hi & ((1<<SHIFT)-1);			x.hi &= ~((1<<SHIFT)-1);			x.hi |= z>>bits;			deltae -= bits;		}	}	x.hi &= ~(MASK << SHIFT);	x.hi |= (long)e << SHIFT;	return x.x;}doublemodf(double d, double *ip){	FPdbleword x;	int e;	if(d < 1) {		if(d < 0) {			x.x = modf(-d, ip);			*ip = -*ip;			return -x.x;		}		*ip = 0;		return d;	}	x.x = d;	e = ((x.hi >> SHIFT) & MASK) - BIAS;	if(e <= SHIFT+1) {		x.hi &= ~(0x1fffffL >> e);		x.lo = 0;	} else	if(e <= SHIFT+33)		x.lo &= ~(0x7fffffffL >> (e-SHIFT-2));	*ip = x.x;	return d - x.x;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -