mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
d/vive: Apply all axis flip after scale and bias
This commit is contained in:
parent
995ecfaac2
commit
8306e00bd1
|
@ -294,9 +294,9 @@ update_imu(struct vive_device *d, struct vive_imu_report *report)
|
||||||
|
|
||||||
scale = (float)d->imu.acc_range / 32768.0f;
|
scale = (float)d->imu.acc_range / 32768.0f;
|
||||||
struct xrt_vec3 acceleration = {
|
struct xrt_vec3 acceleration = {
|
||||||
-scale * d->imu.acc_scale.x * acc[0] - d->imu.acc_bias.x,
|
scale * d->imu.acc_scale.x * acc[0] - d->imu.acc_bias.x,
|
||||||
-scale * d->imu.acc_scale.y * acc[1] - d->imu.acc_bias.y,
|
scale * d->imu.acc_scale.y * acc[1] - d->imu.acc_bias.y,
|
||||||
-scale * d->imu.acc_scale.z * acc[2] - d->imu.acc_bias.z,
|
scale * d->imu.acc_scale.z * acc[2] - d->imu.acc_bias.z,
|
||||||
};
|
};
|
||||||
|
|
||||||
int16_t gyro[3] = {
|
int16_t gyro[3] = {
|
||||||
|
@ -307,9 +307,9 @@ update_imu(struct vive_device *d, struct vive_imu_report *report)
|
||||||
|
|
||||||
scale = (float)d->imu.gyro_range / 32768.0f;
|
scale = (float)d->imu.gyro_range / 32768.0f;
|
||||||
struct xrt_vec3 angular_velocity = {
|
struct xrt_vec3 angular_velocity = {
|
||||||
-scale * d->imu.gyro_scale.x * gyro[0] - d->imu.gyro_bias.x,
|
scale * d->imu.gyro_scale.x * gyro[0] - d->imu.gyro_bias.x,
|
||||||
-scale * d->imu.gyro_scale.y * gyro[1] - d->imu.gyro_bias.y,
|
scale * d->imu.gyro_scale.y * gyro[1] - d->imu.gyro_bias.y,
|
||||||
-scale * d->imu.gyro_scale.z * gyro[2] - d->imu.gyro_bias.z,
|
scale * d->imu.gyro_scale.z * gyro[2] - d->imu.gyro_bias.z,
|
||||||
};
|
};
|
||||||
|
|
||||||
VIVE_SPEW(d, "ACC %f %f %f", acceleration.x, acceleration.y,
|
VIVE_SPEW(d, "ACC %f %f %f", acceleration.x, acceleration.y,
|
||||||
|
@ -320,18 +320,23 @@ update_imu(struct vive_device *d, struct vive_imu_report *report)
|
||||||
|
|
||||||
switch (d->variant) {
|
switch (d->variant) {
|
||||||
case VIVE_VARIANT_VIVE:
|
case VIVE_VARIANT_VIVE:
|
||||||
// flip x axis
|
// flip all execpt x axis
|
||||||
angular_velocity.x = -angular_velocity.x;
|
angular_velocity.x = +angular_velocity.x;
|
||||||
|
angular_velocity.y = -angular_velocity.y;
|
||||||
|
angular_velocity.z = -angular_velocity.z;
|
||||||
break;
|
break;
|
||||||
case VIVE_VARIANT_PRO:
|
case VIVE_VARIANT_PRO:
|
||||||
// flip y axis
|
// flip all execpt y axis
|
||||||
angular_velocity.y = -angular_velocity.y;
|
angular_velocity.x = -angular_velocity.x;
|
||||||
|
angular_velocity.y = +angular_velocity.y;
|
||||||
|
angular_velocity.z = -angular_velocity.z;
|
||||||
break;
|
break;
|
||||||
case VIVE_VARIANT_INDEX: {
|
case VIVE_VARIANT_INDEX: {
|
||||||
|
// Flip all axis and re-order.
|
||||||
struct xrt_vec3 angular_velocity_fixed;
|
struct xrt_vec3 angular_velocity_fixed;
|
||||||
angular_velocity_fixed.x = angular_velocity.y;
|
angular_velocity_fixed.x = -angular_velocity.y;
|
||||||
angular_velocity_fixed.y = angular_velocity.x;
|
angular_velocity_fixed.y = -angular_velocity.x;
|
||||||
angular_velocity_fixed.z = angular_velocity.z;
|
angular_velocity_fixed.z = -angular_velocity.z;
|
||||||
angular_velocity = angular_velocity_fixed;
|
angular_velocity = angular_velocity_fixed;
|
||||||
} break;
|
} break;
|
||||||
default: VIVE_ERROR("Unhandled Vive variant\n"); return;
|
default: VIVE_ERROR("Unhandled Vive variant\n"); return;
|
||||||
|
|
Loading…
Reference in a new issue