mat4x3.rst 6.6 KB

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