The optimization of the neural stimulation protocol remains an important challenge to be addressed in the development of visual prosthetics. Our research explores a simulation-based deep learning pipeline for the automated optimization of visual prosthetics in an end-to-end fashion.
The code for our original proof-of-principle paper on end-to-end optimization of prosthetic vision can be found in the e2e_paper branch and can be cited as:
- de Ruyter van Steveninck, J., Güçlü, U., van Wezel, R., & van Gerven, M. (2022). End-to-end optimization of Prosthetic Vision. Journal of Vision, 22(2), 20. https://doi.org/10.1167/jov.22.2.20
Recently, our lab developed a more biologically plausible simulator that accounts for specific stimulation parameters, temporal dynamics and other findings from recent clinical literature (integrated in the main branch):
- van der Grinten, M., de Ruyter van Steveninck, J., Lozano, A., Pijnacker, L., Rückauer, B., Roelfsema, P., van Gerven, M., van Wezel, R., Güçlü, U., Güçlütürk, Y. (2024) Towards biologically plausible phosphene simulation for the differentiable optimization of visual cortical prostheses eLife 13:e85812. https://doi.org/10.7554/eLife.85812
-
Download the datasets:
- ADE20K dataset
- Moving MNIST video dataset
- Or use a different dataset (modify local_datasets.py accordingly).
-
Install the dynaphos simulator package for biologically plausible simulation of cortical prosthetic vision (see the dynaphos repository)
-
either install via pip:
pip install dynaphos
-
or install the bleeding edge version:
git clone https://github.com/neuralcodinglab/dynaphos dynaphos-core cd dynaphos-core python setup.py install
-
-
(optional) Adjust or add training pipelines in init_training.py according to needs.
-
(optional) Adjust or add yaml file with training configuration (in the ./_config directory).
- Make sure to correctly set the save_path, data_directory, the simulator base_config and phosphene_map with the right paths.
- Set load_preprocessed to False if no access to preprocessed dataset.
-
Initialize training.
-
For example, run:
python training.py -c .\_config\exp2\naturalistic_unconstrained.yaml
-
Monitor training using tensorboard:
tensorboard --logdir [your output path]\tensorboard
-