Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Pass eye camera focal_length to 3D detector #1995

Merged
merged 15 commits into from
Sep 2, 2020
Merged

Pass eye camera focal_length to 3D detector #1995

merged 15 commits into from
Sep 2, 2020

Conversation

pfaion
Copy link
Contributor

@pfaion pfaion commented Aug 24, 2020

This PR uses the eye camera intrinsics (specifically focal_length) to get a more accurate 3D eyeball position estimate.

Depends on pupil-detectors v1.1.1, upgrade with

pip install -U pupil-detectors

Summary

  • Added known intrinsics for the eye cameras to camera_models.py
  • On recording stop, current eye camera intrinsics are saved to the recording (like with world.intrinsics)
  • The 3D detector is initialized with g_pool.capture.intrinsics.focal_length (cannot be changed at runtime)
  • On focal_length changes (e.g. by changing the resolution), the 3D detector and all dependent UI is re-initialized
  • Added clear warnings that loading dummy intrinsics is not good
  • Added upgrade mechanism (RecordingInfo v2.3) which creates eye(0/1).intrinsics files when opening an older recording, as these will be tried to load from. To make it easy, we just serialize all intrinsics for eye cameras Cam1 and Cam2, the correct intrinsics will be picked later based on the actual resolution. This is not correct if Cam3 was used to recording, but there is no way of figuring this out.

Tests

  1. Run Capture and open the 3D detector debug window while wearing a headset. The eyeball-center z coordinate should be relatively stable (+/-5mm). Switch the resolution of the eye camera. The debug window reopens with a reset model. After stabilizing, the eyeball-center z coordinate should settle down to the same value as with the other resolution (+/-5mm).

  2. Make a recording, the recording should contain eye0.intrinsics and eye1.intrinsics files.

  3. Open the recording in player and check that the post-hoc pupil detection works fine.

  4. Open an older recording in player and check that the post-hoc pupil detection works fine. The recording should contain eye0.intrinsics and eye1.intrinsics files afterwards.

  5. Open a fresh pupil mobile recording in player and check that the post-hoc pupil detection works fine. The recording should contain eye0.intrinsics and eye1.intrinsics files afterwards.

@pfaion pfaion requested review from papr and romanroibu August 24, 2020 16:58
@pfaion
Copy link
Contributor Author

pfaion commented Aug 25, 2020

@papr @romanroibu I added some tests to the description, maybe you can coordinate with regards to testing and having a look at the code changes.

@pfaion
Copy link
Contributor Author

pfaion commented Aug 25, 2020

@papr should I add a comment that only the focal lengths of the eye camera intrinsics were actually measured and the rest is currently just default values (for principal point) and identities (for distortion coordinates)?

@papr
Copy link
Contributor

papr commented Aug 25, 2020

Yes, please do so

@pfaion
Copy link
Contributor Author

pfaion commented Aug 26, 2020

I added GitHub labels as long as we have not released pupil-detectors v1.1.1 to PyPI.

Copy link
Contributor

@romanroibu romanroibu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

performed the tests (except for the last step with mobile recording) and everything seems to work file 👍🏻

@pfaion
Copy link
Contributor Author

pfaion commented Sep 1, 2020

I'll fix the merge conflicts...

@papr papr merged commit 2dc750c into develop Sep 2, 2020
@papr papr deleted the focal_length branch September 2, 2020 14:17
@papr papr mentioned this pull request Nov 2, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants