Collection of DPF-based plugins for packaging
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

62 lines
1.8KB

  1. /// @ref gtx_spline
  2. /// @file glm/gtx/spline.inl
  3. namespace glm
  4. {
  5. template<typename genType>
  6. GLM_FUNC_QUALIFIER genType catmullRom
  7. (
  8. genType const& v1,
  9. genType const& v2,
  10. genType const& v3,
  11. genType const& v4,
  12. typename genType::value_type const& s
  13. )
  14. {
  15. typename genType::value_type s2 = pow2(s);
  16. typename genType::value_type s3 = pow3(s);
  17. typename genType::value_type f1 = -s3 + typename genType::value_type(2) * s2 - s;
  18. typename genType::value_type f2 = typename genType::value_type(3) * s3 - typename genType::value_type(5) * s2 + typename genType::value_type(2);
  19. typename genType::value_type f3 = typename genType::value_type(-3) * s3 + typename genType::value_type(4) * s2 + s;
  20. typename genType::value_type f4 = s3 - s2;
  21. return (f1 * v1 + f2 * v2 + f3 * v3 + f4 * v4) / typename genType::value_type(2);
  22. }
  23. template<typename genType>
  24. GLM_FUNC_QUALIFIER genType hermite
  25. (
  26. genType const& v1,
  27. genType const& t1,
  28. genType const& v2,
  29. genType const& t2,
  30. typename genType::value_type const& s
  31. )
  32. {
  33. typename genType::value_type s2 = pow2(s);
  34. typename genType::value_type s3 = pow3(s);
  35. typename genType::value_type f1 = typename genType::value_type(2) * s3 - typename genType::value_type(3) * s2 + typename genType::value_type(1);
  36. typename genType::value_type f2 = typename genType::value_type(-2) * s3 + typename genType::value_type(3) * s2;
  37. typename genType::value_type f3 = s3 - typename genType::value_type(2) * s2 + s;
  38. typename genType::value_type f4 = s3 - s2;
  39. return f1 * v1 + f2 * v2 + f3 * t1 + f4 * t2;
  40. }
  41. template<typename genType>
  42. GLM_FUNC_QUALIFIER genType cubic
  43. (
  44. genType const& v1,
  45. genType const& v2,
  46. genType const& v3,
  47. genType const& v4,
  48. typename genType::value_type const& s
  49. )
  50. {
  51. return ((v1 * s + v2) * s + v3) * s + v4;
  52. }
  53. }//namespace glm