Skip to content

[ECCV 2024] 3DGazeNet: Generalizing Gaze Estimation with Weak-Supervision from Synthetic Views

Notifications You must be signed in to change notification settings

eververas/3DGazeNet

Repository files navigation

[ECCV 2024] 3DGazeNet: Generalizing Gaze Estimation with Weak-Supervision from Synthetic Views

We propose to train general gaze estimation models which can be directly employed in novel environments without adaptation. To do so, we leverage the observation that head, body, and hand pose estimation benefit from revising them as dense 3D coordinate prediction, and similarly express gaze estimation as regression of dense 3D eye meshes.

demo_vid.mp4

Installation

To create a conda environment with the required dependences run the command:

$ conda env create --file env_requirements.yaml
$ conda activate 3DGazeNet

Download models

Download the data directory contatining pre-trained gaze estimation models from here. Extract and place the data folder in the root directory of this repo.

Inference

To run inference on a set of images follow the steps below. A set of example images are given in the data/example_images directory.

1. Pre-process the set of images. This step performs face detection and exports a .pkl file in the path defined by --output_dir, containing pre-processing data. For data pre-processing run the following command:

$ cd tools
$ python preprocess_inference.py --image_base_dir ../data/example_images 
                                 --output_dir ../output/preprocessing
                                 --gpu_id 0 --n_procs 5

2. Run inference on the set of images. This step outputs gaze estimation and 3D eye reconstruction results in a .pkl file in the inference_results directory. For inference run the following command:

$ python inference.py --cfg configs/inference/inference.yaml
                      --inference_data_file 'output/preprocessing/data_face68.pkl'
                      --inference_dataset_dir 'data/example_images/'
                      --checkpoint data/3dgazenet/models/singleview/vertex/ALL/test_0/checkpoint.pth
                      --skip_optimizer

3. To inspect the gaze tracking results run the jupyter notebook in notebooks/view-inference_results.ipynb.

Bash scripts for the above commands can be found in the scripts directory.

Prepare Datasets

ETH-XGaze

1. Download the 448*448 pixels version of the datset from the official source here. Place the dataset in the datasets folder in the root of this repo.

2. Fit 3D eyes on images using the following command. This will export a .pkl data file in the dataset's folder which is used for training.

cd tools
python xgaze_preprocess.py

3. To visualize the 3D eye fittings run the notebook in notebooks/xgaze_view_dataset.ipynb.

Gaze360

1. Download the datset from the official source here. Place the dataset in the datasets folder in the root of this repo.

2. Fit 3D eyes on images using the following command. This will export a .pkl data file in the dataset's folder which is used for training.

cd tools
python gaze360_preprocess.py

3. To visualize the 3D eye fittings run the notebook in notebooks/gaze360_view_dataset.ipynb.

GazeCapture

1. Download the datset from the official source here. Place the dataset in the datasets folder in the root of this repo.

MPIIFaceGaze

1. Download the aligned dataset from the official source here. Place the dataset in the datasets folder in the root of this repo.

2. Fit 3D eyes on images using the following command. This will export a .pkl data file in the dataset's folder which is used for training.

cd tools
python mpiiface_preprocess.py

3. To visualize the 3D eye fittings run the notebook in notebooks/mpiiface_view_dataset.ipynb.

Citation

If you find our work useful in your research, please consider to cite our paper:

@inproceedings{ververas2024dgazenet,
  title={3DGazeNet: Generalizing Gaze Estimation with Weak-Supervision from Synthetic Views},
  author={Ververas, Evangelos and Gkagkos, Polydefkis and Deng, Jiankang and Christos Doukas, Michail and Guo, Jia and Zafeiriou, Stefanos},
  booktitle={ECCV},
  year={2024}
}

About

[ECCV 2024] 3DGazeNet: Generalizing Gaze Estimation with Weak-Supervision from Synthetic Views

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published