Metadata-Version: 2.4
Name: fenics-dolfinx
Version: 0.11.0.post0
Summary: DOLFINx Python interface
Author: FEniCS Steering Council
Author-Email: Unknown <fenics-steering-council@googlegroups.com>
License-Expression: LGPL-3.0-or-later
License-File: COPYING
License-File: COPYING.LESSER
Requires-Python: >=3.11
Requires-Dist: numpy>=2
Requires-Dist: cffi
Requires-Dist: nanobind
Requires-Dist: mpi4py
Requires-Dist: fenics-basix<0.12.0,>=0.11.0
Requires-Dist: fenics-ffcx<0.12.0,>=0.11.0
Requires-Dist: fenics-ufl<2026.2.0,>=2026.1.0
Provides-Extra: demo
Requires-Dist: gmsh; extra == "demo"
Requires-Dist: networkx; extra == "demo"
Requires-Dist: numba; extra == "demo"
Requires-Dist: matplotlib; extra == "demo"
Requires-Dist: scipy; extra == "demo"
Requires-Dist: pyvista; extra == "demo"
Provides-Extra: docs
Requires-Dist: breathe; extra == "docs"
Requires-Dist: jupytext; extra == "docs"
Requires-Dist: markdown; extra == "docs"
Requires-Dist: myst_parser; extra == "docs"
Requires-Dist: packaging; extra == "docs"
Requires-Dist: pyyaml; extra == "docs"
Requires-Dist: sphinx; extra == "docs"
Requires-Dist: pydata-sphinx-theme; extra == "docs"
Requires-Dist: sphinx_codeautolink[ipython]; extra == "docs"
Requires-Dist: sphinxcontrib-bibtex; extra == "docs"
Requires-Dist: fenics-dolfinx[demo]; extra == "docs"
Provides-Extra: lint
Requires-Dist: ruff; extra == "lint"
Provides-Extra: mypy
Requires-Dist: mypy; extra == "mypy"
Requires-Dist: types-cffi; extra == "mypy"
Requires-Dist: types-setuptools; extra == "mypy"
Requires-Dist: scipy-stubs; extra == "mypy"
Provides-Extra: optional
Requires-Dist: numba; extra == "optional"
Provides-Extra: petsc4py
Requires-Dist: petsc4py; extra == "petsc4py"
Provides-Extra: test
Requires-Dist: matplotlib; extra == "test"
Requires-Dist: networkx; extra == "test"
Requires-Dist: packaging; extra == "test"
Requires-Dist: pytest>=9.0.0; extra == "test"
Requires-Dist: scipy; extra == "test"
Requires-Dist: fenics-dolfinx[optional]; extra == "test"
Provides-Extra: ci
Requires-Dist: pytest-xdist; extra == "ci"
Requires-Dist: fenics-dolfinx[build]; extra == "ci"
Requires-Dist: fenics-dolfinx[docs]; extra == "ci"
Requires-Dist: fenics-dolfinx[lint]; extra == "ci"
Requires-Dist: fenics-dolfinx[mypy]; extra == "ci"
Requires-Dist: fenics-dolfinx[optional]; extra == "ci"
Requires-Dist: fenics-dolfinx[test]; extra == "ci"
Description-Content-Type: text/markdown

# DOLFINx

[![DOLFINx CI](https://github.com/FEniCS/dolfinx/actions/workflows/ccpp.yml/badge.svg)](https://github.com/FEniCS/dolfinx/actions/workflows/ccpp.yml)
[![Actions Spack build](https://github.com/FEniCS/dolfinx/actions/workflows/spack.yml/badge.svg)](https://github.com/FEniCS/dolfinx/actions/workflows/spack.yml)
[![Actions Conda install](https://github.com/FEniCS/dolfinx/actions/workflows/conda.yml/badge.svg)](https://github.com/FEniCS/dolfinx/actions/workflows/conda.yml)
[![Actions macOS/Homebrew install](https://github.com/FEniCS/dolfinx/actions/workflows/macos.yml/badge.svg)](https://github.com/FEniCS/dolfinx/actions/workflows/macos.yml)
[![Actions Docker images](https://github.com/FEniCS/dolfinx/actions/workflows/docker-end-user.yml/badge.svg)](https://github.com/FEniCS/dolfinx/actions/workflows/docker-end-user.yml)
[![Actions Windows/vcpkg install](https://github.com/FEniCS/dolfinx/actions/workflows/windows.yml/badge.svg)](https://github.com/FEniCS/dolfinx/actions/workflows/windows.yml)

DOLFINx is the computational environment of
[FEniCSx](https://fenicsproject.org) and implements the FEniCS Problem
Solving Environment in C++ and Python. DOLFINx is a new version of
DOLFIN and is actively developed.

For questions about using DOLFINx, visit the [FEniCS
Discourse](https://fenicsproject.discourse.group/) page or use the
[FEniCS Slack channel](https://fenicsproject.slack.com/) (use
[this](https://join.slack.com/t/fenicsproject/shared_invite/zt-1lraknsp1-6_3Js5kueDIyWgF192d3nA)
link to sign up to the Slack channel).

## Documentation

Documentation can be viewed [here](https://docs.fenicsproject.org).

## Installation

### From source

For detailed instructions and a list of dependencies, see
[here](https://docs.fenicsproject.org/dolfinx/main/python/installation).

#### C++ core

To build and install the C++ core, in the `cpp/` directory, run:

```shell
mkdir build
cd build
cmake ..
make install
```

#### Python interface

To install the Python interface, first install the C++ core, and then in
the `python/` directory run:

```shell
pip install scikit-build-core
python -m scikit_build_core.build requires | python -c "import sys, json; print(' '.join(json.load(sys.stdin)))" | xargs pip install
pip install --check-build-dependencies --no-build-isolation .
```

### Spack

To build the most recent release using
[Spack](https://spack.readthedocs.io/) (assuming a bash-compatible
shell):

```shell
git clone https://github.com/spack/spack.git
. ./spack/share/spack/setup-env.sh
spack env create fenicsx-env
spack env activate fenicsx-env
spack install --add py-fenics-dolfinx+petsc4py+slepc4py
```

Spack is the recommended approach for HPC systems.

Although Spack already contains FEniCS Project packages, we also maintain a
separate [overlay package repository](https://github.com/FEniCS/spack-fenics)
which may contain bug fixes and package specs for newer releases of the FEniCS
Project components, particularly after a recent release.

```shell
spack repo add https://github.com/fenics/spack-fenics
spack repo ls # shows fenics above builtin
```

### Binary packages

**Recommendations**

- macOS: [conda](#conda).
- Linux: [apt](#ubuntu-packages)
  ([Ubuntu](#ubuntu-packages)/[Debian](#debian-packages)),
  [docker](#docker-images) or [conda](#conda). See also [Spack](#spack).
- Windows: [docker](#docker-images), or install
  [WSL2](https://docs.microsoft.com/en-us/windows/wsl/install) and use
  [Ubuntu](#ubuntu-packages). [conda](#conda) packages in beta testing.
- High performance computers: [Spack](#spack) or
  [from source](#from-source), both using system-provided MPI.

#### conda

To install the latest release of the Python interface, including pyvista for
visualisation, using [conda](https://conda.io):

```shell
conda create -n fenicsx-env
conda activate fenicsx-env
conda install -c conda-forge fenics-dolfinx mpich pyvista # Linux and macOS
conda install -c conda-forge fenics-dolfinx pyvista pyamg # Windows
```

*Windows only*: Windows conda packages are currently in beta testing. PETSc
and petsc4py are not available on Windows. Because FEniCS uses just-in-time
compilation it necessary to install
[Microsoft Visual Studio](https://visualstudio.microsoft.com/downloads/).

conda is distributed with [Anaconda](https://www.anaconda.com/) and
[Miniconda](https://docs.conda.io/en/latest/miniconda.html). The recipe
is hosted on
[conda-forge](https://github.com/conda-forge/fenics-dolfinx-feedstock).

| Name | Downloads | Version | Platforms |
| --- | --- | --- | --- |
| [![Conda Recipe](https://img.shields.io/badge/recipe-fenics--dolfinx-green.svg)](https://anaconda.org/conda-forge/fenics-dolfinx) | [![Conda Downloads](https://anaconda.org/conda-forge/fenics-dolfinx/badges/downloads.svg)](https://anaconda.org/conda-forge/fenics-dolfinx) | [![Conda Version](https://anaconda.org/conda-forge/fenics-dolfinx/badges/version.svg)](https://anaconda.org/conda-forge/fenics-dolfinx) | [![Conda Platforms](https://anaconda.org/conda-forge/fenics-dolfinx/badges/platforms.svg)](https://anaconda.org/conda-forge/fenics-dolfinx) |

#### Ubuntu packages

The [Ubuntu
PPA](https://launchpad.net/~fenics-packages/+archive/ubuntu/fenics)
provides FEniCSx packages. To install:

```shell
add-apt-repository ppa:fenics-packages/fenics
apt update
apt install fenicsx
```

When a version of DOLFINx is released we aim to provide a package for
the most recent LTS version of Ubuntu. All other versions are provided
on a best-effort basis.

#### Debian packages

[DOLFINx](https://tracker.debian.org/pkg/fenics-dolfinx) is included
with [various
versions](https://packages.debian.org/search?keywords=python3-dolfinx&searchon=names&exact=1&suite=all&section=all)
of Debian. Install with `apt-get install fenicsx`.

#### Docker images

To run a Docker image with the latest release of DOLFINx:

```shell
docker run -ti dolfinx/dolfinx:stable
```

To switch between real and complex builds of DOLFINx/PETSc.

```shell
source /usr/local/bin/dolfinx-complex-mode
source /usr/local/bin/dolfinx-real-mode
```

A Jupyter Lab environment with the latest release of DOLFINx:

```shell
docker run --init -ti -p 8888:8888 dolfinx/lab:stable  # Access at http://localhost:8888
```

A Docker image with DOLFINx built nightly:

```shell
docker run -ti dolfinx/dolfinx:nightly
```

A development image with all of the dependencies required to build the
latest release of the FEniCSx components:

```shell
docker run -ti dolfinx/dev-env:stable
```

A development image with all of the dependencies required
to build the `main` branch of the FEniCSx components:

```shell
docker run -ti dolfinx/dev-env:current
```

The Docker images support arm64 and amd64 architectures. For a full list
of tags, including versioned images, see
<https://hub.docker.com/u/dolfinx>

## Contributing

Information about how to contribute to DOLFINx can be found
[here](CONTRIBUTING.md).

## License

DOLFINx is free software: you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

DOLFINx is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public
License along with DOLFINx. If not, see
<https://www.gnu.org/licenses/>.
