quaternion: compare test results using sum-of-differences
comparison of floating point values is inexact and there isn't an easy way for providing an ULP delta via the TAP interface. morever, the general expected error is too large to reliably express in ULPs.
This commit is contained in:
parent
7b4ece207b
commit
45795a1ae0
@ -76,20 +76,23 @@ main (void)
|
|||||||
for (size_t i = 0; i < elems (ROTATIONS); ++i) {
|
for (size_t i = 0; i < elems (ROTATIONS); ++i) {
|
||||||
const auto &r = ROTATIONS[i];
|
const auto &r = ROTATIONS[i];
|
||||||
|
|
||||||
tap.expect_eq (quaternionf::rotation (r.mag, r.axis).as_matrix (),
|
auto q = quaternionf::rotation (r.mag, r.axis).as_matrix ();
|
||||||
util::matrix4f::rotation (r.mag, r.axis),
|
auto m = util::matrix4f::rotation (r.mag, r.axis);
|
||||||
"single basis rotation %zu", i);
|
auto diff = util::abs (q - m);
|
||||||
|
|
||||||
|
tap.expect_lt (util::sum (diff), 1e-6f, "single basis rotation %zu", i);
|
||||||
}
|
}
|
||||||
|
|
||||||
auto q_total = quaternionf::IDENTITY;
|
auto q = quaternionf::IDENTITY;
|
||||||
auto m_total = util::matrix4f::IDENTITY;
|
auto m = util::matrix4f::IDENTITY;
|
||||||
|
|
||||||
for (auto r: ROTATIONS) {
|
for (auto r: ROTATIONS) {
|
||||||
q_total = q_total.rotation (r.mag, r.axis) * q_total;
|
q = q.rotation (r.mag, r.axis) * q;
|
||||||
m_total = m_total.rotation (r.mag, r.axis) * m_total;
|
m = m.rotation (r.mag, r.axis) * m;
|
||||||
}
|
}
|
||||||
|
|
||||||
tap.expect_eq (q_total.as_matrix (), m_total, "chained single axis rotations");
|
auto diff = util::abs (q.as_matrix () - m);
|
||||||
|
tap.expect_lt (util::sum (diff), 1e-6f, "chained single axis rotations");
|
||||||
}
|
}
|
||||||
|
|
||||||
return tap.status ();
|
return tap.status ();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user