-
Notifications
You must be signed in to change notification settings - Fork 60
/
Copy pathe_sqrtf.cpp
42 lines (38 loc) · 1.06 KB
/
e_sqrtf.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/* See the import.pl script for potential modifications */
/* e_sqrtf.c -- Simple version of e_sqrt.c.
* Conversion to Simple by Ian Lance Taylor, Cygnus Support, [email protected].
*/
/*
* ====================================================
* 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.
* ====================================================
*/
#if defined(LIBM_SCCS) && !defined(lint)
static char rcsid[] = "$NetBSD: e_sqrtf.c,v 1.4f 1995/05/10 20:46:19 jtc Exp $";
#endif
#include "SMath.h"
#include "math_private.h"
namespace streflop_libm {
#ifdef __STDC__
Simple __ieee754_sqrtf(Simple x)
#else
Simple __ieee754_sqrtf(x)
Simple x;
#endif
{
float y = x;
// Approximation
uint32_t* i = (uint32_t*)&x;
*i = (*i >> 1) + (127 << 22);
// Newton-Raphson
x = (x + y/x) / 2;
x = (x + y/x) / 2;
x = (x + y/x) / 2;
return x;
}
}