exp.c 912 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /*
  2. exp returns the exponential function of its
  3. floating-point argument.
  4. The coefficients are #1069 from Hart and Cheney. (22.35D)
  5. */
  6. #include <u.h>
  7. #include <libc.h>
  8. #define p0 .2080384346694663001443843411e7
  9. #define p1 .3028697169744036299076048876e5
  10. #define p2 .6061485330061080841615584556e2
  11. #define q0 .6002720360238832528230907598e7
  12. #define q1 .3277251518082914423057964422e6
  13. #define q2 .1749287689093076403844945335e4
  14. #define log2e 1.4426950408889634073599247
  15. #define sqrt2 1.4142135623730950488016887
  16. #define maxf 10000
  17. double
  18. exp(double arg)
  19. {
  20. double fract, temp1, temp2, xsq;
  21. int ent;
  22. if(arg == 0)
  23. return 1;
  24. if(arg < -maxf)
  25. return 0;
  26. if(arg > maxf)
  27. return Inf(1);
  28. arg *= log2e;
  29. ent = floor(arg);
  30. fract = (arg-ent) - 0.5;
  31. xsq = fract*fract;
  32. temp1 = ((p2*xsq+p1)*xsq+p0)*fract;
  33. temp2 = ((xsq+q2)*xsq+q1)*xsq + q0;
  34. return ldexp(sqrt2*(temp2+temp1)/(temp2-temp1), ent);
  35. }