polar_coordinates.inl 734 B

123456789101112131415161718192021222324252627282930313233343536
  1. /// @ref gtx_polar_coordinates
  2. namespace glm
  3. {
  4. template<typename T, qualifier Q>
  5. GLM_FUNC_QUALIFIER vec<3, T, Q> polar
  6. (
  7. vec<3, T, Q> const& euclidean
  8. )
  9. {
  10. T const Length(length(euclidean));
  11. vec<3, T, Q> const tmp(euclidean / Length);
  12. T const xz_dist(sqrt(tmp.x * tmp.x + tmp.z * tmp.z));
  13. return vec<3, T, Q>(
  14. asin(tmp.y), // latitude
  15. atan(tmp.x, tmp.z), // longitude
  16. xz_dist); // xz distance
  17. }
  18. template<typename T, qualifier Q>
  19. GLM_FUNC_QUALIFIER vec<3, T, Q> euclidean
  20. (
  21. vec<2, T, Q> const& polar
  22. )
  23. {
  24. T const latitude(polar.x);
  25. T const longitude(polar.y);
  26. return vec<3, T, Q>(
  27. cos(latitude) * sin(longitude),
  28. sin(latitude),
  29. cos(latitude) * cos(longitude));
  30. }
  31. }//namespace glm