Installation

Available Packages

  • Python Package - available through PyPI

  • Conda Package - available through conda-forge

The following optional libraries are not included is the package:

  • HPC libraries - FFTW, PyAMG, MKL/FFT, and MKL/PARDISO

  • Notebook support - JupyterLab, IPyWidgets, Trame, and ipympl

  • GPU libraries - CuPy and CUDA

Some important remarks about the PyPEEC packages:

  • PyPEEC packages are architecture and system independent.

  • Some dependencies are architecture and system dependent.

  • The optional HPC libraries are usually easier to install through Conda.

  • The Jupyter libraries are usually easier to install through Conda.

Using a Python Environment

# Install a Python interpreter
#   - Website: https://www.python.org/downloads
#   - Supported versions: 3.10, 3.11, 3.12, and 3.13
#   - Python executable: "python" or "python3"

# Create a Python Virtual Environment
python -m venv venv

# Activate the Python Virtual Environment
source venv/bin/activate

# Install PyPEEC from PyPI
python -m pip install pypeec

# Check that PyPEEC is available
pypeec --version

Using a Conda Environment

# Install a Conda distribution
#   - Website: https://conda-forge.org/download
#   - Miniforge is sufficient for installing PyPEEC
#   - Using mamba as a dependency solver is faster

# Create a Conda Environment with a Python interpreter
mamba create -n pypeec python=3.11 pypeec

# Activate the Conda Environment
mamba activate pypeec

# Check that PyPEEC is available
pypeec --version

Using the Docker Image

# A Dockerfile is also available for building an image
#   - Contains an Ubuntu image with PyPEEC and Jupyter
#   - The PyPEEC tutorial and examples are included
#   - The image is only intended for test purposes

# Clone the repository
git clone git@github.com:otvam/pypeec.git

# Build the Docker image
docker build --tag "pypeec:latest" .

# Run the Docker image
docker run -p 8888:8888 \
    "pypeec:latest" "start-notebook.py" \
    --NotebookApp.password="" --NotebookApp.token=""

# Access Jupyter inside the Docker image
xdg-open "http://127.0.0.1:8888/lab/tree/notebook.ipynb"