Program Listing for File welford_covariance_provider.h

Return to documentation for file (include/adi_imu/welford_covariance_provider.h)

// Copyright 2025 Analog Devices, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef ADI_IMU__WELFORD_COVARIANCE_PROVIDER_H_
#define ADI_IMU__WELFORD_COVARIANCE_PROVIDER_H_

#include <cstddef>

#include "adi_imu/imu_covariance_interface.h"

namespace adi_imu
{

class WelfordCovarianceProvider : public ImuCovarianceInterface
{
public:
  //Default Welford algorithm parameters
  inline static constexpr size_t DEFAULT_CALIBRATION_SAMPLES = 1000;
  inline static constexpr double DEFAULT_MIN_VARIANCE = 1e-9;

  explicit WelfordCovarianceProvider(
    size_t calibration_samples = DEFAULT_CALIBRATION_SAMPLES,
    double min_variance = DEFAULT_MIN_VARIANCE);

  void addSample(const Vec3 & accel, const Vec3 & gyro) override;
  bool isReady() const override;
  CovarianceMatrix getAccelCovariance() const override;
  CovarianceMatrix getGyroCovariance() const override;
  void reset() override;
  double getCalibrationProgress() const override;

private:
  void updateWelford(double value, double & mean, double & M2, size_t n);
  double computeVariance(double M2, size_t n) const;

  size_t m_target_samples;
  size_t m_sample_count;
  double m_min_variance;

  // Welford state for accelerometer (mean and M2 for each axis)
  Vec3 m_accel_mean;
  Vec3 m_accel_M2;

  // Welford state for gyro
  Vec3 m_gyro_mean;
  Vec3 m_gyro_M2;

  // Frozen covariance after calibration
  CovarianceMatrix m_accel_covariance;
  CovarianceMatrix m_gyro_covariance;
  bool m_calibration_complete;
};
}  // namespace adi_imu

#endif  // ADI_IMU__WELFORD_COVARIANCE_PROVIDER_H_