assign_scalar.cpp 930 B

1234567891011121314151617181920212223242526272829303132
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2015 Alec Jacobson <alecjacobson@gmail.com>
  4. //
  5. // This Source Code Form is subject to the terms of the Mozilla Public License
  6. // v. 2.0. If a copy of the MPL was not distributed with this file, You can
  7. // obtain one at http://mozilla.org/MPL/2.0/.
  8. #include "assign_scalar.h"
  9. IGL_INLINE void igl::copyleft::cgal::assign_scalar(
  10. const typename CGAL::Epeck::FT & cgal,
  11. CGAL::Epeck::FT & d)
  12. {
  13. d = cgal;
  14. }
  15. IGL_INLINE void igl::copyleft::cgal::assign_scalar(
  16. const typename CGAL::Epeck::FT & cgal,
  17. double & d)
  18. {
  19. const auto interval = CGAL::to_interval(cgal);
  20. assert(nextafter(interval.first, interval.second) == interval.second);
  21. d = (cgal-interval.first) < (interval.second-cgal)?
  22. interval.first:interval.second;
  23. }
  24. IGL_INLINE void igl::copyleft::cgal::assign_scalar(
  25. const double & c,
  26. double & d)
  27. {
  28. d = c;
  29. }