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 #pragma once 17*ec779b8eSAndroid Build Coastguard Worker 18*ec779b8eSAndroid Build Coastguard Worker #include <optional> 19*ec779b8eSAndroid Build Coastguard Worker 20*ec779b8eSAndroid Build Coastguard Worker #include "media/Pose.h" 21*ec779b8eSAndroid Build Coastguard Worker 22*ec779b8eSAndroid Build Coastguard Worker namespace android { 23*ec779b8eSAndroid Build Coastguard Worker namespace media { 24*ec779b8eSAndroid Build Coastguard Worker 25*ec779b8eSAndroid Build Coastguard Worker /** 26*ec779b8eSAndroid Build Coastguard Worker * Drift compensator for a stream of poses. 27*ec779b8eSAndroid Build Coastguard Worker * 28*ec779b8eSAndroid Build Coastguard Worker * This is effectively a high-pass filter for a pose stream, removing any DC-offset / bias. The 29*ec779b8eSAndroid Build Coastguard Worker * provided input stream will be "pulled" toward identity with an exponential decay filter with a 30*ec779b8eSAndroid Build Coastguard Worker * configurable time constant. Rotation and translation are handled separately. 31*ec779b8eSAndroid Build Coastguard Worker * 32*ec779b8eSAndroid Build Coastguard Worker * Typical usage: 33*ec779b8eSAndroid Build Coastguard Worker * PoseDriftCompensator comp(...); 34*ec779b8eSAndroid Build Coastguard Worker * 35*ec779b8eSAndroid Build Coastguard Worker * while (...) { 36*ec779b8eSAndroid Build Coastguard Worker * comp.setInput(...); 37*ec779b8eSAndroid Build Coastguard Worker * Pose3f output = comp.getOutput(); 38*ec779b8eSAndroid Build Coastguard Worker * } 39*ec779b8eSAndroid Build Coastguard Worker * 40*ec779b8eSAndroid Build Coastguard Worker * There doesn't need to be a 1:1 correspondence between setInput() and getOutput() calls. The 41*ec779b8eSAndroid Build Coastguard Worker * output timestamp is always that of the last setInput() call. Calling recenter() will reset the 42*ec779b8eSAndroid Build Coastguard Worker * bias to the current output, causing the output to be identity. 43*ec779b8eSAndroid Build Coastguard Worker * 44*ec779b8eSAndroid Build Coastguard Worker * The initial bias point is identity. 45*ec779b8eSAndroid Build Coastguard Worker * 46*ec779b8eSAndroid Build Coastguard Worker * This implementation is thread-compatible, but not thread-safe. 47*ec779b8eSAndroid Build Coastguard Worker */ 48*ec779b8eSAndroid Build Coastguard Worker class PoseDriftCompensator { 49*ec779b8eSAndroid Build Coastguard Worker public: 50*ec779b8eSAndroid Build Coastguard Worker struct Options { 51*ec779b8eSAndroid Build Coastguard Worker float translationalDriftTimeConstant = std::numeric_limits<float>::infinity(); 52*ec779b8eSAndroid Build Coastguard Worker float rotationalDriftTimeConstant = std::numeric_limits<float>::infinity(); 53*ec779b8eSAndroid Build Coastguard Worker }; 54*ec779b8eSAndroid Build Coastguard Worker 55*ec779b8eSAndroid Build Coastguard Worker explicit PoseDriftCompensator(const Options& options); 56*ec779b8eSAndroid Build Coastguard Worker 57*ec779b8eSAndroid Build Coastguard Worker void setInput(int64_t timestamp, const Pose3f& input); 58*ec779b8eSAndroid Build Coastguard Worker 59*ec779b8eSAndroid Build Coastguard Worker void recenter(); 60*ec779b8eSAndroid Build Coastguard Worker 61*ec779b8eSAndroid Build Coastguard Worker Pose3f getOutput() const; 62*ec779b8eSAndroid Build Coastguard Worker 63*ec779b8eSAndroid Build Coastguard Worker private: 64*ec779b8eSAndroid Build Coastguard Worker const Options mOptions; 65*ec779b8eSAndroid Build Coastguard Worker 66*ec779b8eSAndroid Build Coastguard Worker Pose3f mPrevInput; 67*ec779b8eSAndroid Build Coastguard Worker Pose3f mOutput; 68*ec779b8eSAndroid Build Coastguard Worker std::optional<int64_t> mTimestamp; 69*ec779b8eSAndroid Build Coastguard Worker 70*ec779b8eSAndroid Build Coastguard Worker Pose3f scale(const Pose3f& pose, int64_t dt); 71*ec779b8eSAndroid Build Coastguard Worker }; 72*ec779b8eSAndroid Build Coastguard Worker 73*ec779b8eSAndroid Build Coastguard Worker } // namespace media 74*ec779b8eSAndroid Build Coastguard Worker } // namespace android 75