2023-06-14 16:52:36 +10:00
|
|
|
/* SPDX-FileCopyrightText: 2011-2022 Blender Foundation
|
|
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: Apache-2.0 */
|
2020-08-03 11:04:51 +02:00
|
|
|
|
|
|
|
|
#include "testing/testing.h"
|
|
|
|
|
|
2021-10-24 14:19:19 +02:00
|
|
|
#include "util/transform.h"
|
|
|
|
|
#include "util/vector.h"
|
2020-08-03 11:04:51 +02:00
|
|
|
|
|
|
|
|
CCL_NAMESPACE_BEGIN
|
|
|
|
|
|
|
|
|
|
TEST(transform_motion_decompose, Degenerated)
|
|
|
|
|
{
|
|
|
|
|
// Simple case: single degenerated matrix.
|
|
|
|
|
{
|
|
|
|
|
vector<Transform> motion = {transform_scale(0.0f, 0.0f, 0.0f)};
|
|
|
|
|
vector<DecomposedTransform> decomp(motion.size());
|
|
|
|
|
transform_motion_decompose(decomp.data(), motion.data(), motion.size());
|
2024-12-26 17:53:59 +01:00
|
|
|
EXPECT_TRUE(transform_decomposed_isfinite_safe(decomp.data()));
|
2020-08-03 11:04:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy from previous to current.
|
|
|
|
|
{
|
2021-02-17 01:47:18 +01:00
|
|
|
vector<Transform> motion = {transform_rotate(M_PI_4_F, one_float3()),
|
2020-08-03 11:04:51 +02:00
|
|
|
transform_scale(0.0f, 0.0f, 0.0f)};
|
|
|
|
|
vector<DecomposedTransform> decomp(motion.size());
|
|
|
|
|
transform_motion_decompose(decomp.data(), motion.data(), motion.size());
|
|
|
|
|
EXPECT_NEAR(len(decomp[1].x - decomp[0].x), 0.0f, 1e-6f);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Copy from next to current.
|
|
|
|
|
{
|
|
|
|
|
vector<Transform> motion = {transform_scale(0.0f, 0.0f, 0.0f),
|
2021-02-17 01:47:18 +01:00
|
|
|
transform_rotate(M_PI_4_F, one_float3())};
|
2020-08-03 11:04:51 +02:00
|
|
|
vector<DecomposedTransform> decomp(motion.size());
|
|
|
|
|
transform_motion_decompose(decomp.data(), motion.data(), motion.size());
|
|
|
|
|
EXPECT_NEAR(len(decomp[0].x - decomp[1].x), 0.0f, 1e-6f);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
CCL_NAMESPACE_END
|