Helix/bwVisu/JupyterLab: Difference between revisions
| H Schumacher (talk | contribs)  (created page) | H Schumacher (talk | contribs)  m (fixed formatting, added link to VSCode page) | ||
| Line 71: | Line 71: | ||
| <li>Start kernel 'R 4.2' as console or notebook</li> | <li>Start kernel 'R 4.2' as console or notebook</li> | ||
| </ol> | </ol> | ||
| ⚫ | |||
| === Interactive Widgets === | === Interactive Widgets === | ||
| Line 84: | Line 84: | ||
| == FAQ == | == FAQ == | ||
| ⚫ | |||
| <ol style="list-style-type: decimal;"> | |||
| Request more memory when starting Jupyter.</li> | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| <p>A: Request more memory when starting Jupyter. In the job settings open 'Cluster Settings' and look for the option 'Memory / node'.</p></li> | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| </ol> | |||
| ⚫ | |||
| ⚫ | |||
| ⚫ | |||
| <ul> | |||
| <li>normal Slurm job with a Jupyter instance (jupyter lab --no-browser --ip=0.0.0.0 --port=somenumber) and connect to that? That way, you could also automate most of the process instead of having to log in to a web page.</li></ul> | |||
| ⚫ | |||
Revision as of 16:56, 27 March 2025
JupyterLab is an integrated development environment (IDE) that provides a flexible and scalable interface for the Jupyter Notebook system. It supports interactive data science and scientific computing across over 40 programming languages (including Python, Julia, and R).
Python version
You can see the default python version by running python --version
- Activate the Miniconda module
- Create a virtual environment with a custom python version via conda:
conda create --name <myenv> python=<python version> 
- Install the ipykernel package:
conda install ipykernel 
- Register your virtual environment as custom kernel to Jupyter:
python3 -m ipykernel install --user --name=<myKernel> 
- Select your newly created kernel in Jupyter
Python packages
Add packages via venv virtual environments
- Open a terminal and type:
python3 -m venv <myEnv> 
- Activate your environment:
source <myEnv>/bin/activate 
- Install your packages:
pip install -U pip pip install <mypackage> 
- Install the ipykernel package:
pip install ipykernel 
- Register your virtual environment as custom kernel to Jupyter:
python3 -m ipykernel install --user --name=<myKernel> 
Add packages via miniconda
- Load the miniconda module by clicking first on the blue hexagon icon on the left-hand side of Jupyter's start page and then on the "load" Button right of the entry for miniconda in the software module menu. 
Open a terminal and complete the miniconda setup with:
source $MINICONDA_HOME/etc/profile.d/conda.sh 
- Open a terminal and create a conda environment:
conda create --name <myenv> 
- Activate your environment:
conda activate <myenv> 
- Install your packages:
conda install <mypackage> 
- Install the ipykernel package:
conda install ipykernel 
- Register your virtual environment as custom kernel to Jupyter:
python3 -m ipykernel install --user --name=<myKernel> 
Multi-Language Support
JupyterLab supports over 40 programming languages including Python, R, Julia, and Scala. This is achieved through the use of different kernels, which are implementations of the Jupyter notebook environment for each language. You can switch between kernels easily, allowing you to use the best tool for a specific task.
Example of switching kernels in a notebook:
- On the cluster:
$ module load math/R $ R > install.packages('IRkernel')
- On bwVisu:
- Start Jupyter App
- In left menu: load math/R
- Open Console:
- Start kernel 'R 4.2' as console or notebook
 $ R > IRkernel::installspec(displayname = 'R 4.2') 
Interactive Widgets
JupyterLab supports interactive widgets that can create UI controls for interactive data visualization and manipulation within the notebooks. Example of using an interactive widget:
from ipywidgets import IntSlider slider = IntSlider() display(slider)
These widgets can be sliders, dropdowns, buttons, etc., which can be connected to Python code running in the backend.
FAQ
- My conda commands are interrupted with message 'Killed'.
 Request more memory when starting Jupyter.
- How can I navigate to my SDS@hd folder in the file browser?
 Open a terminal and set a symbolic link to your SDS@hd folder in your home directory. For example:
- Jupyterlab doesn't let me in but asks for a password.
 Try using more memory for the job. If this doesn't help, try using the inkognito mode of your browser as the browser cache might be the problem.
- I prefer VSCode over JupyterLab. Can I start a JupyterLab job and then connect with it via VSCode?
 This is possible but, if you are a bwForCluster Helix user as well, it is not recommended as it wastes bwVisu resources. Please start the job directly on Helix instead. You can find the instructions at the VSCode page.
cd $HOME mkdir sds-hd cd sds-hd ln -s /mnt/sds-hd/sd16a001 sd16a001