aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorshashank <shashank.shashank.c@gmail.com>2024-05-27 23:38:50 +0530
committershashank <shashank.shashank.c@gmail.com>2024-05-27 23:38:50 +0530
commitfb6248925ae17ebc6abb3d4a735aa395dcbf831f (patch)
treed5ccbda59df75c21c2f55ac09151b84707882464
parent75f1215ed283e29dda4b8c84ac8929d7d54189e5 (diff)
fix pitch_from_quaternion
-rw-r--r--core/math/linalg/specific_euler_angles_f16.odin2
-rw-r--r--core/math/linalg/specific_euler_angles_f32.odin2
-rw-r--r--core/math/linalg/specific_euler_angles_f64.odin2
3 files changed, 3 insertions, 3 deletions
diff --git a/core/math/linalg/specific_euler_angles_f16.odin b/core/math/linalg/specific_euler_angles_f16.odin
index bacda163e..1e9ded9ab 100644
--- a/core/math/linalg/specific_euler_angles_f16.odin
+++ b/core/math/linalg/specific_euler_angles_f16.odin
@@ -159,7 +159,7 @@ roll_from_quaternion_f16 :: proc "contextless" (q: Quaternionf16) -> f16 {
@(require_results)
pitch_from_quaternion_f16 :: proc "contextless" (q: Quaternionf16) -> f16 {
- y := 2 * (q.y*q.z + q.w*q.w)
+ y := 2 * (q.y*q.z + q.w*q.x)
x := q.w*q.w - q.x*q.x - q.y*q.y + q.z*q.z
if abs(x) <= F16_EPSILON && abs(y) <= F16_EPSILON {
diff --git a/core/math/linalg/specific_euler_angles_f32.odin b/core/math/linalg/specific_euler_angles_f32.odin
index b9957034f..e33b1f095 100644
--- a/core/math/linalg/specific_euler_angles_f32.odin
+++ b/core/math/linalg/specific_euler_angles_f32.odin
@@ -159,7 +159,7 @@ roll_from_quaternion_f32 :: proc "contextless" (q: Quaternionf32) -> f32 {
@(require_results)
pitch_from_quaternion_f32 :: proc "contextless" (q: Quaternionf32) -> f32 {
- y := 2 * (q.y*q.z + q.w*q.w)
+ y := 2 * (q.y*q.z + q.w*q.x)
x := q.w*q.w - q.x*q.x - q.y*q.y + q.z*q.z
if abs(x) <= F32_EPSILON && abs(y) <= F32_EPSILON {
diff --git a/core/math/linalg/specific_euler_angles_f64.odin b/core/math/linalg/specific_euler_angles_f64.odin
index 8001d080a..9b5cf4b56 100644
--- a/core/math/linalg/specific_euler_angles_f64.odin
+++ b/core/math/linalg/specific_euler_angles_f64.odin
@@ -159,7 +159,7 @@ roll_from_quaternion_f64 :: proc "contextless" (q: Quaternionf64) -> f64 {
@(require_results)
pitch_from_quaternion_f64 :: proc "contextless" (q: Quaternionf64) -> f64 {
- y := 2 * (q.y*q.z + q.w*q.w)
+ y := 2 * (q.y*q.z + q.w*q.x)
x := q.w*q.w - q.x*q.x - q.y*q.y + q.z*q.z
if abs(x) <= F64_EPSILON && abs(y) <= F64_EPSILON {