2020-07-23 11:12:03 +00:00
|
|
|
// Copyright 2020, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Functions for manipulating @ref xrt_pose, @ref xrt_space_relation and
|
2022-01-21 15:58:44 +00:00
|
|
|
* @ref xrt_relation_chain structs.
|
2020-07-23 11:12:03 +00:00
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup aux_math
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "xrt/xrt_defines.h"
|
|
|
|
|
|
|
|
#include "math/m_api.h"
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2021-03-06 23:34:35 +00:00
|
|
|
* @addtogroup aux_math
|
2020-07-23 11:12:03 +00:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Pose functions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
static inline bool
|
|
|
|
m_pose_is_identity(struct xrt_pose *pose)
|
|
|
|
{
|
|
|
|
struct xrt_pose p = *pose;
|
|
|
|
|
|
|
|
if ((p.position.x == 0.0f || p.position.x == -0.0f) && // x
|
|
|
|
(p.position.y == 0.0f || p.position.y == -0.0f) && // y
|
|
|
|
(p.position.z == 0.0f || p.position.z == -0.0f) && // z
|
|
|
|
(p.orientation.x == 0.0f || p.orientation.x == -0.0f) && // x
|
|
|
|
(p.orientation.y == 0.0f || p.orientation.y == -0.0f) && // y
|
|
|
|
(p.orientation.z == 0.0f || p.orientation.z == -0.0f) && // z
|
|
|
|
(p.orientation.w == 1.0f || p.orientation.w == -1.0f) // w
|
|
|
|
) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Space relation functions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
static inline void
|
2021-01-14 14:13:48 +00:00
|
|
|
m_space_relation_from_pose(const struct xrt_pose *pose, struct xrt_space_relation *out_relation)
|
2020-07-23 11:12:03 +00:00
|
|
|
{
|
2021-01-14 14:13:48 +00:00
|
|
|
enum xrt_space_relation_flags flags = (enum xrt_space_relation_flags)(XRT_SPACE_RELATION_ORIENTATION_VALID_BIT |
|
|
|
|
XRT_SPACE_RELATION_POSITION_VALID_BIT);
|
2020-07-23 11:12:03 +00:00
|
|
|
struct xrt_space_relation relation = {
|
2020-09-04 10:41:28 +00:00
|
|
|
flags,
|
|
|
|
*pose,
|
2021-04-26 20:05:34 +00:00
|
|
|
XRT_VEC3_ZERO,
|
|
|
|
XRT_VEC3_ZERO,
|
2020-07-23 11:12:03 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
*out_relation = relation;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
m_space_relation_ident(struct xrt_space_relation *out_relation)
|
|
|
|
{
|
2021-04-26 20:05:34 +00:00
|
|
|
struct xrt_pose identity = XRT_POSE_IDENTITY;
|
2020-07-23 11:12:03 +00:00
|
|
|
|
|
|
|
m_space_relation_from_pose(&identity, out_relation);
|
|
|
|
}
|
|
|
|
|
2020-11-12 23:20:22 +00:00
|
|
|
void
|
2021-01-14 14:13:48 +00:00
|
|
|
m_space_relation_invert(struct xrt_space_relation *relation, struct xrt_space_relation *out_relation);
|
2020-07-23 11:12:03 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
2022-01-21 15:58:44 +00:00
|
|
|
* Relation chain functions.
|
2020-07-23 11:12:03 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
2022-01-21 15:58:44 +00:00
|
|
|
* Reserve a step in the chain and return a pointer to the relation.
|
|
|
|
*
|
|
|
|
* @note The data pointed to by the returned pointer is not initialized:
|
|
|
|
* you must populate it before using @ref m_relation_chain_resolve
|
|
|
|
*
|
|
|
|
* @public @memberof xrt_relation_chain
|
2020-07-23 11:12:03 +00:00
|
|
|
*/
|
|
|
|
static inline struct xrt_space_relation *
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_reserve(struct xrt_relation_chain *xrc)
|
2020-07-23 11:12:03 +00:00
|
|
|
{
|
2022-01-21 15:58:44 +00:00
|
|
|
if (xrc->step_count < XRT_RELATION_CHAIN_CAPACITY) {
|
|
|
|
return &xrc->steps[xrc->step_count++];
|
2020-07-23 11:12:03 +00:00
|
|
|
} else {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
2022-01-21 15:58:44 +00:00
|
|
|
* Append a new relation
|
|
|
|
*
|
|
|
|
* @public @memberof xrt_relation_chain
|
2020-07-23 11:12:03 +00:00
|
|
|
*/
|
|
|
|
static inline void
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_relation(struct xrt_relation_chain *xrc, const struct xrt_space_relation *relation)
|
2020-07-23 11:12:03 +00:00
|
|
|
{
|
2022-01-21 15:58:44 +00:00
|
|
|
if (xrc->step_count >= XRT_RELATION_CHAIN_CAPACITY) {
|
2020-07-23 11:12:03 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-01-21 15:58:44 +00:00
|
|
|
xrc->steps[xrc->step_count++] = *relation;
|
2020-07-23 11:12:03 +00:00
|
|
|
}
|
|
|
|
|
2022-01-21 15:58:44 +00:00
|
|
|
/*!
|
|
|
|
* Append the inverse of the provided relation.
|
|
|
|
*
|
|
|
|
* Validity flags stay the same, only the pose and velocities are inverted.
|
|
|
|
*
|
|
|
|
* @public @memberof xrt_relation_chain
|
|
|
|
*/
|
2020-11-12 23:21:19 +00:00
|
|
|
static inline void
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_inverted_relation(struct xrt_relation_chain *xrc, const struct xrt_space_relation *relation)
|
2020-11-12 23:21:19 +00:00
|
|
|
{
|
|
|
|
struct xrt_space_relation r = *relation;
|
|
|
|
|
|
|
|
struct xrt_space_relation invert;
|
|
|
|
m_space_relation_invert(&r, &invert);
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_relation(xrc, &invert);
|
2020-11-12 23:21:19 +00:00
|
|
|
}
|
|
|
|
|
2022-01-21 15:58:44 +00:00
|
|
|
/*!
|
|
|
|
* Append a new pose as a relation without velocity
|
|
|
|
*
|
|
|
|
* @public @memberof xrt_relation_chain
|
|
|
|
*/
|
2020-07-23 11:12:03 +00:00
|
|
|
static inline void
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_pose(struct xrt_relation_chain *xrc, const struct xrt_pose *pose)
|
2020-07-23 11:12:03 +00:00
|
|
|
{
|
|
|
|
struct xrt_space_relation relation;
|
|
|
|
m_space_relation_from_pose(pose, &relation);
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_relation(xrc, &relation);
|
2020-07-23 11:12:03 +00:00
|
|
|
}
|
|
|
|
|
2022-01-21 15:58:44 +00:00
|
|
|
/*!
|
|
|
|
* Append a new pose as a relation without velocity, if it is not the identity pose.
|
|
|
|
*
|
|
|
|
* @public @memberof xrt_relation_chain
|
|
|
|
*/
|
2020-07-23 11:12:03 +00:00
|
|
|
static inline void
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_pose_if_not_identity(struct xrt_relation_chain *xrc, const struct xrt_pose *pose)
|
2020-07-23 11:12:03 +00:00
|
|
|
{
|
|
|
|
struct xrt_pose p = *pose;
|
|
|
|
|
|
|
|
if (m_pose_is_identity(&p)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_pose(xrc, &p);
|
2020-07-23 11:12:03 +00:00
|
|
|
}
|
|
|
|
|
2022-01-21 15:58:44 +00:00
|
|
|
/*!
|
|
|
|
* Append the inverse of a pose as a relation without velocity, if it is not the identity pose.
|
|
|
|
*
|
|
|
|
* Validity flags stay the same, only the pose is inverted.
|
|
|
|
*
|
|
|
|
* @public @memberof xrt_relation_chain
|
|
|
|
*/
|
2020-07-23 11:12:03 +00:00
|
|
|
static inline void
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_inverted_pose_if_not_identity(struct xrt_relation_chain *xrc, const struct xrt_pose *pose)
|
2020-07-23 11:12:03 +00:00
|
|
|
{
|
|
|
|
struct xrt_pose p = *pose;
|
|
|
|
|
|
|
|
if (m_pose_is_identity(&p)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct xrt_pose invert;
|
|
|
|
math_pose_invert(&p, &invert);
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_push_pose(xrc, &invert);
|
2020-07-23 11:12:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
2022-01-21 15:58:44 +00:00
|
|
|
* Compute the equivalent single relation from flattening a relation chain.
|
|
|
|
*
|
|
|
|
* The input chain is not modified.
|
|
|
|
*
|
|
|
|
* @public @memberof xrt_relation_chain
|
2020-07-23 11:12:03 +00:00
|
|
|
*/
|
|
|
|
void
|
2022-01-21 15:58:44 +00:00
|
|
|
m_relation_chain_resolve(const struct xrt_relation_chain *xrc, struct xrt_space_relation *out_relation);
|
2020-07-23 11:12:03 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|