home *** CD-ROM | disk | FTP | other *** search
/ Il CD di internet / CD.iso / SOURCE / D / LIBC / LIBC-4.6 / LIBC-4 / libc-linux / sysdeps / linux / i386 / math / log1p.c < prev    next >
Encoding:
C/C++ Source or Header  |  1993-12-09  |  1.3 KB  |  55 lines

  1. /* Copyright (C) 1993  Hongjiu Lu
  2. This file is part of the Linux C Library.
  3.  
  4. The Linux C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Library General Public License as
  6. published by the Free Software Foundation; either version 2 of the
  7. License, or (at your option) any later version.
  8.  
  9. The Linux C Library is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  12. Library General Public License for more details.  */
  13.  
  14. #include <ansidecl.h>
  15. #include <math.h>
  16. #include <errno.h>
  17.  
  18. static inline double
  19. domain ( double x)
  20. {
  21.     /* perror("log"); */
  22.     if (x < -1.0)
  23.       return __infnan( EDOM);
  24.     else /* i.e. x == -1.0 */
  25.       return __infnan(-ERANGE);
  26. }
  27.  
  28. double
  29. DEFUN(log1p, (x), double x)
  30. {
  31.   if (x <= -1.0) return domain (x);
  32.  
  33. #ifndef CYRIX_83D87
  34.   /* lousy 387 can only handle abs(x) < 1-sqrt(2)/2 in fly2xp1. */
  35.   if (fabs (x) < 0.2929)
  36.   {
  37. #endif
  38.       __asm__ __volatile__ ("fldln2\n\t"
  39.             "fxch %%st(1)\n\t"
  40.             "fyl2xp1"
  41.             :"=t" (x) : "0" (x));
  42. #ifndef CYRIX_83D87
  43.   }
  44.   else
  45.   {
  46.       x += 1.0;
  47.       __asm__ __volatile__ ("fldln2\n\t"
  48.             "fxch %%st(1)\n\t"
  49.             "fyl2x"
  50.             :"=t" (x) : "0" (x));
  51.   }
  52. #endif
  53.   return x;
  54. }
  55.