// Copyright 2019-2021, Collabora, Ltd. // SPDX-License-Identifier: BSL-1.0 /*! * @file * @brief Interoperability helpers connecting internal math types and Eigen. * @author Ryan Pavlik * @author Nis Madsen * @ingroup aux_math */ #pragma once #ifndef __cplusplus #error "This header only usable from C++" #endif #include "math/m_api.h" #include #include namespace xrt::auxiliary::math { /*! * @brief Wrap an internal quaternion struct in an Eigen type, const overload. * * Permits zero-overhead manipulation of `const xrt_quat&` by Eigen routines as * if it were a `const Eigen::Quaternionf&`. */ static inline Eigen::Map map_quat(const struct xrt_quat &q) { return Eigen::Map{&q.x}; } /*! * @brief Wrap an internal quaternion struct in an Eigen type, non-const * overload. * * Permits zero-overhead manipulation of `xrt_quat&` by Eigen routines as if it * were a `Eigen::Quaternionf&`. */ static inline Eigen::Map map_quat(struct xrt_quat &q) { return Eigen::Map{&q.x}; } /*! * @brief Wrap an internal 3D vector struct in an Eigen type, const overload. * * Permits zero-overhead manipulation of `const xrt_vec3&` by Eigen routines as * if it were a `const Eigen::Vector3f&`. */ static inline Eigen::Map map_vec3(const struct xrt_vec3 &v) { return Eigen::Map{&v.x}; } /*! * @brief Wrap an internal 3D vector struct in an Eigen type, non-const * overload. * * Permits zero-overhead manipulation of `xrt_vec3&` by Eigen routines as * if it were a `Eigen::Vector3f&`. */ static inline Eigen::Map map_vec3(struct xrt_vec3 &v) { return Eigen::Map{&v.x}; } /*! * @brief Wrap an internal 3D vector struct in an Eigen type, non-const * overload. * * Permits zero-overhead manipulation of `xrt_vec3&` by Eigen routines as * if it were a `const Eigen::Vector3_f64&`. */ static inline Eigen::Map map_vec3_f64(const struct xrt_vec3_f64 &v) { return Eigen::Map{&v.x}; } /*! * @brief Wrap an internal 3D vector struct in an Eigen type, non-const * overload. * * Permits zero-overhead manipulation of `xrt_vec3&` by Eigen routines as * if it were a `Eigen::Vector3_f64&`. */ static inline Eigen::Map map_vec3_f64(struct xrt_vec3_f64 &v) { return Eigen::Map{&v.x}; } /*! * @brief Wrap an internal 3x3 matrix struct in an Eigen type, const overload. * * Permits zero-overhead manipulation of `xrt_matrix_3x3&` by Eigen routines as * if it were a `Eigen::Matrix3f&`. */ static inline Eigen::Map map_matrix_3x3(const struct xrt_matrix_3x3 &m) { return Eigen::Map(m.v); } /*! * @brief Wrap an internal 3x3 matrix struct in an Eigen type, non-const * overload. * * Permits zero-overhead manipulation of `xrt_matrix_3x3&` by Eigen routines as * if it were a `Eigen::Matrix3f&`. */ static inline Eigen::Map map_matrix_3x3(struct xrt_matrix_3x3 &m) { return Eigen::Map(m.v); } /*! * @brief Wrap an internal 3x3 matrix struct in an Eigen type, non-const * overload. * * Permits zero-overhead manipulation of `xrt_matrix_3x3&` by Eigen routines as * if it were a `Eigen::Matrix3_f64&`. */ static inline Eigen::Map map_matrix_3x3_f64(struct xrt_matrix_3x3_f64 &m) { return Eigen::Map(m.v); } /*! * @brief Wrap an internal 4x4 matrix struct in an Eigen type, const * overload. * * Permits zero-overhead manipulation of `xrt_matrix_4x4&` by Eigen routines as * if it were a `Eigen::Matrix4f&`. */ static inline Eigen::Map map_matrix_4x4(const struct xrt_matrix_4x4 &m) { return Eigen::Map(m.v); } /*! * @brief Wrap an internal 4x4 matrix struct in an Eigen type, non-const * overload. * * Permits zero-overhead manipulation of `xrt_matrix_4x4&` by Eigen routines as * if it were a `Eigen::Matrix4f&`. */ static inline Eigen::Map map_matrix_4x4(struct xrt_matrix_4x4 &m) { return Eigen::Map(m.v); } /*! * @brief Wrap an internal 4x4 matrix f64 struct in an Eigen type, const overload. * * Permits zero-overhead manipulation of `const xrt_matrix_4x4_f64&` by Eigen routines as if it were a * `const Eigen::Matrix4d&`. */ static inline Eigen::Map map_matrix_4x4_f64(const struct xrt_matrix_4x4_f64 &m) { return Eigen::Map(m.v); } /*! * @brief Wrap an internal 4x4 matrix struct in an Eigen type, non-const overload. * * Permits zero-overhead manipulation of `xrt_matrix_4x4_f64&` by Eigen routines as if it were a `Eigen::Matrix4d&`. */ static inline Eigen::Map map_matrix_4x4_f64(struct xrt_matrix_4x4_f64 &m) { return Eigen::Map(m.v); } /* * * Pose deconstruction helpers. * */ /*! * Return a Eigen type wrapping a pose's orientation (const). */ static inline Eigen::Map orientation(const struct xrt_pose &pose) { return map_quat(pose.orientation); } /*! * Return a Eigen type wrapping a pose's orientation. */ static inline Eigen::Map orientation(struct xrt_pose &pose) { return map_quat(pose.orientation); } /*! * Return a Eigen type wrapping a pose's position (const). */ static inline Eigen::Map position(const struct xrt_pose &pose) { return map_vec3(pose.position); } /*! * Return a Eigen type wrapping a pose's position. */ static inline Eigen::Map position(struct xrt_pose &pose) { return map_vec3(pose.position); } } // namespace xrt::auxiliary::math