Spack verwenden

Auflisten der verfügbaren Pakete

$ spack list
==> 3247 packages.
abinit                                 py-fiona
abyss                                  py-fiscalyear

oder zum filtern nach bestimmten Paketen, z.B.

$ spack list numpy
==> 2 packages.
py-numpy  py-numpydoc

Auflisten der installierten Pakete

$ spack find
==> 17 installed packages
-- darwin-mojave-x86_64 / clang@10.0.1-apple --------------------
bzip2@1.0.8    libffi@3.2.1    perl@5.26.2           python@3.7.4   zlib@1.2.11
diffutils@3.7  ncurses@6.1     pkgconf@1.6.1         readline@7.0
expat@2.2.5    openblas@0.3.6  py-numpy@1.16.4       sqlite@3.28.0
gdbm@1.18.1    openssl@1.1.1b  py-setuptools@41.0.1  xz@5.2.4

spack info

$ spack info py-numpy
PythonPackage:   py-numpy

Description:
    NumPy is the fundamental package for scientific computing with Python.
    It contains among other things: a powerful N-dimensional array object,
    sophisticated (broadcasting) functions, tools for integrating C/C++ and
    Fortran code, and useful linear algebra, Fourier transform, and random
    number capabilities

Homepage: http://www.numpy.org/

Tags:
    None

Preferred version:
    1.16.4    https://pypi.io/packages/source/n/numpy/numpy-1.16.4.zip

Safe versions:
    1.16.4    https://pypi.io/packages/source/n/numpy/numpy-1.16.4.zip
    1.16.3    https://pypi.io/packages/source/n/numpy/numpy-1.16.3.zip
    1.16.2    https://pypi.io/packages/source/n/numpy/numpy-1.16.2.zip
    1.16.1    https://pypi.io/packages/source/n/numpy/numpy-1.16.1.zip
    1.16.0    https://pypi.io/packages/source/n/numpy/numpy-1.16.0.zip
    1.15.4    https://pypi.io/packages/source/n/numpy/numpy-1.15.4.zip
    1.15.3    https://pypi.io/packages/source/n/numpy/numpy-1.15.3.zip
    1.15.2    https://pypi.io/packages/source/n/numpy/numpy-1.15.2.zip
    1.15.1    https://pypi.io/packages/source/n/numpy/numpy-1.15.1.zip
    1.15.0    https://pypi.io/packages/source/n/numpy/numpy-1.15.0.zip
    1.14.6    https://pypi.io/packages/source/n/numpy/numpy-1.14.6.zip
    1.14.5    https://pypi.io/packages/source/n/numpy/numpy-1.14.5.zip
    1.14.4    https://pypi.io/packages/source/n/numpy/numpy-1.14.4.zip
    1.14.3    https://pypi.io/packages/source/n/numpy/numpy-1.14.3.zip
    1.14.2    https://pypi.io/packages/source/n/numpy/numpy-1.14.2.zip
    1.14.1    https://pypi.io/packages/source/n/numpy/numpy-1.14.1.zip
    1.14.0    https://pypi.io/packages/source/n/numpy/numpy-1.14.0.zip
    1.13.3    https://pypi.io/packages/source/n/numpy/numpy-1.13.3.zip
    1.13.1    https://pypi.io/packages/source/n/numpy/numpy-1.13.1.zip
    1.13.0    https://pypi.io/packages/source/n/numpy/numpy-1.13.0.zip
    1.12.1    https://pypi.io/packages/source/n/numpy/numpy-1.12.1.zip
    1.12.0    https://pypi.io/packages/source/n/numpy/numpy-1.12.0.zip
    1.11.3    https://pypi.io/packages/source/n/numpy/numpy-1.11.3.zip
    1.11.2    https://pypi.io/packages/source/n/numpy/numpy-1.11.2.zip
    1.11.1    https://pypi.io/packages/source/n/numpy/numpy-1.11.1.zip
    1.11.0    https://pypi.io/packages/source/n/numpy/numpy-1.11.0.zip
    1.10.4    https://pypi.io/packages/source/n/numpy/numpy-1.10.4.zip
    1.9.3     https://pypi.io/packages/source/n/numpy/numpy-1.9.3.zip
    1.9.2     https://pypi.io/packages/source/n/numpy/numpy-1.9.2.zip
    1.9.1     https://pypi.io/packages/source/n/numpy/numpy-1.9.1.zip

Variants:
    Name [Default]    Allowed values    Description


    blas [on]         True, False       Build with BLAS support
    lapack [on]       True, False       Build with LAPACK support

Installation Phases:
    build    install

Build Dependencies:
    blas  lapack  py-setuptools  python

Link Dependencies:
    blas  lapack  python

Run Dependencies:
    python

Virtual Packages:
    None

spack version

spack version zeigt die verfügbaren Versionen an, z.B.

$ spack versions python
==> Safe versions (already checksummed):
  3.7.4  3.7.0  3.6.5  3.6.1  3.5.1   3.3.6   2.7.15  2.7.11
  3.7.3  3.6.8  3.6.4  3.6.0  3.5.0   3.2.6   2.7.14  2.7.10
  3.7.2  3.6.7  3.6.3  3.5.7  3.4.10  3.1.5   2.7.13  2.7.9
  3.7.1  3.6.6  3.6.2  3.5.2  3.4.3   2.7.16  2.7.12  2.7.8
==> Remote versions (not yet checksummed):
  3.8.0b2   3.6.9     3.5.7rc1  3.5.0a2    3.4.0     3.1.2      2.7    2.4.3
  3.8.0b1   3.6.8rc1  3.5.6rc1  3.5.0a1    3.3.7rc1  3.1.1      2.6.9  2.4.2

Installation bestimmter Pakete

z.B.

$ spack install python@3.7.4

oder um py-numpy für Python 3.7.4 zu installieren:

$ spack install py-numpy ^python@3.7.4

Anschließend kann die Installation überprüft werden mit

$ spack find --deps py-numpy
==> 1 installed package
-- darwin-mojave-x86_64 / clang@10.0.1-apple --------------------
    py-numpy@1.16.4
        ^openblas@0.3.6
        ^python@3.7.4
            ^bzip2@1.0.8
            ^expat@2.2.5
            ^gdbm@1.18.1
                ^readline@7.0
                    ^ncurses@6.1
            ^libffi@3.2.1
            ^openssl@1.1.1b
                ^zlib@1.2.11
            ^sqlite@3.28.0
            ^xz@5.2.4

Deinstallieren

$ spack uninstall py-numpy

oder

$ spack uninstall --dependents py-numpy

Extensions und Python-Support

Das Installationsmodell von Spack geht davon aus, dass jedes Paket in einem eigenen Installations-Präfix lebt. Module in interpretierten Sprachen wie Python werden typischerweise im $prefix/lib/python-3.7/site-packages/ installiert, also z.B. /Users/veit/spack/opt/spack/darwin-mojave-x86_64/clang-10.0.1-apple/py-numpy-1.16.4-45sqnufha2yprpx6rxyelsokky65ucdy/lib/python3.7/site-packages/numpy. Es können jedoch auch Pakete verwendet werden, die in einem anderen Präfix installiert wurden. In Spack wird ein solches Paket als Extension bezeichnet.

Angenommen, Python wurde installiert mit

$ spack find python
==> 1 installed package
-- darwin-mojave-x86_64 / clang@10.0.1-apple --------------------
python@3.7.4

so können Extensions gefunden werden mit

$ spack extensions python
==> python@3.7.4%clang@10.0.1-apple+bz2+ctypes+dbm+lzma~nis~optimizations patches=210df3f28cde02a8135b58cc4168e70ab91dbf9097359d05938f1e2843875e57 +pic+pyexpat+pythoncmd+readline~shared+sqlite3+ssl~tix~tkinter~ucs4~uuid+zlib arch=darwin-mojave-x86_64/jqlxzxp
==> 623 extensions:
adios2                                 py-munch
antlr                                  py-mx


==> 2 installed:
-- darwin-mojave-x86_64 / clang@10.0.1-apple --------------------
py-numpy@1.16.4  py-setuptools@41.0.1

==> None activated.

numpy kann dem PYTHONPATH der aktuellen Shell hinzugefügt werden mit load:

$ spack load python
$ spack load py-numpy
$ python
Python 3.7.4 (default, Jul 28 2019, 20:00:06)
[Clang 10.0.1 (clang-1001.0.46.4)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import numpy
>>>

Oft sollen jedoch bestimmte Pakete dauerhaft einer Python-Installation zur Verfügung stehen. Spack bietet hierfür activate an:

$ spack activate py-numpy
==> Activating extension py-numpy@1.16.4%clang@10.0.1-apple+blas+lapack arch=darwin-mojave-x86_64/45sqnuf for python@3.7.4%clang@10.0.1-apple+bz2+ctypes+dbm+lzma~nis~optimizations patches=210df3f28cde02a8135b58cc4168e70ab91dbf9097359d05938f1e2843875e57 +pic+pyexpat+pythoncmd+readline~shared+sqlite3+ssl~tix~tkinter~ucs4~uuid+zlib arch=darwin-mojave-x86_64/jqlxzxp