Skip to content

Commit

Permalink
Fix Quaternion arc constructor to check dot & Add test for same vec3s
Browse files Browse the repository at this point in the history
  • Loading branch information
TokageItLab committed Jan 19, 2025
1 parent 7b1ed52 commit 2bd84a2
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 3 deletions.
10 changes: 7 additions & 3 deletions core/math/quaternion.h
Original file line number Diff line number Diff line change
Expand Up @@ -141,16 +141,20 @@ struct [[nodiscard]] Quaternion {
}

Quaternion(const Vector3 &p_v0, const Vector3 &p_v1) { // Shortest arc.
Vector3 c = p_v0.cross(p_v1);
real_t d = p_v0.normalized().dot(p_v1.normalized());
real_t n = 1.0f - (real_t)CMP_EPSILON;
if (d > n) {
return;
}

if (c.is_zero_approx()) {
if (d < -n) {
Vector3 axis = p_v0.get_any_perpendicular();
x = axis.x;
y = axis.y;
z = axis.z;
w = 0;
} else {
real_t d = p_v0.dot(p_v1);
Vector3 c = p_v0.cross(p_v1);
real_t s = Math::sqrt((1.0f + d) * 2.0f);
real_t rs = 1.0f / s;

Expand Down
3 changes: 3 additions & 0 deletions tests/core/math/test_quaternion.h
Original file line number Diff line number Diff line change
Expand Up @@ -263,6 +263,9 @@ TEST_CASE("[Quaternion] Construct Shortest Arc For 180 Degree Arc") {

// For the consistency of the rotation direction, they should be symmetrical to the plane.
CHECK(left_to_right.is_equal_approx(right_to_left.inverse()));

// If vectors are same, no rotation.
CHECK(Quaternion(diagonal_up, diagonal_up).is_equal_approx(Quaternion()));
}

TEST_CASE("[Quaternion] Get Euler Orders") {
Expand Down

0 comments on commit 2bd84a2

Please sign in to comment.