This example demonstrates physics informing of a data-driven model using numerical derivatives (PINO).
To examine the properties of PINOs with multiple complex equations, we
examined the ability of the networks to reproduce the incompressible
magnetohydrodynamics (MHD) equations representing an incompressible fluid
in the presence of a magnetic field
where
For the magnetic field divergence equation, we can either include it
in the loss function or instead evolve the magnetic vector potential
which ensures that the divergence of
Both scripts to evolve the magnetic field
We will demonstrate the use of data loss and physics constraints, specifically the equation residual loss, to create accurate predictions. Modulus Sym has utilities tailored for physics-informed machine learning. It also presents abstracted APIs that allow users to think and model the problem from the lens of equations, constraints, etc. In this example, we will only leverage the physics-informed utilities to see how we can add physics to an existing data-driven model with ease while still maintaining the flexibility to define our own training loop and other details. For a more abstracted definition of these type of problems, where the training loop definition and other things is taken care of implicitly, you may refer Modulus Sym
The code to generate the training and validation datasets for this example can be found on the MHD PINO Github page. You will also need to install Dedalus to generate the data. More information can be found on through the Dedalus project documentation After this, generating the data can be done by running the below set of commands:
pip install -r requirements.txt
python3 dedalus_mhd.py
or
pip install -r requirements.txt
python3 dedalus_mhd_parallel.py
The first script is not parallelized while the second script is parallelized based on the CPU count. To demonstrate the usefulness of the Physics loss, we will deliberately choose a smaller dataset size of 100 samples. In such regimes, the effect of physics loss is more evident, as it regularizes the model in the absence of large data. However, the tensor factorized Fourier Neural Operator (TFNO) model requires 1000 samples to reproduce the results from the paper.
In this example, we will use a Fourier Neural Operator (FNO) and then compute the derivatives in a PINO style, using Numerical differentiation with Fourier derivatives. With this example, we intend to demonstrate how to implement multiple equations into the loss function. We will also use a tensor factorized Fourier Neural Operator (TFNO) in the same pipeline. The only difference with a TFNO model is that the weights are factorized using TensorLy.
In this example, we will also use the PDE
class from Modulus-Sym to symbolically define
the PDEs. This is very convinient and most natural way to define these PDEs and allows
us to print the equations to check for correctness. This also abstracts out the
complexity of converting the equation into a pytorch representation. Modulus Sym also
provides several complex, well-tested PDEs like 3D Navier-Stokes, Linear elasticity,
Electromagnetics, etc. pre-defined which can be used directly in physics-informing
applications. We will also give you the option to choose between the
derivative functions from Modulus-Sym or from the original paper.
To get started with the example that evolves the magnetic field with a FNO model, simply run,
torchrun --standalone --nnodes=1 --nproc_per_node=<num_gpus> train_mhd.py
To get started with the example that evolves the vector potential with a FNO model, simply run,
torchrun --standalone --nnodes=1 --nproc_per_node=<num_gpus> train_mhd_vec_pot.py
To get started with the example that evolves the vector potential with a TFNO model, simply run,
torchrun --standalone --nnodes=1 --nproc_per_node=<num_gpus> train_mhd_vec_pot_tfno.py