mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-01 12:46:12 +00:00
d/vive: Apply IMU pose correction for SLAM tracking
The offset between IMU and middle-of-eyes for the Index is quite noticeable and tracking felt very off before this.
This commit is contained in:
parent
21788f8650
commit
8f14c572ee
|
@ -159,6 +159,10 @@ vive_device_get_slam_tracked_pose(struct xrt_device *xdev,
|
|||
#endif
|
||||
}
|
||||
|
||||
if (d->tracking.imu2me) {
|
||||
math_pose_transform(&d->pose, &d->P_imu_me, &d->pose);
|
||||
}
|
||||
|
||||
out_relation->pose = d->pose;
|
||||
out_relation->relation_flags = (enum xrt_space_relation_flags)(
|
||||
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT | XRT_SPACE_RELATION_POSITION_VALID_BIT |
|
||||
|
@ -810,6 +814,7 @@ vive_device_setup_ui(struct vive_device *d)
|
|||
|
||||
u_var_add_gui_header(d, NULL, "SLAM Tracking");
|
||||
u_var_add_ro_text(d, d->gui.slam_status, "Tracker status");
|
||||
u_var_add_bool(d, &d->tracking.imu2me, "Correct IMU pose to middle of eyes");
|
||||
|
||||
u_var_add_gui_header(d, NULL, "Hand Tracking");
|
||||
u_var_add_ro_text(d, d->gui.hand_status, "Tracker status");
|
||||
|
@ -842,6 +847,7 @@ vive_set_trackers_status(struct vive_device *d, struct vive_tracking_status stat
|
|||
|
||||
d->tracking.slam_enabled = slam_enabled;
|
||||
d->tracking.hand_enabled = hand_enabled;
|
||||
d->tracking.imu2me = true;
|
||||
|
||||
d->slam_over_3dof = slam_enabled; // We prefer SLAM over 3dof tracking if possible
|
||||
|
||||
|
@ -859,6 +865,49 @@ vive_set_trackers_status(struct vive_device *d, struct vive_tracking_status stat
|
|||
snprintf(d->gui.hand_status, sizeof(d->gui.hand_status), "%s", hand_status);
|
||||
}
|
||||
|
||||
/*!
|
||||
* Precompute transforms to convert between OpenXR and device coordinate systems.
|
||||
*
|
||||
* OpenXR: X: Right, Y: Up, Z: Backward
|
||||
* Index / tracking reference / tr: X: Left, Y: Up, Z: Forward
|
||||
*/
|
||||
static void
|
||||
precompute_sensor_transforms(struct vive_device *d)
|
||||
{
|
||||
// P_A_B is such that B = P_A_B * A. See conventions.md
|
||||
|
||||
struct xrt_pose P_tr_imu = d->config.imu.trackref;
|
||||
|
||||
struct xrt_pose P_tr_me = d->config.display.trackref;
|
||||
|
||||
struct xrt_pose P_imu_tr = {0};
|
||||
math_pose_invert(&P_tr_imu, &P_imu_tr);
|
||||
|
||||
struct xrt_pose P_imu_me = {0};
|
||||
math_pose_transform(&P_imu_tr, &P_tr_me, &P_imu_me);
|
||||
|
||||
// Rotation needed to convert IMU coords to OpenXR coords. E.g., for an Index
|
||||
// it goes from X: down, Y: left, Z: forward to X: right, Y: up, Z: backward
|
||||
struct xrt_quat Q_imu_tr = P_imu_tr.orientation;
|
||||
struct xrt_quat Q_tr_oxr = {.x = 0, .y = 1, .z = 0, .w = 0};
|
||||
struct xrt_quat Q_imu_oxr = {0};
|
||||
math_quat_rotate(&Q_imu_tr, &Q_tr_oxr, &Q_imu_oxr);
|
||||
|
||||
// imuxr is the same IMU entity but with axes rotated to be like OpenXR
|
||||
struct xrt_pose P_imu_imuxr = {Q_imu_oxr, XRT_VEC3_ZERO};
|
||||
|
||||
struct xrt_pose P_tr_imuxr = {0};
|
||||
math_pose_transform(&P_tr_imu, &P_imu_imuxr, &P_tr_imuxr);
|
||||
|
||||
struct xrt_pose P_imuxr_imu = {0};
|
||||
math_pose_invert(&P_imu_imuxr, &P_imuxr_imu);
|
||||
|
||||
struct xrt_pose P_imuxr_me = {0};
|
||||
math_pose_transform(&P_imuxr_imu, &P_imu_me, &P_imuxr_me);
|
||||
|
||||
d->P_imu_me = P_imuxr_me;
|
||||
}
|
||||
|
||||
struct vive_device *
|
||||
vive_device_create(struct os_hid_device *mainboard_dev,
|
||||
struct os_hid_device *sensors_dev,
|
||||
|
@ -982,6 +1031,8 @@ vive_device_create(struct os_hid_device *mainboard_dev,
|
|||
}
|
||||
}
|
||||
|
||||
precompute_sensor_transforms(d);
|
||||
|
||||
// Init threads.
|
||||
os_thread_helper_init(&d->mainboard_thread);
|
||||
os_thread_helper_init(&d->sensors_thread);
|
||||
|
|
|
@ -96,8 +96,12 @@ struct vive_device
|
|||
//! Set at start. Whether the hand tracker was initialized.
|
||||
bool hand_enabled;
|
||||
|
||||
//! SLAM systems track the IMU pose, enabling this corrects it to middle of the eyes
|
||||
bool imu2me;
|
||||
} tracking;
|
||||
|
||||
struct xrt_pose P_imu_me; //!< IMU to head/display/middle-of-eyes transform in OpenXR coords
|
||||
|
||||
//! Whether to track the HMD with 6dof SLAM or fallback to the 3dof tracker
|
||||
bool slam_over_3dof;
|
||||
|
||||
|
|
Loading…
Reference in a new issue