Summary day 2
Keypoints
- Load and run and pre-installed packages
Use python from module system
Start a Python shell session either with
pythonoripythonrun scripts with
python3 <script.py>- Check for preinstalled packages
from the Python shell with the
importcommand- from BASH shell with the
pip listcommand at both centersml help python/3.11.8at UPPMAXmodule -r spider '.*Python.*'at otherwise
- Install packages and use isolated environments
With a virtual environment you can tailor an environment with specific versions for Python and packages, not interfering with other installed python versions and packages.
Make it for each project you have for reproducibility.
- There are different tools to create virtual environemnts.
virtualenvandvenvinstall packages with
pip.the flag
--system-site-packagesincludes preinstalled packages as well
- Conda (available everywhere but not HPC2N)
- Conda is an installer of packages but also bigger toolkits
Conda creates isolated environments as well
requires that you install all packages needed.
Rackham: Pip or secondary conda
Bianca: conda and secondary wharf + (pip or conda)
- Interactive work on calculation nodes
- Start an interactive session on a calculation node by a SLURM allocation (similar flags)
At HPC2N:
salloc…At UPPMAX/NSC:
interactive…At LUNARC: Desktop on demand
Follow the same procedure as usual by loading the Python module and possible prerequisites.
- IDEs
- Jupyter-lab/notebook
Available in all clusters
- Spyder
Best available at LUNARC
Possible at the others through virtual environments (pip) or Conda (not HPC2N)
VScode: perhaps shown tomorrow
- Matplotlib
Matplotlib is the essential Python data visualization package, with nearly 40 different plot types to choose from depending on the shape of your data and which qualities you want to highlight.
Almost every plot will start by instantiating the figure,
fig(the blank canvas), and 1 or moreaxesobjects,ax, withfig, ax = plt.subplots(*args, **kwargs).Most of the plotting and formatting commands you will use are methods of Axes objects, but a few, like colorbar are methods of the Figure, and some commands are methods both.