fdlibm.h

来自「This is a resource based on j2me embedde」· C头文件 代码 · 共 257 行

H
257
字号
/* * @(#)fdlibm.h	1.22 06/10/10 * * Copyright  1990-2008 Sun Microsystems, Inc. All Rights Reserved.   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER   *    * This program is free software; you can redistribute it and/or   * modify it under the terms of the GNU General Public License version   * 2 only, as published by the Free Software Foundation.    *    * This program is distributed in the hope that it will be useful, but   * WITHOUT ANY WARRANTY; without even the implied warranty of   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU   * General Public License version 2 for more details (a copy is   * included at /legal/license.txt).    *    * You should have received a copy of the GNU General Public License   * version 2 along with this work; if not, write to the Free Software   * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA   * 02110-1301 USA    *    * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa   * Clara, CA 95054 or visit www.sun.com if you need additional   * information or have any questions.  * *//* * And see what the platform endianness is */#include "javavm/include/porting/doubleword.h"#include "javavm/include/porting/endianness.h"/* * Include the mapping of names to CVM names, and the setting of the * mode to IEEE.   */#include "jfdlibm.h"typedef union {    double d;    int    i[2];} CVMdiUnion;#if (CVM_DOUBLE_ENDIANNESS == CVM_LITTLE_ENDIAN)#define __HI(x) ((CVMdiUnion*)&x)->i[1]#define __LO(x) ((CVMdiUnion*)&x)->i[0]#define __HIp(x) ((CVMdiUnion*)x)->i[1]#define __LOp(x) ((CVMdiUnion*)x)->i[0]#else#define __HI(x) ((CVMdiUnion*)&x)->i[0]#define __LO(x) ((CVMdiUnion*)&x)->i[1]#define __HIp(x) ((CVMdiUnion*)x)->i[0]#define __LOp(x) ((CVMdiUnion*)x)->i[1]#endif#undef __P#ifdef __STDC__#define	__P(p)	p#else#define	__P(p)	()#endif/* * ANSI/POSIX */extern int signgam;#define	MAXFLOAT	((float)3.40282346638528860e+38)enum CVMFdlibmVersion {CVMfdlibm_ieee = -1, CVMfdlibm_svid, CVMdlibm_xopen, CVMfdlibm_posix};/*#define _LIB_VERSION_TYPE enum CVMFdlibmVersion*//*#define _LIB_VERSION CVMfdlibmVersion*/#undef  _LIB_VERSION#define _LIB_VERSION CVMfdlibm_ieee  /* always ieee for cvm *//* if global variable _LIB_VERSION is not desirable, one may * change the following to be a constant by: *	#define _LIB_VERSION_TYPE const enum version * In that case, after one initializes the value _LIB_VERSION (see * s_lib_version.c) during compile time, it cannot be modified * in the middle of a program *//*extern  _LIB_VERSION_TYPE  _LIB_VERSION;*/#undef  _LIB_VERSION_TYPE#define _LIB_VERSION_TYPE const enum version#undef _IEEE_#undef _SVID_#undef _XOPEN_#undef _POSIX_#define _IEEE_  CVMfdlibm_ieee#define _SVID_  CVMfdlibm_svid#define _XOPEN_ CVMfdlibm_xopen#define _POSIX_ CVMfdlibm_posixstruct CVMfdlibmException {	int type;	char *name;	double arg1;	double arg2;	double retval;};#undef HUGE#define	HUGE		MAXFLOAT/* * set X_TLOSS = pi*2**52, which is possibly defined in <values.h> * (one may replace the following line by "#include <values.h>") */#define X_TLOSS		1.41484755040568800000e+16/* We need to #undef these because they conflict with math.h on win32 */#undef	DOMAIN#undef	SING#undef	OVERFLOW#undef	UNDERFLOW#undef	TLOSS#undef	PLOSS#define	DOMAIN		1#define	SING		2#define	OVERFLOW	3#define	UNDERFLOW	4#define	TLOSS		5#define	PLOSS		6/* * ANSI/POSIX */extern double acos __P((double));extern double asin __P((double));extern double atan __P((double));extern double atan2 __P((double, double));extern double cos __P((double));extern double sin __P((double));extern double tan __P((double));extern double cosh __P((double));extern double sinh __P((double));extern double tanh __P((double));extern double exp __P((double));extern double frexp __P((double, int *));extern double ldexp __P((double, int));extern double log __P((double));extern double log10 __P((double));extern double modf __P((double, double *));extern double pow __P((double, double));extern double sqrt __P((double));extern double ceil __P((double));extern double fabs __P((double));extern double floor __P((double));extern double fmod __P((double, double));extern double erf __P((double));extern double erfc __P((double));extern double gamma __P((double));extern double hypot __P((double, double));extern int isnan __P((double));extern int finite __P((double));extern double j0 __P((double));extern double j1 __P((double));extern double jn __P((int, double));extern double lgamma __P((double));extern double y0 __P((double));extern double y1 __P((double));extern double yn __P((int, double));extern double acosh __P((double));extern double asinh __P((double));extern double atanh __P((double));extern double cbrt __P((double));extern double logb __P((double));extern double nextafter __P((double, double));extern double remainder __P((double, double));#ifdef _SCALB_INTextern double scalb __P((double, int));#elseextern double scalb __P((double, double));#endifextern int matherr __P((struct CVMfdlibmException *));/* * IEEE Test Vector */extern double significand __P((double));/* * Functions callable from C, intended to support IEEE arithmetic. */extern double copysign __P((double, double));extern int ilogb __P((double));extern double rint __P((double));extern double scalbn __P((double, int));/* * BSD math library entry points */extern double expm1 __P((double));extern double log1p __P((double));/* * Reentrant version of gamma & lgamma; passes signgam back by reference * as the second argument; user must allocate space for signgam. */#ifdef _REENTRANTextern double gamma_r __P((double, int *));extern double lgamma_r __P((double, int *));#endif	/* _REENTRANT *//* ieee style elementary functions */extern double __ieee754_sqrt __P((double));extern double __ieee754_acos __P((double));extern double __ieee754_acosh __P((double));extern double __ieee754_log __P((double));extern double __ieee754_atanh __P((double));extern double __ieee754_asin __P((double));extern double __ieee754_atan2 __P((double,double));extern double __ieee754_exp __P((double));extern double __ieee754_cosh __P((double));extern double __ieee754_fmod __P((double,double));extern double __ieee754_pow __P((double,double));extern double __ieee754_lgamma_r __P((double,int *));extern double __ieee754_gamma_r __P((double,int *));extern double __ieee754_lgamma __P((double));extern double __ieee754_gamma __P((double));extern double __ieee754_log10 __P((double));extern double __ieee754_sinh __P((double));extern double __ieee754_hypot __P((double,double));extern double __ieee754_j0 __P((double));extern double __ieee754_j1 __P((double));extern double __ieee754_y0 __P((double));extern double __ieee754_y1 __P((double));extern double __ieee754_jn __P((int,double));extern double __ieee754_yn __P((int,double));extern double __ieee754_remainder __P((double,double));extern int    __ieee754_rem_pio2 __P((double,double*));#ifdef _SCALB_INTextern double __ieee754_scalb __P((double,int));#elseextern double __ieee754_scalb __P((double,double));#endif/* fdlibm kernel function */extern double __kernel_standard __P((double,double,int));extern double __kernel_sin __P((double,double,int));extern double __kernel_cos __P((double,double));extern double __kernel_tan __P((double,double,int));extern int    __kernel_rem_pio2 __P((double*,double*,int,int,int,const int*));

⌨️ 快捷键说明

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