Skip to content

[Neuron 2024] Analysis of Baoding ball policy from MyoChallenge at NeurIPS 2022

License

Notifications You must be signed in to change notification settings

amathislab/MyoChallengeAnalysis

Repository files navigation

MyoChallenge Analysis Code for Musculoskeletal Skill Acquisition

Overview

This repository contains the analysis code for the second part of our paper Chiappa, A. S.†, Tano, P.†, Patel, N.†, Ingster, A., Pouget, A., & Mathis, A. (2024). Acquiring musculoskeletal skills with curriculum-based reinforcement learning. Neuron. Our work combines musculoskeletal simulation, reinforcement learning, and neuroscience to advance the understanding of biological motor control (EPFL blog, YT Shorts).

The analyses in this repository complement our winning solution for the inaugural NeurIPS MyoChallenge, where we trained a recurrent neural network to control a realistic model of the human hand to rotate two Baoding balls. For the code of the winning solution (PPO-LSTM + SDS curriculum to solve the MyoChallenge), please refer to our separate repository, MyoChallenge.

Getting Started

Installation and Setup

We use Poetry, a modern Python packaging and dependency management tool. If you're unfamiliar with Poetry, here's a quick tutorial.

To set up the project, follow these steps:

  1. Clone the repository:

    # If you have GitHub CLI (gh) installed:
    gh repo clone amathislab/MyoChallengeAnalysis
    
    # Otherwise, use git clone:
    # git clone https://github.com/amathislab/MyoChallengeAnalysis.git
  2. Navigate to the project directory:

    cd MyoChallengeAnalysis
  3. Ensure you're on the main branch:

    git checkout main
    git pull
  4. Install Poetry (if not already installed):

    pip install poetry
  5. Configure Poetry to create the virtual environment within the project:

    poetry config virtualenvs.in-project true
  6. Create the environment and install dependencies:

    poetry install
  7. Activate the virtual environment:

    poetry shell

Reproducing the Figures

  1. Download the Required Data

    • Option 1: Manual Download

      • Access the relevant data for models and rollouts on Zenodo.
      • Download datasets.zip, extract it, and place the folder in the /data directory.
    • Option 2: Automatic Download

      • Run the code in src/download_data.ipynb.
      • This will automatically download and extract the dataset to the correct location.
      • Note: Please be patient, as downloading and extracting ~10GB of data may take some time.
  2. Verify Dataset Folders Ensure you have the following dataset folders:

    • /data/datasets/csi/
    • /data/datasets/rollouts/
    • /data/datasets/umap/
  3. Generate Figures Run the Jupyter notebooks in the src directory:

    • fig_1.ipynb through fig_6.ipynb

Citation

If you use our code or ideas, please cite:

@article{chiappa2024acquiring,
	title = {Acquiring musculoskeletal skills with curriculum-based reinforcement learning},
	journal = {Neuron},
	volume = {112},
	number = {23},
	pages = {3969-3983.e5},
	year = {2024},
	issn = {0896-6273},
	doi = {https://doi.org/10.1016/j.neuron.2024.09.002},
	url = {https://www.sciencedirect.com/science/article/pii/S0896627324006500},
	author = {Alberto Silvio Chiappa and Pablo Tano and Nisheet Patel and Abigaïl Ingster and Alexandre Pouget and Alexander Mathis},
	keywords = {motor control, motor learning, reinforcement learning, curriculum learning, motor skills, musculoskeletal control, muscle synergies},
}

Acknowledgments & funding: We thank members of the Mathis Group for helpful feedback. A.M. is appreciative to the Kavli Institute for Theoretical Physics (KITP) in Santa Barbara, where part of the manuscript was written. AM thanks Nicola Hodges and John Krakauer for discussions on skill learning. A.C. and A.M. are funded by Swiss SNF grant (310030_212516). A.I. acknowledges EPFL's Summer in the Lab fellowship to join the Mathis Group. A.M. was supported in part by grants NSF PHY-1748958 and PHY-2309135 to the KITP. P.T. and N.P. were supported by University of Geneva internal funding.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Contact

For questions, collaborations, or any issues related to this project, we encourage you to:

  1. Open an issue in this GitHub repository for bug reports, feature requests, or general questions.
  2. Submit a pull request if you have a contribution you'd like to make.
  3. For other inquiries or potential collaborations, please reach out to any of the authors through their institutional contact information.

We appreciate your interest in our work and look forward to your feedback and potential contributions!