mat3x4.rst 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. .. default-domain:: C
  2. mat3x4
  3. ======
  4. Header: cglm/mat3x4.h
  5. Table of contents (click to go):
  6. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  7. Macros:
  8. 1. GLM_MAT3X4_ZERO_INIT
  9. #. GLM_MAT3X4_ZERO
  10. Functions:
  11. 1. :c:func:`glm_mat3x4_copy`
  12. #. :c:func:`glm_mat3x4_zero`
  13. #. :c:func:`glm_mat3x4_make`
  14. #. :c:func:`glm_mat3x4_mul`
  15. #. :c:func:`glm_mat3x4_mulv`
  16. #. :c:func:`glm_mat3x4_transpose`
  17. #. :c:func:`glm_mat3x4_scale`
  18. Represented
  19. ~~~~~~~~~~~
  20. .. csv-table:: mat3x4
  21. :header: "", "column 1", "column 2", "column 3"
  22. "row 1", "m00", "m10", "m20"
  23. "row 2", "m01", "m11", "m21"
  24. "row 3", "m02", "m12", "m22"
  25. "row 4", "m03", "m13", "m23"
  26. Functions documentation
  27. ~~~~~~~~~~~~~~~~~~~~~~~
  28. .. c:function:: void glm_mat3x4_copy(mat3x4 src, mat3x4 dest)
  29. Copy mat3x4 (src) to mat3x4 (dest).
  30. Parameters:
  31. | *[in]* **src** mat3x4 (left)
  32. | *[out]* **dest** destination (result, mat3x4)
  33. .. csv-table:: mat3x4 **(src)**
  34. :header: "", "column 1", "column 2", "column 3"
  35. "row 1", "a00", "a10", "a20"
  36. "row 2", "a01", "a11", "a21"
  37. "row 3", "a02", "a12", "a22"
  38. "row 4", "a03", "a13", "a23"
  39. .. csv-table:: mat3x4 **(dest)**
  40. :header: "", "column 1", "column 2", "column 3"
  41. "row 1", "b00 = a00", "b10 = a10", "b20 = a20"
  42. "row 2", "b01 = a01", "b11 = a11", "b21 = a21"
  43. "row 3", "b02 = a02", "b12 = a12", "b22 = a22"
  44. "row 4", "b03 = a03", "b13 = a13", "b23 = a23"
  45. .. c:function:: void glm_mat3x4_zero(mat3x4 m)
  46. Zero out the mat3x4 (m).
  47. Parameters:
  48. | *[in, out]* **m** mat3x4 (src, dest)
  49. .. csv-table:: mat3x4 **(m)**
  50. :header: "", "column 1", "column 2", "column 3"
  51. "row 1", "0.00", "2.00", "78.00"
  52. "row 2", "5.00", "4.00", "12.00"
  53. "row 3", "7.00", "6.00", "32.00"
  54. "row 4", "23.00", "1.00", "9.00"
  55. .. csv-table:: mat3x4 **(m)**
  56. :header: "", "column 1", "column 2", "column 3"
  57. "row 1", "0.00", "0.00", "0.00"
  58. "row 2", "0.00", "0.00", "0.00"
  59. "row 3", "0.00", "0.00", "0.00"
  60. "row 4", "0.00", "0.00", "0.00"
  61. .. c:function:: void glm_mat3x4_make(const float * __restrict src, mat3x4 dest)
  62. Create mat3x4 (dest) from pointer (src).
  63. .. note:: **@src** must contain at least 12 elements.
  64. Parameters:
  65. | *[in]* **src** pointer to an array of floats (left)
  66. | *[out]* **dest** destination (result, mat3x4)
  67. .. csv-table:: float array (1x12) **(src)**
  68. :header: "", "column 1"
  69. "row 1", "v0"
  70. "row 2", "v1"
  71. "row 3", "v2"
  72. "row 4", "v3"
  73. "row 5", "v4"
  74. "row 6", "v5"
  75. "row 7", "v6"
  76. "row 8", "v7"
  77. "row 9", "v8"
  78. "row 10", "v9"
  79. "row 11", "v10"
  80. "row 12", "v11"
  81. .. csv-table:: mat3x4 **(dest)**
  82. :header: "", "column 1", "column 2", "column 3"
  83. "row 1", "v0", "v4", "v8"
  84. "row 2", "v1", "v5", "v9"
  85. "row 3", "v2", "v6", "v10"
  86. "row 4", "v3", "v7", "v11"
  87. .. c:function:: void glm_mat3x4_mul(mat3x4 m1, mat4x3 m2, mat4 dest)
  88. Multiply mat3x4 (m1) by mat4x3 (m2) and store in mat4 (dest).
  89. .. code-block:: c
  90. glm_mat3x4_mul(mat3x4, mat4x3, mat4);
  91. Parameters:
  92. | *[in]* **m1** mat2x4 (left)
  93. | *[in]* **m2** mat4x2 (right)
  94. | *[out]* **dest** destination (result, mat4)
  95. .. csv-table:: mat3x4 **(m1)**
  96. :header: "", "column 1", "column 2", "column 3"
  97. "row 1", "a00", "a10", "a20"
  98. "row 2", "a01", "a11", "a21"
  99. "row 3", "a02", "a12", "a22"
  100. "row 4", "a03", "a13", "a23"
  101. .. csv-table:: mat4x3 **(m2)**
  102. :header: "", "column 1", "column 2", "column 3", "column 4"
  103. "row 1", "b00", "b10", "b20", "b30"
  104. "row 2", "b01", "b11", "b21", "b31"
  105. "row 3", "b02", "b12", "b22", "b32"
  106. .. csv-table:: mat4x4 **(dest)**
  107. :header: "", "column 1", "column 2", "column 3", "column 4"
  108. "row 1", "a00 * b00 + a10 * b01 + a20 * b02", "a00 * b10 + a10 * b11 + a20 * b12", "a00 * b20 + a10 * b21 + a20 * b22", "a00 * b30 + a10 * b31 + a20 * b32"
  109. "row 2", "a01 * b00 + a11 * b01 + a21 * b02", "a01 * b10 + a11 * b11 + a21 * b12", "a01 * b20 + a11 * b21 + a21 * b22", "a01 * b30 + a11 * b31 + a21 * b32"
  110. "row 3", "a02 * b00 + a12 * b01 + a22 * b02", "a02 * b10 + a12 * b11 + a22 * b12", "a02 * b20 + a12 * b21 + a22 * b22", "a02 * b30 + a12 * b31 + a22 * b32"
  111. "row 4", "a03 * b00 + a13 * b01 + a23 * b02", "a03 * b10 + a13 * b11 + a23 * b12", "a03 * b20 + a13 * b21 + a23 * b22", "a03 * b30 + a13 * b31 + a23 * b32"
  112. .. c:function:: void glm_mat3x4_mulv(mat3x4 m, vec3 v, vec4 dest)
  113. Multiply ma3x4 (m) by vec3 (v) and store in vec4 (dest).
  114. Parameters:
  115. | *[in]* **m** mat3x4 (left)
  116. | *[in]* **v** vec3 (right, column vector)
  117. | *[out]* **dest** destination (result, column vector)
  118. .. csv-table:: mat3x4 **(m)**
  119. :header: "", "column 1", "column 2", "column 3"
  120. "row 1", "m00", "m10", "m20"
  121. "row 2", "m01", "m11", "m21"
  122. "row 3", "m02", "m12", "m22"
  123. "row 4", "m03", "m13", "m23"
  124. .. csv-table:: column vec3 (1x3) **(v)**
  125. :header: "", "column 1"
  126. "row 1", "v0"
  127. "row 2", "v1"
  128. "row 3", "v2"
  129. .. csv-table:: column vec4 (1x4) **(dest)**
  130. :header: "", "column 1"
  131. "row 1", "m00 * v0 + m10 * v1 + m20 * v2"
  132. "row 2", "m01 * v0 + m11 * v1 + m21 * v2"
  133. "row 3", "m02 * v0 + m12 * v1 + m22 * v2"
  134. "row 4", "m03 * v0 + m13 * v1 + m23 * v2"
  135. .. c:function:: void glm_mat3x4_transpose(mat3x4 src, mat4x3 dest)
  136. Transpose mat3x4 (src) and store in mat4x3 (dest).
  137. Parameters:
  138. | *[in]* **src** mat3x4 (left)
  139. | *[out]* **dest** destination (result, mat4x3)
  140. .. csv-table:: mat3x4 **(src)**
  141. :header: "", "column 1", "column 2", "column 3"
  142. "row 1", "a00", "a10", "a20"
  143. "row 2", "a01", "a11", "a21"
  144. "row 3", "a02", "a12", "a22"
  145. "row 4", "a03", "a13", "a23"
  146. .. csv-table:: mat4x3 **(dest)**
  147. :header: "", "column 1", "column 2", "column 3", "column 4"
  148. "row 1", "b00 = a00", "b10 = a01", "b20 = a02", "b30 = a03"
  149. "row 2", "b01 = a10", "b11 = a11", "b21 = a12", "b31 = a13"
  150. "row 3", "b02 = a20", "b12 = a21", "b22 = a22", "b32 = a23"
  151. .. c:function:: void glm_mat3x4_scale(mat3x4 m, float s)
  152. Multiply mat3x4 (m) by scalar constant (s).
  153. Parameters:
  154. | *[in, out]* **m** mat3x4 (src, dest)
  155. | *[in]* **s** float (scalar)
  156. .. csv-table:: mat3x4 **(m)**
  157. :header: "", "column 1", "column 2", "column 3"
  158. "row 1", "m00 = m00 * s", "m10 = m10 * s", "m20 = m20 * s"
  159. "row 2", "m01 = m01 * s", "m11 = m11 * s", "m21 = m21 * s"
  160. "row 3", "m02 = m02 * s", "m12 = m12 * s", "m22 = m22 * s"
  161. "row 4", "m03 = m03 * s", "m13 = m13 * s", "m23 = m23 * s"