Skip to content

Collection of pre-configured conda environments available on the ESI HPC cluster

Notifications You must be signed in to change notification settings

esi-neuroscience/esi-conda

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

55 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Centrally-Managed conda Environments on the ESI HPC Cluster

ESI IT provides a set of pre-configured conda environments for use on the ESI high-performance computing cluster. Every environment is set up and tested on the institute's cluster with the demands of multiple users in mind.

Usage

All environments have been assembled and tested on cluster nodes equipped with Intel Xeon as well as IBM POWER 8 processors running Red Hat Enterprise Linux 8.5 and SLURM 20.11.9

Installation

Setting up an environment requires a recent version of conda (4.4+) shipped with Anaconda or Miniconda, both obtainable from here. Please follow the official documentation to install conda on your system. Once conda is up and running, you may use any of the provided YAML files (see Documentation for details) to set up the corresponding environment on your computer by performing the following steps:

  1. Windows: Open the Anaconda Prompt from the Start menu
    macOS/Linux: open a terminal and add the conda command to your shell, i.e.,
    source /path/to/conda/etc/profile.d/conda.sh (for bash users)
    source /path/to/conda/etc/profile.d/conda.csh (for csh/tcsh users)
  2. Create environment from the corresponding YAML file
    conda env create --file envs/<ARCHITECTURE/><ENVIRONMENT>.yml

All environments starting with esi-2021b support interactive controls for matplotlib figures in Jupyter notebooks. In older environments, this feature can be enabled manually: conda activate esi-2020xy, then install respective JupyterLab extensions: jupyter labextension install @jupyter-widgets/jupyterlab-manager and jupyter labextension install jupyter-matplotlib. The command jupyter labextension list can be used to check if both extensions are "enabled" and "OK".

Testing

The directory tests of this repository contains Python scripts and Jupyter notebooks to test-drive any created environment. Specifically, Jupyter and its interactive widgets tend to warrant a quick trial run:

jupyter lab --ip `hostname` --no-browser --notebook-dir esi-conda/tests/

Trouble-Shooting

All environments have been validated for consistency with respect to dependency resolution. If conda nevertheless complains about conflicting dependencies when trying to install one of our environments, please open an issue in our GitHub issue tracker.

Other than package dependence consistency, interactive figure support in Jupyter notebooks should work out of the box with our recent environments. If it does not, some additional tinkering with setting up JupyterLab extensions and/or npm packages is usually required. Effective trouble-shooting strongly depends on the specific hardware platform (CPU architecture, RAM availability) and the software environment (operating system, conda version, node.js version etc.). However, a boilerplate strategy to debug missing interactive figure widgets ("model not found" or "widget loading..." errors) is to clean up all relevant caches and re-build the JavaScript components of JupyterLab:

jlpm cache clean
jupyter lab clean
jupyter nbextension enable --py widgetsnbextension
jupyter lab build

Many extensions are still under heavy development and might introduce substantial changes between releases. It is usually helpful to consult the GitHub issue trackers of the respective extensions - oftentimes others already ran into similar problems and have already found workarounds.

Documentation

All YAML files with names containing the suffix "_concretized" have been generated by exporting the corresponding environments on the ESI HPC cluster. Thus, <ENVIRONMENT>_concretized.yml files can be used to re-create exact clones of ESI compute cluster environments provided the host system is based on the same architecture (x86 or ppc64le) and is also a Linux machine. To set up an environment on another platform, please use the corresponding <ENVIRONMENT>.yml file instead, as outlined in Installation.

Please refer to the official conda documentation for more details about virtual environment management with conda.

Layout

This repository is structured as follows:

  • envs: contains YAML environment specification files stratified by machine architecture (x86 and ppc)
  • tests: contains scripts and notebooks to test/try-out environments

Available Environments

  • esi-202xa/esi-202xb: standard "reference" Python environment that is updated bi-annually. Comprises most widely used scientific computing packages (NumPy, SciPy, matplotlib, pandas, dask, scikit, mne etc.) in their respective most recent versions. These environments are provided for both x86 and POWER architectures
  • DLC-PPC: environment for running DeepLabCut on POWER based on a custom fork
  • jupyterhub: base environment that is used to launch JupyterHub notebooks on the ESI HPC cluster

About

Collection of pre-configured conda environments available on the ESI HPC cluster

Topics

Resources

Stars

Watchers

Forks