a/vive: Generate FoV values in config

This commit is contained in:
Jakob Bornecrantz 2023-04-22 22:53:06 +01:00
parent 62c483301c
commit 7b691ccab7
4 changed files with 75 additions and 17 deletions

View file

@ -106,8 +106,8 @@ _get_distortion_properties(struct vive_config *d, const cJSON *eye_transform_jso
// TODO: store grow_for_undistort per eye // TODO: store grow_for_undistort per eye
// clang-format off // clang-format off
JSON_FLOAT(eye_json, "grow_for_undistort", &d->distortion[eye].grow_for_undistort); JSON_FLOAT(eye_json, "grow_for_undistort", &d->distortion.values[eye].grow_for_undistort);
JSON_FLOAT(eye_json, "undistort_r2_cutoff", &d->distortion[eye].undistort_r2_cutoff); JSON_FLOAT(eye_json, "undistort_r2_cutoff", &d->distortion.values[eye].undistort_r2_cutoff);
// clang-format on // clang-format on
const char *names[3] = { const char *names[3] = {
@ -122,12 +122,12 @@ _get_distortion_properties(struct vive_config *d, const cJSON *eye_transform_jso
continue; continue;
} }
JSON_FLOAT(distortion, "center_x", &d->distortion[eye].center[i].x); JSON_FLOAT(distortion, "center_x", &d->distortion.values[eye].center[i].x);
JSON_FLOAT(distortion, "center_y", &d->distortion[eye].center[i].y); JSON_FLOAT(distortion, "center_y", &d->distortion.values[eye].center[i].y);
const cJSON *coeffs = cJSON_GetObjectItemCaseSensitive(distortion, "coeffs"); const cJSON *coeffs = cJSON_GetObjectItemCaseSensitive(distortion, "coeffs");
if (coeffs != NULL) { if (coeffs != NULL) {
_get_color_coeffs(&d->distortion[eye], coeffs, eye, i); _get_color_coeffs(&d->distortion.values[eye], coeffs, eye, i);
} }
} }
} }
@ -330,12 +330,60 @@ vive_init_defaults(struct vive_config *d)
d->cameras.valid = false; d->cameras.valid = false;
for (int view = 0; view < 2; view++) { for (int view = 0; view < 2; view++) {
d->distortion[view].aspect_x_over_y = 0.89999997615814209f; d->distortion.values[view].aspect_x_over_y = 0.89999997615814209f;
d->distortion[view].grow_for_undistort = 0.5f; d->distortion.values[view].grow_for_undistort = 0.5f;
d->distortion[view].undistort_r2_cutoff = 1.0f; d->distortion.values[view].undistort_r2_cutoff = 1.0f;
} }
} }
static bool
_calculate_fov(struct vive_config *d)
{
// TODO: Replace hard coded values from OpenHMD with config
double w_meters = 0.122822 / 2.0;
double h_meters = 0.068234;
double lens_horizontal_separation = 0.057863;
double eye_to_screen_distance = 0.023226876441867737;
if (d->variant == VIVE_VARIANT_INDEX) {
lens_horizontal_separation = 0.06;
h_meters = 0.07;
// eye relief knob adjusts this around [0.0255(near)-0.275(far)]
eye_to_screen_distance = 0.0255;
}
double fov = 2 * atan2(w_meters - lens_horizontal_separation / 2.0, eye_to_screen_distance);
struct xrt_vec2 lens_center[2];
for (uint8_t eye = 0; eye < 2; eye++) {
lens_center[eye].y = (float)h_meters / 2.0f;
}
// Left
lens_center[0].x = (float)(w_meters - lens_horizontal_separation / 2.0);
// Right
lens_center[1].x = (float)lens_horizontal_separation / 2.0f;
for (uint8_t eye = 0; eye < 2; eye++) {
bool bret = math_compute_fovs( //
w_meters, //
(double)lens_center[eye].x, //
fov, //
h_meters, //
(double)lens_center[eye].y, //
0, //
&d->distortion.fov[eye]); //
if (!bret) {
VIVE_ERROR(d, "Failed to compute the partial fields of view.");
free(d);
return false;
}
}
return true;
}
/* /*
* *
@ -442,9 +490,9 @@ vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level
if (device_json) { if (device_json) {
if (d->variant != VIVE_VARIANT_INDEX) { if (d->variant != VIVE_VARIANT_INDEX) {
JSON_DOUBLE(device_json, "persistence", &d->display.persistence); JSON_DOUBLE(device_json, "persistence", &d->display.persistence);
JSON_FLOAT(device_json, "physical_aspect_x_over_y", &d->distortion[0].aspect_x_over_y); JSON_FLOAT(device_json, "physical_aspect_x_over_y", &d->distortion.values[0].aspect_x_over_y);
d->distortion[1].aspect_x_over_y = d->distortion[0].aspect_x_over_y; d->distortion.values[1].aspect_x_over_y = d->distortion.values[0].aspect_x_over_y;
} }
JSON_INT(device_json, "eye_target_height_in_pixels", &d->display.eye_target_height_in_pixels); JSON_INT(device_json, "eye_target_height_in_pixels", &d->display.eye_target_height_in_pixels);
JSON_INT(device_json, "eye_target_width_in_pixels", &d->display.eye_target_width_in_pixels); JSON_INT(device_json, "eye_target_width_in_pixels", &d->display.eye_target_width_in_pixels);
@ -457,13 +505,19 @@ vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level
} }
} }
if (!_calculate_fov(d)) {
VIVE_ERROR(d, "Could not calculate fields of view.");
vive_config_teardown(d);
return false;
}
cJSON_Delete(json); cJSON_Delete(json);
// clang-format off // clang-format off
VIVE_DEBUG(d, "= Vive configuration ="); VIVE_DEBUG(d, "= Vive configuration =");
VIVE_DEBUG(d, "lens_separation: %f", d->display.lens_separation); VIVE_DEBUG(d, "lens_separation: %f", d->display.lens_separation);
VIVE_DEBUG(d, "persistence: %f", d->display.persistence); VIVE_DEBUG(d, "persistence: %f", d->display.persistence);
VIVE_DEBUG(d, "physical_aspect_x_over_y: %f", (double)d->distortion[0].aspect_x_over_y); VIVE_DEBUG(d, "physical_aspect_x_over_y: %f", (double)d->distortion.values[0].aspect_x_over_y);
VIVE_DEBUG(d, "model_number: %s", d->firmware.model_number); VIVE_DEBUG(d, "model_number: %s", d->firmware.model_number);
VIVE_DEBUG(d, "mb_serial_number: %s", d->firmware.mb_serial_number); VIVE_DEBUG(d, "mb_serial_number: %s", d->firmware.mb_serial_number);
@ -479,10 +533,10 @@ vive_config_parse(struct vive_config *d, char *json_string, enum u_logging_level
_print_vec3("gyro_scale", &d->imu.gyro_scale); _print_vec3("gyro_scale", &d->imu.gyro_scale);
} }
VIVE_DEBUG(d, "grow_for_undistort: %f", (double)d->distortion[0].grow_for_undistort); VIVE_DEBUG(d, "grow_for_undistort: %f", (double)d->distortion.values[0].grow_for_undistort);
VIVE_DEBUG(d, "undistort_r2_cutoff 0: %f", (double)d->distortion[0].undistort_r2_cutoff); VIVE_DEBUG(d, "undistort_r2_cutoff 0: %f", (double)d->distortion.values[0].undistort_r2_cutoff);
VIVE_DEBUG(d, "undistort_r2_cutoff 1: %f", (double)d->distortion[1].undistort_r2_cutoff); VIVE_DEBUG(d, "undistort_r2_cutoff 1: %f", (double)d->distortion.values[1].undistort_r2_cutoff);
// clang-format on // clang-format on
return true; return true;

View file

@ -184,7 +184,11 @@ struct vive_config
char device_serial_number[32]; char device_serial_number[32];
} firmware; } firmware;
struct u_vive_values distortion[2]; struct
{
struct u_vive_values values[2];
struct xrt_fov fov[2];
} distortion;
struct struct
{ {

View file

@ -870,7 +870,7 @@ static bool
compute_distortion(struct xrt_device *xdev, uint32_t view, float u, float v, struct xrt_uv_triplet *result) compute_distortion(struct xrt_device *xdev, uint32_t view, float u, float v, struct xrt_uv_triplet *result)
{ {
struct survive_device *d = (struct survive_device *)xdev; struct survive_device *d = (struct survive_device *)xdev;
return u_compute_distortion_vive(&d->hmd.config.distortion[view], u, v, result); return u_compute_distortion_vive(&d->hmd.config.distortion.values[view], u, v, result);
} }
static bool static bool

View file

@ -857,7 +857,7 @@ compute_distortion(struct xrt_device *xdev, uint32_t view, float u, float v, str
XRT_TRACE_MARKER(); XRT_TRACE_MARKER();
struct vive_device *d = vive_device(xdev); struct vive_device *d = vive_device(xdev);
return u_compute_distortion_vive(&d->config.distortion[view], u, v, result); return u_compute_distortion_vive(&d->config.distortion.values[view], u, v, result);
} }
void void