xref: /aosp_15_r20/frameworks/av/media/libheadtracking/StillnessDetector-test.cpp (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1*ec779b8eSAndroid Build Coastguard Worker /*
2*ec779b8eSAndroid Build Coastguard Worker  * Copyright (C) 2021 The Android Open Source Project
3*ec779b8eSAndroid Build Coastguard Worker  *
4*ec779b8eSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*ec779b8eSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*ec779b8eSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*ec779b8eSAndroid Build Coastguard Worker  *
8*ec779b8eSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*ec779b8eSAndroid Build Coastguard Worker  *
10*ec779b8eSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*ec779b8eSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*ec779b8eSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*ec779b8eSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*ec779b8eSAndroid Build Coastguard Worker  * limitations under the License.
15*ec779b8eSAndroid Build Coastguard Worker  */
16*ec779b8eSAndroid Build Coastguard Worker 
17*ec779b8eSAndroid Build Coastguard Worker #include <gtest/gtest.h>
18*ec779b8eSAndroid Build Coastguard Worker 
19*ec779b8eSAndroid Build Coastguard Worker #include "StillnessDetector.h"
20*ec779b8eSAndroid Build Coastguard Worker 
21*ec779b8eSAndroid Build Coastguard Worker #include "media/QuaternionUtil.h"
22*ec779b8eSAndroid Build Coastguard Worker #include "TestUtil.h"
23*ec779b8eSAndroid Build Coastguard Worker 
24*ec779b8eSAndroid Build Coastguard Worker namespace android {
25*ec779b8eSAndroid Build Coastguard Worker namespace media {
26*ec779b8eSAndroid Build Coastguard Worker namespace {
27*ec779b8eSAndroid Build Coastguard Worker 
28*ec779b8eSAndroid Build Coastguard Worker using Eigen::Quaternionf;
29*ec779b8eSAndroid Build Coastguard Worker using Eigen::Vector3f;
30*ec779b8eSAndroid Build Coastguard Worker using Options = StillnessDetector::Options;
31*ec779b8eSAndroid Build Coastguard Worker 
32*ec779b8eSAndroid Build Coastguard Worker class StillnessDetectorTest : public testing::TestWithParam<bool> {
33*ec779b8eSAndroid Build Coastguard Worker   public:
SetUp()34*ec779b8eSAndroid Build Coastguard Worker     void SetUp() override { mDefaultValue = GetParam(); }
35*ec779b8eSAndroid Build Coastguard Worker 
36*ec779b8eSAndroid Build Coastguard Worker   protected:
37*ec779b8eSAndroid Build Coastguard Worker     bool mDefaultValue;
38*ec779b8eSAndroid Build Coastguard Worker };
39*ec779b8eSAndroid Build Coastguard Worker 
TEST_P(StillnessDetectorTest,Still)40*ec779b8eSAndroid Build Coastguard Worker TEST_P(StillnessDetectorTest, Still) {
41*ec779b8eSAndroid Build Coastguard Worker     StillnessDetector detector(Options{.defaultValue = mDefaultValue,
42*ec779b8eSAndroid Build Coastguard Worker                                        .windowDuration = 1000,
43*ec779b8eSAndroid Build Coastguard Worker                                        .translationalThreshold = 1,
44*ec779b8eSAndroid Build Coastguard Worker                                        .rotationalThreshold = 0.05});
45*ec779b8eSAndroid Build Coastguard Worker 
46*ec779b8eSAndroid Build Coastguard Worker     const Pose3f baseline(Vector3f{1, 2, 3}, Quaternionf::UnitRandom());
47*ec779b8eSAndroid Build Coastguard Worker     const Pose3f withinThreshold =
48*ec779b8eSAndroid Build Coastguard Worker             baseline * Pose3f(Vector3f(0.3, -0.3, 0), rotateX(0.01) * rotateY(-0.01));
49*ec779b8eSAndroid Build Coastguard Worker 
50*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(0));
51*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(0, baseline);
52*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(0));
53*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(300, withinThreshold);
54*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(300));
55*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(600, baseline);
56*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(600));
57*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(999, withinThreshold);
58*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(999));
59*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1000, baseline);
60*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(1000));
61*ec779b8eSAndroid Build Coastguard Worker }
62*ec779b8eSAndroid Build Coastguard Worker 
TEST_P(StillnessDetectorTest,ZeroDuration)63*ec779b8eSAndroid Build Coastguard Worker TEST_P(StillnessDetectorTest, ZeroDuration) {
64*ec779b8eSAndroid Build Coastguard Worker     StillnessDetector detector(Options{.defaultValue = mDefaultValue, .windowDuration = 0});
65*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(0));
66*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(1000));
67*ec779b8eSAndroid Build Coastguard Worker }
68*ec779b8eSAndroid Build Coastguard Worker 
TEST_P(StillnessDetectorTest,NotStillTranslation)69*ec779b8eSAndroid Build Coastguard Worker TEST_P(StillnessDetectorTest, NotStillTranslation) {
70*ec779b8eSAndroid Build Coastguard Worker     StillnessDetector detector(Options{.defaultValue = mDefaultValue,
71*ec779b8eSAndroid Build Coastguard Worker                                        .windowDuration = 1000,
72*ec779b8eSAndroid Build Coastguard Worker                                        .translationalThreshold = 1,
73*ec779b8eSAndroid Build Coastguard Worker                                        .rotationalThreshold = 0.05});
74*ec779b8eSAndroid Build Coastguard Worker 
75*ec779b8eSAndroid Build Coastguard Worker     const Pose3f baseline(Vector3f{1, 2, 3}, Quaternionf::UnitRandom());
76*ec779b8eSAndroid Build Coastguard Worker     const Pose3f withinThreshold =
77*ec779b8eSAndroid Build Coastguard Worker             baseline * Pose3f(Vector3f(0.3, -0.3, 0), rotateX(0.01) * rotateY(-0.01));
78*ec779b8eSAndroid Build Coastguard Worker     const Pose3f outsideThreshold = baseline * Pose3f(Vector3f(1, 1, 0));
79*ec779b8eSAndroid Build Coastguard Worker 
80*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(0));
81*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(0, baseline);
82*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(0));
83*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(300, outsideThreshold);
84*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(300));
85*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(600, baseline);
86*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(600));
87*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1299, withinThreshold);
88*ec779b8eSAndroid Build Coastguard Worker     EXPECT_FALSE(detector.calculate(1299));
89*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1300, baseline);
90*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(1300));
91*ec779b8eSAndroid Build Coastguard Worker }
92*ec779b8eSAndroid Build Coastguard Worker 
TEST_P(StillnessDetectorTest,NotStillRotation)93*ec779b8eSAndroid Build Coastguard Worker TEST_P(StillnessDetectorTest, NotStillRotation) {
94*ec779b8eSAndroid Build Coastguard Worker     StillnessDetector detector(Options{.defaultValue = mDefaultValue,
95*ec779b8eSAndroid Build Coastguard Worker                                        .windowDuration = 1000,
96*ec779b8eSAndroid Build Coastguard Worker                                        .translationalThreshold = 1,
97*ec779b8eSAndroid Build Coastguard Worker                                        .rotationalThreshold = 0.05});
98*ec779b8eSAndroid Build Coastguard Worker 
99*ec779b8eSAndroid Build Coastguard Worker     const Pose3f baseline(Vector3f{1, 2, 3}, Quaternionf::UnitRandom());
100*ec779b8eSAndroid Build Coastguard Worker     const Pose3f withinThreshold =
101*ec779b8eSAndroid Build Coastguard Worker             baseline * Pose3f(Vector3f(0.3, -0.3, 0), rotateX(0.03) * rotateY(-0.03));
102*ec779b8eSAndroid Build Coastguard Worker     const Pose3f outsideThreshold = baseline * Pose3f(rotateZ(0.06));
103*ec779b8eSAndroid Build Coastguard Worker 
104*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(0));
105*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(0, baseline);
106*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(0));
107*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(300, outsideThreshold);
108*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(300));
109*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(600, baseline);
110*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(600));
111*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1299, withinThreshold);
112*ec779b8eSAndroid Build Coastguard Worker     EXPECT_FALSE(detector.calculate(1299));
113*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1300, baseline);
114*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(1300));
115*ec779b8eSAndroid Build Coastguard Worker }
116*ec779b8eSAndroid Build Coastguard Worker 
TEST_P(StillnessDetectorTest,Suppression)117*ec779b8eSAndroid Build Coastguard Worker TEST_P(StillnessDetectorTest, Suppression) {
118*ec779b8eSAndroid Build Coastguard Worker     StillnessDetector detector(Options{.defaultValue = mDefaultValue,
119*ec779b8eSAndroid Build Coastguard Worker                                        .windowDuration = 1000,
120*ec779b8eSAndroid Build Coastguard Worker                                        .translationalThreshold = 1,
121*ec779b8eSAndroid Build Coastguard Worker                                        .rotationalThreshold = 0.05});
122*ec779b8eSAndroid Build Coastguard Worker 
123*ec779b8eSAndroid Build Coastguard Worker     const Pose3f baseline(Vector3f{1, 2, 3}, Quaternionf::UnitRandom());
124*ec779b8eSAndroid Build Coastguard Worker     const Pose3f outsideThreshold = baseline * Pose3f(Vector3f(1.1, 0, 0));
125*ec779b8eSAndroid Build Coastguard Worker     const Pose3f middlePoint = baseline * Pose3f(Vector3f(0.55, 0, 0));
126*ec779b8eSAndroid Build Coastguard Worker 
127*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(0, baseline);
128*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1000, baseline);
129*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(1000));
130*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1100, outsideThreshold);
131*ec779b8eSAndroid Build Coastguard Worker     EXPECT_FALSE(detector.calculate(1100));
132*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1500, middlePoint);
133*ec779b8eSAndroid Build Coastguard Worker     EXPECT_FALSE(detector.calculate(1500));
134*ec779b8eSAndroid Build Coastguard Worker     EXPECT_FALSE(detector.calculate(1999));
135*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(2000));
136*ec779b8eSAndroid Build Coastguard Worker }
137*ec779b8eSAndroid Build Coastguard Worker 
TEST_P(StillnessDetectorTest,Reset)138*ec779b8eSAndroid Build Coastguard Worker TEST_P(StillnessDetectorTest, Reset) {
139*ec779b8eSAndroid Build Coastguard Worker     StillnessDetector detector(Options{.defaultValue = mDefaultValue,
140*ec779b8eSAndroid Build Coastguard Worker                                        .windowDuration = 1000,
141*ec779b8eSAndroid Build Coastguard Worker                                        .translationalThreshold = 1,
142*ec779b8eSAndroid Build Coastguard Worker                                        .rotationalThreshold = 0.05});
143*ec779b8eSAndroid Build Coastguard Worker 
144*ec779b8eSAndroid Build Coastguard Worker     const Pose3f baseline(Vector3f{1, 2, 3}, Quaternionf::UnitRandom());
145*ec779b8eSAndroid Build Coastguard Worker     const Pose3f withinThreshold =
146*ec779b8eSAndroid Build Coastguard Worker             baseline * Pose3f(Vector3f(0.3, -0.3, 0), rotateX(0.01) * rotateY(-0.01));
147*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(0));
148*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(300, baseline);
149*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(300));
150*ec779b8eSAndroid Build Coastguard Worker     detector.reset();
151*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(600, baseline);
152*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(600));
153*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(900, withinThreshold);
154*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(900));
155*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1200, baseline);
156*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(1200));
157*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1599, withinThreshold);
158*ec779b8eSAndroid Build Coastguard Worker     EXPECT_EQ(mDefaultValue, detector.calculate(1599));
159*ec779b8eSAndroid Build Coastguard Worker     detector.setInput(1600, baseline);
160*ec779b8eSAndroid Build Coastguard Worker     EXPECT_TRUE(detector.calculate(1600));
161*ec779b8eSAndroid Build Coastguard Worker }
162*ec779b8eSAndroid Build Coastguard Worker 
163*ec779b8eSAndroid Build Coastguard Worker INSTANTIATE_TEST_SUITE_P(StillnessDetectorTestParametrized, StillnessDetectorTest,
164*ec779b8eSAndroid Build Coastguard Worker                          testing::Values(false, true));
165*ec779b8eSAndroid Build Coastguard Worker 
166*ec779b8eSAndroid Build Coastguard Worker }  // namespace
167*ec779b8eSAndroid Build Coastguard Worker }  // namespace media
168*ec779b8eSAndroid Build Coastguard Worker }  // namespace android
169