Skip to content

Latest commit

 

History

History
171 lines (108 loc) · 12.1 KB

README.md

File metadata and controls

171 lines (108 loc) · 12.1 KB

Workshops Cambridge - 2020

Binder GitHub size Docker Hub GitHub HitCount

This repository contains everything you'll need for the pybrain workshop "MRI analysis in Python using Nipype, Nilearn and more" in Cambridge 2020, 9th to 10th of November.

Schedule

Registration for this workshop can be done via pybrain-workshop.github.io (Update: Course is unfortunately already fully booked!)

This 2-day workshop runs from 09:30 to 15:30 on both days. Lunch breaks are scheduled from 12:00 to 13:00. Individual short breaks can be taken during the multiple independent excersie sessesion throughout the workshop.

The scheudle might still be subject to some small changes, but the bigger picture looks as follows.

9th November

  • 09:30-10:00 - Workshop overview
  • 10:00-10:45 - Quick recap on Jupyter, Python and more*
  • 10:45-12:00 - Explore MRI data with Nibabel and Nilearn
  • 12:00-13:00 - Lunch
  • 13:00-13:30 - How to set up your system, using Conda and Docker
  • 13:30-15:00 - Functional connectivity and machine learning
  • 15:00-15:30 - Innovations in neuroimaging tools (Part I)
  • 15:30-... - Open ended for questions

10th November

  • 09:30-10:00 - Introduction to Nipype
  • 10:00-11:00 - Exploration of Nipype's building blocks
  • 11:00-12:00 - Creating a Nipype Pipeline from A-Z
  • 12:00-13:00 - Lunch
  • 13:00-14:00 - PyBIDS and Nistats
  • 14:00-15:00 - Multivariate pattern analysis using Searchlight and Deep Learning
  • 15:00-15:30 - Innovations in neuroimaging tools (Part 2)
  • 15:30-... - Open ended for questions

Accessing workshop content (interactively or static)

There are four ways how you can profit from this workshop:

  1. Via Docker (recommened): Full workshop experience, interactive, with all software dependencies.
  2. Via Conda (Python): Almost full workshop experience, interactive, with only Python based software dependencies (i.e. no support for FSL, SPM or ANTs)
  3. Via Mybinder: Full workshop experience, interactive and online, with restricted computational power.
  4. Via Jupyter NBViewer: Only visual exploration of the workshop content, no interactive aspect.

1. Docker (recommended): Fully interactive

If you want the full experience, chose this option. This is also the one you should use if you participate in the November 2020 workshop. The only thing you'll need to install for this workshop is Docker Desktop (for more detailed instructions, see here Mac, Windows and Linux).

Once Docker Desktop is set up, open a (docker) terminal and run the following command to verify if everything is good to go:

docker run hello-world

Download workshop content

Now, the only thing that's still missing is the actual workshop content. Do get this, use again a (docker) terminal and run the following command

docker pull miykael/workshop_pybrain

Given that the whole workshop content is more than 8GB in size, the download of this container image might take a while.

Access workshop content via Jupyter Notebooks

Once the container is pulled and on your system, you're all good to go. To access the workshop and open the Jupyter Notebook environment, please follow these steps:

  1. Open a (docker) terminal and run the following command:

     docker run -p 8888:8888 -it --rm miykael/workshop_pybrain
    
  2. Open http://127.0.0.1:8888/?token=pybrain or http://localhost:8888/?token=pybrain in your web browser to access the workshop content.

  3. Once Jupyter Notebook is open, double click on the Jupyter Notebook called program.ipynb - et voilà.

Note: Should you by any chance encounter the following "Password or token" needed message, use the token pybrain to login.

Important notes

Don't loose your progress/notes

Everything you do within this docker container will be reset the moment you terminate the docker run ... command in step one (or you close this terminal). This means, any output file created within the docker container will be deleted. Similarly, any notes and changes within the notebooks will be lost. To prevent this from happening, either (1) manually download the changed notebooks (i.e. File > Download As > Notebook (.ipynb)) or (2) create a common folder within the container and on your system and allow a direct transition of data by adding the -v flag to the docker run ... command.

For example, something like docker run -p 8888:8888 -it --rm -v /path/to/your/output_folder:/output miykael/workshop_pybrain, where /path/to/your/output_folder should be an empty folder on your system, such as /User/neuro/Desktop/output.

Here's a more detailed explanation of this full command:

docker run \                    #  start up a container already built or pulled
    -p 8888:8888  \             #  port used, <local port>:<container port>
    -it  \                      #  run Docker interactively
    --rm  \                     #  remove the container when it exits
    -v ~/local_folder:/output   #  use local files <local path>:<container path>
    miykael/workshop_pybrain    #  use specified user/project:version container

Note: The path to the folder /path/to/your/output_folder needs to be an absolut path (i.e. it cannot be relate). So if you're corrently in the folder /User/neuro/Desktop/workshop/ and want to give access to a subfolder called results. You cannot use -v results:/output or -v ./results:/output. You either need to use -v /User/neuro/Desktop/workshop/results:/output or -v ~/Desktop/workshop/results:/output.

Memory issues during workshop

It is possible that you might run into some MemoryError messages during the workshop, or that you don't have enough CPUs for parallel process. This has most likely nothing to do with your system, and probably is due to Docker Desktop and it's resource management. By default, Docker Desktop only uses 2 CPUs and 2 GB of RAM. You can change this default setting by opening Docker Desktop, go to Settings/Preferences > Resources. For a more detailed description see here for Mac and for Windows.

Docker is messy, clean up space afterwards

Docker is a great tool to quickly provide a out-of-the-box running computer environment. However, if you're not carefull, it can quickly create a lot of unwanted files on your machine. To better understand these footprints and to clean out unwanted files after the workshop, please concider the following commands (run from within a (docker) terminal).

# Show all installed Docker images
docker images

# Remove a docker image
docker rmi -f $IMAGE_ID

# Remove all unused docker objects
docker system prune

# Remove everything (including images you might still need)
docker system prune -a

And should you chose to remove the --rm string in the docker run ... command, you can use the following commands to explore which containers are still open and potentially can be accessed once more (with their changes and additional outputs still present). Our advice is against such an approach as it can clutter your machine even quicker.

# Show running containers
docker ps

# Show all (also stopped) containers
docker ps -a

# Start a stopped container & attach to it
docker start -ia $CONTAINER_ID

# Remove a container
docker rm $CONTAINER_ID

2. Conda (Python): Almost fully interactive (Python only)

If you want to do the workshop without installing heavy neuroimaing software packages, such as FSL, SPM12 or ANTs and don't want to install Docker on your system, than you might be interested in this approach. By installing Python on your system (i.e. specifically Conda) and setting up the appropriate environment, you will be able to open all the Jupyter Notebooks and go through the whole content of the course. Except for the notebooks which depend on the heavy neuroimaing software packages, you should be able to run everything locally.

To get things up and running, please follow these steps:

  1. Download and install either miniconda or Anaconda with a Python version of at least 3.6
  2. Download the environment.yml file (e.g. with right mouse click -> Save As). Make sure that the file ends with .yml and not .txt.
  3. Open up a conda terminal (or any other terminal), and create a new conda environment with the following command: conda env create -f /path/to/file/environment.yml - For example ``conda env create -f ~/Downloads/environment.yml`
  4. Download the notebooks in this repository via this link) and unzip them to your prefered location, e.g. Desktop/pybrain.h
  5. Download the three datasets adhd, ds000114 and ds000228 and put them into the workshop folder as well, e.g. at Desktop/pybrain/adhd and Desktop/pybrain/ds000114.
  6. Next, open up a conda terminal (or any other terminal), activate the conda environment with conda activate pybrain (or on older conda environments with source activate pybrain for mac and linux and activate pybrain for windows).
  7. Finally, via the terminal, move to the folder where you've put all the unzipped content of this workshop, e.g. with the command cd ~/Desktop/pybrain and run the command jupyter notebook from the folder that contains the program.ipynb notebook.

Note: This only provides you the notebooks from the workshop that are not already in the nipype_tutorial. You can download the notebooks for the Nipype section of this workshop directly from here.

3. Mybinder (online): Fully interactive with restricted computational power

Binder

MyBinder.org is a great service that allows you to run Jupyter notebooks in a Docker or Python environment, directly online and for free. However, this service comes of course with a restricted computational environment (1-2GB of RAM). This means, many notebooks might be very slow and some might even crash, due to not enough memory.

You can use this approach to run and test most of the notebooks and to explore the slides. To access the MyBinder instance, use this link.

4. Jupyter NBViewer: Visual inspection only

If you want to go through the content of this workshop without installing anything on your machine, you should chose this approach. To see all the notebooks and slides from this workshop, please use this Jupyter NBviewer link.

Note: For the non-interactive version of the Nipype section of this workshop, please us this link.