/glm/gtx/color_space_YCoCg.inl

https://bitbucket.org/ggerganov/test_opengl · C++ Header · 64 lines · 52 code · 4 blank · 8 comment · 0 complexity · 1be386bf7fdbe9c4cbdb49d243de51b9 MD5 · raw file

  1. ///////////////////////////////////////////////////////////////////////////////////////////////////
  2. // OpenGL Mathematics Copyright (c) 2005 - 2012 G-Truc Creation (www.g-truc.net)
  3. ///////////////////////////////////////////////////////////////////////////////////////////////////
  4. // Created : 2008-10-28
  5. // Updated : 2008-10-28
  6. // Licence : This source is under MIT License
  7. // File : glm/gtx/color_space_YCoCg.inl
  8. ///////////////////////////////////////////////////////////////////////////////////////////////////
  9. namespace glm
  10. {
  11. template <typename valType>
  12. GLM_FUNC_QUALIFIER detail::tvec3<valType> rgb2YCoCg
  13. (
  14. detail::tvec3<valType> const & rgbColor
  15. )
  16. {
  17. detail::tvec3<valType> result;
  18. result.x/*Y */ = rgbColor.r / valType(4) + rgbColor.g / valType(2) + rgbColor.b / valType(4);
  19. result.y/*Co*/ = rgbColor.r / valType(2) + rgbColor.g * valType(0) - rgbColor.b / valType(2);
  20. result.z/*Cg*/ = - rgbColor.r / valType(4) + rgbColor.g / valType(2) - rgbColor.b / valType(4);
  21. return result;
  22. }
  23. template <typename valType>
  24. GLM_FUNC_QUALIFIER detail::tvec3<valType> rgb2YCoCgR
  25. (
  26. detail::tvec3<valType> const & rgbColor
  27. )
  28. {
  29. detail::tvec3<valType> result;
  30. result.x/*Y */ = rgbColor.g / valType(2) + (rgbColor.r + rgbColor.b) / valType(4);
  31. result.y/*Co*/ = rgbColor.r - rgbColor.b;
  32. result.z/*Cg*/ = rgbColor.g - (rgbColor.r + rgbColor.b) / valType(2);
  33. return result;
  34. }
  35. template <typename valType>
  36. GLM_FUNC_QUALIFIER detail::tvec3<valType> YCoCg2rgb
  37. (
  38. detail::tvec3<valType> const & YCoCgColor
  39. )
  40. {
  41. detail::tvec3<valType> result;
  42. result.r = YCoCgColor.x + YCoCgColor.y - YCoCgColor.z;
  43. result.g = YCoCgColor.x + YCoCgColor.z;
  44. result.b = YCoCgColor.x - YCoCgColor.y - YCoCgColor.z;
  45. return result;
  46. }
  47. template <typename valType>
  48. GLM_FUNC_QUALIFIER detail::tvec3<valType> YCoCgR2rgb
  49. (
  50. detail::tvec3<valType> const & YCoCgRColor
  51. )
  52. {
  53. detail::tvec3<valType> result;
  54. valType tmp = YCoCgRColor.x - (YCoCgRColor.z / valType(2));
  55. result.g = YCoCgRColor.z + tmp;
  56. result.b = tmp - (YCoCgRColor.y / valType(2));
  57. result.r = result.b + YCoCgRColor.y;
  58. return result;
  59. }
  60. }//namespace glm