mirror of
https://github.com/adtools/clib2.git
synced 2025-12-08 14:59:05 +00:00
- Implemented lrintf(), lrint(), lroundf(), lround(), nearbyintf(),
nearbyint(), remquof(), remquo(), roundf(), round(), tgammaf(), tgamma(), truncf(), trunc(). Sort of implemented fmaf() and fma(), which really ought to be done in "SIMD" fashion. This completes the "real" floating point math library (ignoring for a moment that the floating point environment code is still not implemented). git-svn-id: file:///Users/olsen/Code/migration-svn-zu-git/logical-line-staging/clib2/trunk@15035 87f5fb63-7c3d-0410-a384-fd976d0f7a62
This commit is contained in:
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: math_lrintf.c,v 1.1 2005-05-29 11:19:01 obarthel Exp $
|
||||
* $Id: math_lrintf.c,v 1.2 2005-10-09 10:38:55 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -29,6 +29,15 @@
|
||||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*
|
||||
* PowerPC math library based in part on work by Sun Microsystems
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#ifndef _MATH_HEADERS_H
|
||||
@ -41,11 +50,60 @@
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
/* Adding a float, x, to 2^23 will cause the result to be rounded based on
|
||||
the fractional part of x, according to the implementation's current rounding
|
||||
mode. 2^23 is the smallest float that can be represented using all 23 significant
|
||||
digits. */
|
||||
static const float TWO23[2]={
|
||||
8.3886080000e+06, /* 0x4b000000 */
|
||||
-8.3886080000e+06, /* 0xcb000000 */
|
||||
};
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
long int
|
||||
lrintf(float x)
|
||||
{
|
||||
/* ZZZ unimplemented */
|
||||
return(0);
|
||||
LONG j0,sx;
|
||||
ULONG i0;
|
||||
float t;
|
||||
volatile float w;
|
||||
long int result;
|
||||
|
||||
GET_FLOAT_WORD(i0,x);
|
||||
|
||||
/* Extract sign bit. */
|
||||
sx = (i0 >> 31);
|
||||
|
||||
/* Extract exponent field. */
|
||||
j0 = ((i0 & 0x7f800000) >> 23) - 127;
|
||||
|
||||
if (j0 < (int)(sizeof (long int) * 8) - 1)
|
||||
{
|
||||
if (j0 < -1)
|
||||
return 0;
|
||||
else if (j0 >= 23)
|
||||
result = (long int) ((i0 & 0x7fffff) | 0x800000) << (j0 - 23);
|
||||
else
|
||||
{
|
||||
w = TWO23[sx] + x;
|
||||
t = w - TWO23[sx];
|
||||
GET_FLOAT_WORD (i0, t);
|
||||
/* Detect the all-zeros representation of plus and
|
||||
minus zero, which fails the calculation below. */
|
||||
if ((i0 & ~(1 << 31)) == 0)
|
||||
return 0;
|
||||
j0 = ((i0 >> 23) & 0xff) - 0x7f;
|
||||
i0 &= 0x7fffff;
|
||||
i0 |= 0x800000;
|
||||
result = i0 >> (23 - j0);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
return (long int) x;
|
||||
}
|
||||
return sx ? -result : result;
|
||||
}
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
Reference in New Issue
Block a user