rint.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /* vi: set sw=4 ts=4: */
  2. /*
  3. * rint for uClibc
  4. *
  5. * Copyright (C) 2001 by Lineo, inc.
  6. * Written by Erik Andersen <andersen@lineo.com>, <andersee@debian.org>
  7. *
  8. * This program is free software; you can redistribute it and/or modify it
  9. * under the terms of the GNU Library General Public License as published by
  10. * the Free Software Foundation; either version 2 of the License, or (at your
  11. * option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful, but WITHOUT
  14. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  15. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
  16. * for more details.
  17. *
  18. * You should have received a copy of the GNU Library General Public License
  19. * along with this program; if not, write to the Free Software Foundation,
  20. * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  21. *
  22. */
  23. #include <math.h>
  24. /* From the Linux man page:
  25. *
  26. * NAME
  27. * rint - round to closest integer
  28. *
  29. * SYNOPSIS
  30. * #include <math.h>
  31. * double rint(double x);
  32. *
  33. * DESCRIPTION
  34. * The rint() function rounds x to an integer value according
  35. * to the prevalent rounding mode. The default rounding mode
  36. * is to round to the nearest integer.
  37. *
  38. * RETURN VALUE
  39. * The rint() function returns the integer value as a float­
  40. * ing-point number.
  41. */
  42. double rint (double x) {
  43. double low = floor(x);
  44. if (fmod(x,low) >= (double)0.5)
  45. return(ceil(x));
  46. else
  47. return(low);
  48. }