00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
#if defined(LIBM_SCCS) && !defined(lint)
00014
static char rcsid[] =
"$NetBSD: w_sqrt.c,v 1.6 1995/05/10 20:49:55 jtc Exp $";
00015
#endif
00016
00017
00018
00019
00020
00021
#include "math.h"
00022
#include "mathP.h"
00023
00024
#ifdef __STDC__
00025
double sqrt(
double x)
00026 #
else
00027 double sqrt(x)
00028 double x;
00029 #endif
00030 {
00031
#ifdef _IEEE_LIBM
00032
return __ieee754_sqrt(x);
00033
#else
00034
double z;
00035 z =
__ieee754_sqrt(x);
00036
if(
_LIB_VERSION == _IEEE_ || isnan(x))
return z;
00037
if(x<0.0) {
00038
return __kernel_standard(x,x,26);
00039 }
else
00040
return z;
00041
#endif
00042
}