tan_half_angle.h 1.1 KB

1234567891011121314151617181920212223242526272829303132333435
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2018 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. #ifndef IGL_TAN_HALF_ANGLE_H
  9. #define IGL_TAN_HALF_ANGLE_H
  10. #include "igl_inline.h"
  11. namespace igl
  12. {
  13. // TAN_HALF_ANGLE Compute the tangent of half of the angle opposite the side
  14. // with length a, in a triangle with side lengths (a,b,c).
  15. //
  16. // Inputs:
  17. // a scalar edge length of first side of triangle
  18. // b scalar edge length of second side of triangle
  19. // c scalar edge length of third side of triangle
  20. // Returns tangent of half of the angle opposite side with length a
  21. //
  22. // See also: is_intrinsic_delaunay
  23. template < typename Scalar>
  24. IGL_INLINE Scalar tan_half_angle(
  25. const Scalar & a,
  26. const Scalar & b,
  27. const Scalar & c);
  28. }
  29. #ifndef IGL_STATIC_LIBRARY
  30. # include "tan_half_angle.cpp"
  31. #endif
  32. #endif