Documentation | Paper | Discussion Board
This repository contains the source code for FlyGym, the Python library for NeuroMechFly v2, a digital twin of the adult fruit fly Drosophila melanogaster that can see, smell, walk over challenging terrain, and interact with the environment (see our NeuroMechFly v2 paper).
NeuroMechFly consists of the following components:
NeuroMechFly formulates the control of the simulated fly as a partially observable Markov Decision Process (MDP) and implements the Gym interface. This allows the user to use a wide range of reinforcement learning algorithms to train the fly to perform tasks. The standardized interface also allows the user to easily implement their own premotor computation and/or sensory preprocessing processes.
This package is developed at the Neuroengineering Laboratory, EPFL.
In brief:
pip install "flygym"
# or pip install "flygym[examples]" to install additional dependencies needed for examples
Alternatively, we provide a Docker image. See our website for details, especially if you plan to install FlyGym in the developer mode (i.e. if you plan to make changes to the code). Dependencies are specified in setup.py
and will be installed automatically upon installation using pip. Installation should take no more than a few minutes. The PyPI version of the current release of FlyGym is indicated on the shield at the top of this page. No special, paid software is required to use FlyGym.
See our website for tutorials, including expected outputs. For code blocks that take more than a few seconds to run, the running time (on a 2020 MacBook Pro with M1 processor running macOS 13.5.2) is indicated, typically in the form of a progress bar.
We are constantly working on expanding the package and improving its usability; therefore the package is subject to change. To reproduce the exact results demonstrated in our preprint, use FlyGym 0.1.0 and analysis code here.
If you use NeuroMechFly in your work, please cite the following papers:
@article{WangChen2023,
author = {Sibo Wang-Chen and Victor Alfred Stimpfling and Pembe Gizem \"{O}zdil and Louise Genoud and Femke Hurtak and Pavan Ramdya},
title = {NeuroMechFly 2.0, a framework for simulating embodied sensorimotor control in adult Drosophila},
year = {2023},
doi = {10.1101/2023.09.18.556649},
URL = {https://www.biorxiv.org/content/early/2023/09/18/2023.09.18.556649},
journal = {bioRxiv}
}
@article{LobatoRios2022,
doi = {10.1038/s41592-022-01466-7},
url = {https://doi.org/10.1038/s41592-022-01466-7},
year = {2022},
month = may,
volume = {19},
number = {5},
pages = {620--627},
author = {Victor Lobato-Rios and Shravan Tata Ramalingasetty and Pembe Gizem \"{O}zdil and Jonathan Arreguit and Auke Jan Ijspeert and Pavan Ramdya},
title = {{NeuroMechFly}, a neuromechanical model of adult {Drosophila} melanogaster},
journal = {Nature Methods}
}