monado/src/xrt/auxiliary/math/m_eigen_interop.hpp
Mateo de Mayo 05b8e320a5 a/math: Add multiple isometry-related matrix functions
An isometry is a rigid body transform. In this context I'm using the term to
refer to 4x4 homogeneous matrices in SE(3). I.e., matrices comprised of a
3x3 rotation, a 3x1 translation, and a [0,0,0,1] last row.
This matrix represent both rigid body transforms.
2022-05-26 18:35:39 +00:00

232 lines
5.7 KiB
C++

// Copyright 2019-2021, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
/*!
* @file
* @brief Interoperability helpers connecting internal math types and Eigen.
* @author Ryan Pavlik <ryan.pavlik@collabora.com>
* @author Nis Madsen <nima_zero_one@protonmail.com>
* @ingroup aux_math
*/
#pragma once
#ifndef __cplusplus
#error "This header only usable from C++"
#endif
#include "math/m_api.h"
#include <Eigen/Core>
#include <Eigen/Geometry>
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<const Eigen::Quaternionf>
map_quat(const struct xrt_quat &q)
{
return Eigen::Map<const Eigen::Quaternionf>{&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<Eigen::Quaternionf>
map_quat(struct xrt_quat &q)
{
return Eigen::Map<Eigen::Quaternionf>{&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<const Eigen::Vector3f>
map_vec3(const struct xrt_vec3 &v)
{
return Eigen::Map<const Eigen::Vector3f>{&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<Eigen::Vector3f>
map_vec3(struct xrt_vec3 &v)
{
return Eigen::Map<Eigen::Vector3f>{&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<const Eigen::Vector3d>
map_vec3_f64(const struct xrt_vec3_f64 &v)
{
return Eigen::Map<const Eigen::Vector3d>{&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<Eigen::Vector3d>
map_vec3_f64(struct xrt_vec3_f64 &v)
{
return Eigen::Map<Eigen::Vector3d>{&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<const Eigen::Matrix3f>
map_matrix_3x3(const struct xrt_matrix_3x3 &m)
{
return Eigen::Map<const Eigen::Matrix3f>(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<Eigen::Matrix3f>
map_matrix_3x3(struct xrt_matrix_3x3 &m)
{
return Eigen::Map<Eigen::Matrix3f>(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<Eigen::Matrix3d>
map_matrix_3x3_f64(struct xrt_matrix_3x3_f64 &m)
{
return Eigen::Map<Eigen::Matrix3d>(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<const Eigen::Matrix4f>
map_matrix_4x4(const struct xrt_matrix_4x4 &m)
{
return Eigen::Map<const Eigen::Matrix4f>(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<Eigen::Matrix4f>
map_matrix_4x4(struct xrt_matrix_4x4 &m)
{
return Eigen::Map<Eigen::Matrix4f>(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<const Eigen::Matrix4d>
map_matrix_4x4_f64(const struct xrt_matrix_4x4_f64 &m)
{
return Eigen::Map<const Eigen::Matrix4d>(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<Eigen::Matrix4d>
map_matrix_4x4_f64(struct xrt_matrix_4x4_f64 &m)
{
return Eigen::Map<Eigen::Matrix4d>(m.v);
}
/*
*
* Pose deconstruction helpers.
*
*/
/*!
* Return a Eigen type wrapping a pose's orientation (const).
*/
static inline Eigen::Map<const Eigen::Quaternionf>
orientation(const struct xrt_pose &pose)
{
return map_quat(pose.orientation);
}
/*!
* Return a Eigen type wrapping a pose's orientation.
*/
static inline Eigen::Map<Eigen::Quaternionf>
orientation(struct xrt_pose &pose)
{
return map_quat(pose.orientation);
}
/*!
* Return a Eigen type wrapping a pose's position (const).
*/
static inline Eigen::Map<const Eigen::Vector3f>
position(const struct xrt_pose &pose)
{
return map_vec3(pose.position);
}
/*!
* Return a Eigen type wrapping a pose's position.
*/
static inline Eigen::Map<Eigen::Vector3f>
position(struct xrt_pose &pose)
{
return map_vec3(pose.position);
}
} // namespace xrt::auxiliary::math