2019-03-18 05:52:32 +00:00
|
|
|
// Copyright 2019, 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>
|
2019-04-06 11:29:47 +00:00
|
|
|
* @ingroup aux_math
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#ifndef __cplusplus
|
|
|
|
#error "This header only usable from C++"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "math/m_api.h"
|
|
|
|
|
|
|
|
#include <Eigen/Core>
|
|
|
|
#include <Eigen/Geometry>
|
|
|
|
|
2019-11-21 13:15:38 +00:00
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
/*!
|
|
|
|
* @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>
|
2019-09-29 10:42:53 +00:00
|
|
|
map_quat(const struct xrt_quat &q)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
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>
|
2019-09-29 10:42:53 +00:00
|
|
|
map_quat(struct xrt_quat &q)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
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>
|
2019-09-29 10:42:53 +00:00
|
|
|
map_vec3(const struct xrt_vec3 &v)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
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>
|
2019-09-29 10:42:53 +00:00
|
|
|
map_vec3(struct xrt_vec3 &v)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
return Eigen::Map<Eigen::Vector3f>{&v.x};
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Pose deconstruction helpers.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Return a Eigen type wrapping a pose's orientation (const).
|
|
|
|
*/
|
|
|
|
static inline Eigen::Map<const Eigen::Quaternionf>
|
2019-09-29 10:42:53 +00:00
|
|
|
orientation(const struct xrt_pose &pose)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
return map_quat(pose.orientation);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Return a Eigen type wrapping a pose's orientation.
|
|
|
|
*/
|
|
|
|
static inline Eigen::Map<Eigen::Quaternionf>
|
2019-09-29 10:42:53 +00:00
|
|
|
orientation(struct xrt_pose &pose)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
return map_quat(pose.orientation);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Return a Eigen type wrapping a pose's position (const).
|
|
|
|
*/
|
|
|
|
static inline Eigen::Map<const Eigen::Vector3f>
|
2019-09-29 10:42:53 +00:00
|
|
|
position(const struct xrt_pose &pose)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
return map_vec3(pose.position);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Return a Eigen type wrapping a pose's position.
|
|
|
|
*/
|
|
|
|
static inline Eigen::Map<Eigen::Vector3f>
|
2019-09-29 10:42:53 +00:00
|
|
|
position(struct xrt_pose &pose)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
return map_vec3(pose.position);
|
|
|
|
}
|