mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-24 15:41:55 +00:00
05b8e320a5
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.
232 lines
5.7 KiB
C++
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
|