Skip to main content

Implementation of NeuroMechFly v2, a framework for simulating embodied sensorimotor control in adult Drosophila.

Project description




[!CAUTION] A newer FlyGym API is available: see neuromechfly.org for more information.

This repository is a fork of the legacy API. New users should first check out the version above.




Simulating embodied sensorimotor control with NeuroMechFly v2

Documentation | Paper | Discussion Board

Python: 3.9–3.12 License: MPL 2.0 PyPI version Repo Size

Docker Docker image size

overview_video

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:

  • Biomechanical model: The biomechanical model is based on a micro-CT scan of a real adult female fly (see our original NeuroMechFly publication). We have adjusted several body segments (in particular in the antennae) to better reflect the biological reality.
  • Vision: The fly has compound eyes consisting of individual units called ommatidia arranged on a hexagonal lattice. We have simulated the visual inputs on the fly’s retinas.
  • Olfaction: The fly has odor receptors in the antennae and the maxillary palps. We have simulated the odor inputs experienced by the fly by computing the odor/chemical intensity at these locations.
  • Hierarchical control: The fly’s Central Nervous System consists of the brain and the Ventral Nerve Cord (VNC), a hierarchy analogous to our brain-spinal cord organization. The user can build a two-part model — one handling brain-level sensory integration and decision making and one handling VNC-level motor control — with an interface between the two consisting of descending (brain-to-VNC) and ascending (VNC-to-brain) representations.
  • Leg adhesion: Insects have evolved specialized adhesive structures at the tips of the legs that enable locomotion vertical walls and overhanging ceilings. We have simulated these structures in our model. The mechanism by which the fly lifts the legs during locomotion despite adhesive forces is not well understood; to abstract this, adhesion can be turned on/off during leg stance/swing.
  • Mechanosensory feedback: The user has access to the joint angles, forces, and contact forces experienced by the fly.

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.

Installation and dependencies

In brief:

pip install "flygym_gymnasium"
# 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 pyproject.toml 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.

[!NOTE] For Intel-chip Macs with older macOS versions: FlyGym v1.2.0 was the last version to officially support macOS 13, but you can get newer versions to work by downgrading your numpy version pip install "numpy<2" after installing FlyGym.

Demos

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.

Reproducing results in the paper

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.

Citation

If you use NeuroMechFly in your work, please cite the following papers: {% raw %}

@article{WangChen2024,
  title = {{NeuroMechFly v2}: simulating embodied sensorimotor control in adult Drosophila},
  volume = {21},
  ISSN = {1548-7105},
  url = {http://dx.doi.org/10.1038/s41592-024-02497-y},
  DOI = {10.1038/s41592-024-02497-y},
  number = {12},
  journal = {Nature Methods},
  publisher = {Springer Science and Business Media LLC},
  author = {Wang-Chen,  Sibo and Stimpfling,  Victor Alfred and Lam,  Thomas Ka Chung and \"{O}zdil,  Pembe Gizem and Genoud,  Louise and Hurtak,  Femke and Ramdya,  Pavan},
  year = {2024},
  month = nov,
  pages = {2353–2362}
}

@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}
}

{% endraw %}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flygym_gymnasium-1.3.0.tar.gz (23.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flygym_gymnasium-1.3.0-py3-none-any.whl (23.4 MB view details)

Uploaded Python 3

File details

Details for the file flygym_gymnasium-1.3.0.tar.gz.

File metadata

  • Download URL: flygym_gymnasium-1.3.0.tar.gz
  • Upload date:
  • Size: 23.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for flygym_gymnasium-1.3.0.tar.gz
Algorithm Hash digest
SHA256 f69baf4f08dc00195b869208d105edb1afb069ad1e8c3aa06fd773ca3a1dee63
MD5 c373ba24b6a0fac96ed6d40428c5c35e
BLAKE2b-256 ed48c4e0a9e03a7ec78b52f9779703004674ec446495e8ee8eb03ec4dc4a2e6f

See more details on using hashes here.

File details

Details for the file flygym_gymnasium-1.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for flygym_gymnasium-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2a7cccffecf1082a077da63d6655bbd3d13c3ae8fb735843318e6c15773447d1
MD5 7ff120cbe388bc0e26cd3cb20dd489d2
BLAKE2b-256 b3d5c1b475c38cfccfd517902185d538b1a513511ec3087474f4d9b108fe025a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page