Gaussian Process Priors for Systems of Linear Partial Differential Equations with Constant Coefficients

This page contains auxiliary files, animations, and demos connected to the paper:
Marc Härkönen, Markus Lange-Hegermann, Bogdan Raiţă:
Gaussian process priors for systems of linear partial differential equations with constant coefficients
In: Proceedings of the 40th international conference on machine learning : , 23-29 July 2023, Honolulu, Hawaii, USA
[s. l.] : PMLR, 2023 . - P. 12587-12615
(Proceedings of machine learning research ; 202)

Above, solutions to the 2D wave equation, solved using (S-)EPGP kernels with the first frame of the animation as initial data. A demo using the S-EPGP kernel to learn a solution to Laplace’s equation can be found in the S-EPGP demo section. The Jupyter notebook can be downloaded here: demo.ipynb.

Generating solutions to Maxwell’s equations

We demonstrate the generative abilities of EPGP. Below, we compute the posterior mean of the Gaussian process solving Maxwell’s equations. We condition on three initial frames containing a sprial in the electric field; no other initial data is given, and the system is allowed to evolve by itself after that. Below we plot field lines, electric field in blue and magnetic field in red.

2D Heat equation

We apply our GP kernels to the 2D heat equation. On the left, we use an EPGP kernel with scale parameter \(\sigma^2 = 2\), and on the right \(\sigma^2 = 20\). Initial data is given at \(t = 0\), as a grid of values in \(\{0,1\}\) in the shape of a smiling face. In both cases, we see a gradual dissipation of heat over time. The length scale affects how strongly the posterior mean attempts to fit the initial data. Due to the instant smoothing property of the heat equation, the differences are visible only in the first frame of the animation.

Learning a 2D wave

The animation below is a solution to a 2D wave equation, computed using a numerical solver. It represents the vibration of a square membrane.

We try to learn the true solution using the first three frames of the above numerical solution as initial data. With S-EPGP, we converge to a reasonable solution quickly. Other than small oscillations on the boundary, the behavior of the learned wave is very close to the true solution.

As a comparison, we also fit a Physics Informed Neutal Network (PINN) to the same data. While the solution fits the initial data well (first three frames), it fails to extrapolate outside of the given training data.

Project page created: 06/01/2023

Project contributors: Marc Härkönen, Markus Lange-Hegermann, Bogdan Raiţă

Code written by: Marc Härkönen

Software used: Python (Version 3.9.15), PyTorch (Version 1.12.1), iPython (Version 8.5.0), Mathematica (Version 13), Macaulay2 (Version 1.20)

System setup used: Debian GNU/Linux 11 (bullseye), 2x 16-Core Intel Xeon Gold 6226R at 2.9 GHz, 384 GB RAM, Nvidia Tesla A100 80GB GPU.

Corresponding author of this page: Marc Härkönen, marc.harkonen@gmail.com

Last updated 09/01/2023.