math.c 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. * This file is part of FFmpeg.
  3. *
  4. * FFmpeg is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2.1 of the License, or (at your option) any later version.
  8. *
  9. * FFmpeg 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. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with FFmpeg; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. #include <math.h>
  19. #define FUN(name, type, op) \
  20. type name(type x, type y) \
  21. { \
  22. if (fpclassify(x) == FP_NAN) return y; \
  23. if (fpclassify(y) == FP_NAN) return x; \
  24. return x op y ? x : y; \
  25. }
  26. FUN(fmin, double, <)
  27. FUN(fmax, double, >)
  28. FUN(fminf, float, <)
  29. FUN(fmaxf, float, >)
  30. long double fmodl(long double x, long double y)
  31. {
  32. return fmod(x, y);
  33. }
  34. long double scalbnl(long double x, int exp)
  35. {
  36. return scalbn(x, exp);
  37. }
  38. long double copysignl(long double x, long double y)
  39. {
  40. return copysign(x, y);
  41. }