sf_logb.c

来自「KPIT GNU Tools is a set of GNU developme」· C语言 代码 · 共 49 行

C
49
字号
/* sf_logb.c -- float version of s_logb.c. * Conversion to float by Ian Lance Taylor, Cygnus Support, ian@cygnus.com. *//* * ==================================================== * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved. * * Developed at SunPro, a Sun Microsystems, Inc. business. * Permission to use, copy, modify, and distribute this * software is freely granted, provided that this notice  * is preserved. * ==================================================== */#include "fdlibm.h"#ifdef __STDC__	float logbf(float x)#else	float logbf(x)	float x;#endif{	__int32_t ix;	GET_FLOAT_WORD(ix,x);	ix &= 0x7fffffff;			/* high |x| */	if(FLT_UWORD_IS_ZERO(ix)) return (float)-1.0/fabsf(x);	if(!FLT_UWORD_IS_FINITE(ix)) return x*x;	if((ix>>=23)==0) 			/* IEEE 754 logb */		return -126.0; 	else		return (float) (ix-127); }#ifdef _DOUBLE_IS_32BITS#ifdef __STDC__	double logb(double x)#else	double logb(x)	double x;#endif{	return (double) logbf((float) x);}#endif /* defined(_DOUBLE_IS_32BITS) */

⌨️ 快捷键说明

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