Welcome to Irksome¶
Irksome is a Python library that adds a temporal discretization layer on top of finite element discretizations provided by Firedrake. We provide a symbolic representation of time derivatives in UFL, allowing users to write weak forms of semidiscrete PDE. Irksome maps this and a Butcher tableau encoding a Runge-Kutta method into a fully discrete variational problem for the stage values. Irksome then leverages existing advanced solver technology in Firedrake and PETSc to allow for efficient computation of the Runge-Kutta stages. Convenience classes package the underlying lower-level manipulations and present users with a friendly high-level interface time stepping.
So, instead of manually coding UFL for backward Euler for the heat equation:
F = inner((unew - uold) / dt, v) * dx + inner(grad(unew), grad(v)) * dx
and rewriting this if you want a different time-stepping method, Irksome lets you write UFL for a semidiscrete form:
F = inner(Dt(u), v) * dx + inner(grad(u), grad(v)) * dx
and maps this and a Butcher tableau for some Runge-Kutta method to UFL for a fully-discrete method. Hence, switching between RK methods is plug-and-play.
Irksome provides convenience classes to package the transformation of forms and boundary conditions and provide a method to advance by a time step. The underlying variational problem for the (possibly implicit!) Runge-Kutta stages composes fully with advanced Firedrake/PETSc solver technology, so you can use block preconditioners, multigrid with patch smooters, and more – and in parallel, too!
Acknowledgements¶
The Irksome team is deeply grateful to David Ham for setting up our initial documentation and Jack Betteridge for initializing the CI. Ivan Yashchuk set up the GitHub Actions. Lawrence Mitchell provided early assistance on some UFL manipulation and documentation
Getting started¶
Irksome requires Firedrake, if
you have an existing Firedrake installation, you can add Irksome to it
with firedrake-update --install irksome
. If you would like a fresh
installation including Irksome, use firedrake-install --install
irksome
. Alternately you can clone the repository and pip
install -e .
into the Firedrake virtual environment.
Tutorials¶
After your installation works, please check out our demos.
The best place to start are with some simple heat and wave equations:
Since those demos invariably rely on the non-scalable LU factorization, we have several demos showing how to work with Firedrake solver options to deploy more efficient methods:
We now have support for DIRKs:
and for Galerkin-in-Time:
and for explicit schemes:
and for bounds constraints:
and for adaptive IRK methods:
Or check out two IMEX-type methods for the monodomain equations:
Advanced demos¶
There’s also an example solving a Sobolev-type equation with symplectic RK methods:
and with a Galerkin-in-Time approach:
Finally, if you feel you must bypass the TimeStepper
abstraction, we have some examples how to interact with Irksome at a
slightly lower level:
API documentation¶
There is also an alphabetical index, and a search engine.
- irksome package
- Submodules
- irksome.ButcherTableaux module
- irksome.bcs module
- irksome.deriv module
- irksome.dirk_imex_tableaux module
- irksome.dirk_stepper module
- irksome.discontinuous_galerkin_stepper module
- irksome.explicit_stepper module
- irksome.galerkin_stepper module
- irksome.getForm module
- irksome.imex module
- irksome.manipulation module
- irksome.pc module
- irksome.pep_explicit_rk module
- irksome.stage module
- irksome.stepper module
- irksome.tools module
- irksome.wso_dirk_tableaux module
- Module contents