mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
d/wmr: Do prediction when returning poses
This commit is contained in:
parent
a41a869c71
commit
1b4b180e61
|
@ -20,6 +20,7 @@
|
||||||
#include "math/m_mathinclude.h"
|
#include "math/m_mathinclude.h"
|
||||||
#include "math/m_api.h"
|
#include "math/m_api.h"
|
||||||
#include "math/m_vec2.h"
|
#include "math/m_vec2.h"
|
||||||
|
#include "math/m_predict.h"
|
||||||
|
|
||||||
#include "util/u_var.h"
|
#include "util/u_var.h"
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
|
@ -140,7 +141,10 @@ hololens_sensors_read_packets(struct wmr_hmd *wh)
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (buffer[0]) {
|
switch (buffer[0]) {
|
||||||
case WMR_MS_HOLOLENS_MSG_SENSORS:
|
case WMR_MS_HOLOLENS_MSG_SENSORS: {
|
||||||
|
// Get the timing as close to reading the packet as possible.
|
||||||
|
uint64_t now_ns = os_monotonic_get_ns();
|
||||||
|
|
||||||
hololens_sensors_decode_packet(wh, &wh->packet, buffer, size);
|
hololens_sensors_decode_packet(wh, &wh->packet, buffer, size);
|
||||||
|
|
||||||
for (int i = 0; i < 4; i++) {
|
for (int i = 0; i < 4; i++) {
|
||||||
|
@ -148,6 +152,8 @@ hololens_sensors_read_packets(struct wmr_hmd *wh)
|
||||||
vec3_from_hololens_accel(wh->packet.accel, i, &wh->raw_accel);
|
vec3_from_hololens_accel(wh->packet.accel, i, &wh->raw_accel);
|
||||||
|
|
||||||
os_mutex_lock(&wh->fusion.mutex);
|
os_mutex_lock(&wh->fusion.mutex);
|
||||||
|
wh->fusion.last_imu_timestamp_ns = now_ns;
|
||||||
|
wh->fusion.last_angular_velocity = wh->raw_gyro;
|
||||||
m_imu_3dof_update( //
|
m_imu_3dof_update( //
|
||||||
&wh->fusion.i3dof, //
|
&wh->fusion.i3dof, //
|
||||||
wh->packet.gyro_timestamp[i] * WMR_MS_HOLOLENS_NS_PER_TICK, //
|
wh->packet.gyro_timestamp[i] * WMR_MS_HOLOLENS_NS_PER_TICK, //
|
||||||
|
@ -156,6 +162,7 @@ hololens_sensors_read_packets(struct wmr_hmd *wh)
|
||||||
os_mutex_unlock(&wh->fusion.mutex);
|
os_mutex_unlock(&wh->fusion.mutex);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case WMR_MS_HOLOLENS_MSG_UNKNOWN_05:
|
case WMR_MS_HOLOLENS_MSG_UNKNOWN_05:
|
||||||
case WMR_MS_HOLOLENS_MSG_UNKNOWN_06:
|
case WMR_MS_HOLOLENS_MSG_UNKNOWN_06:
|
||||||
case WMR_MS_HOLOLENS_MSG_UNKNOWN_0E: //
|
case WMR_MS_HOLOLENS_MSG_UNKNOWN_0E: //
|
||||||
|
@ -370,16 +377,31 @@ wmr_hmd_get_tracked_pose(struct xrt_device *xdev,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear relation.
|
// Variables needed for prediction.
|
||||||
U_ZERO(out_relation);
|
uint64_t last_imu_timestamp_ns = 0;
|
||||||
|
struct xrt_space_relation relation = {0};
|
||||||
|
relation.relation_flags = (enum xrt_space_relation_flags)( //
|
||||||
|
XRT_SPACE_RELATION_ANGULAR_VELOCITY_VALID_BIT | //
|
||||||
|
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT | //
|
||||||
|
XRT_SPACE_RELATION_ORIENTATION_TRACKED_BIT);
|
||||||
|
|
||||||
|
// Get data while holding the lock.
|
||||||
os_mutex_lock(&wh->fusion.mutex);
|
os_mutex_lock(&wh->fusion.mutex);
|
||||||
out_relation->pose.orientation = wh->fusion.i3dof.rot;
|
relation.pose.orientation = wh->fusion.i3dof.rot;
|
||||||
|
relation.angular_velocity = wh->fusion.last_angular_velocity;
|
||||||
|
last_imu_timestamp_ns = wh->fusion.last_imu_timestamp_ns;
|
||||||
os_mutex_unlock(&wh->fusion.mutex);
|
os_mutex_unlock(&wh->fusion.mutex);
|
||||||
|
|
||||||
out_relation->relation_flags = (enum xrt_space_relation_flags)( //
|
// No prediction needed.
|
||||||
XRT_SPACE_RELATION_ORIENTATION_VALID_BIT | //
|
if (at_timestamp_ns < last_imu_timestamp_ns) {
|
||||||
XRT_SPACE_RELATION_ORIENTATION_TRACKED_BIT);
|
*out_relation = relation;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t prediction_ns = at_timestamp_ns - last_imu_timestamp_ns;
|
||||||
|
double prediction_s = time_ns_to_s(prediction_ns);
|
||||||
|
|
||||||
|
m_predict_relation(&relation, prediction_s, out_relation);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -79,6 +79,12 @@ struct wmr_hmd
|
||||||
|
|
||||||
//! Main fusion calculator.
|
//! Main fusion calculator.
|
||||||
struct m_imu_3dof i3dof;
|
struct m_imu_3dof i3dof;
|
||||||
|
|
||||||
|
//! The last angular velocity from the IMU, for prediction.
|
||||||
|
struct xrt_vec3 last_angular_velocity;
|
||||||
|
|
||||||
|
//! When did we get the last IMU sample, in CPU time.
|
||||||
|
uint64_t last_imu_timestamp_ns;
|
||||||
} fusion;
|
} fusion;
|
||||||
|
|
||||||
struct
|
struct
|
||||||
|
|
Loading…
Reference in a new issue