A full-waveform inversion (FWI) framework built in PyTorch. Forge was designed and built for research and prototyping of tomographic acoustic imaging methods.
Everything has been built from the ground up using pure PyTorch, with no third-party libraries relied upon for wave propagation or inversion. This gives the user complete control and customisability, as well as all of the benefits of PyTorch: seamless integration with cutting-edge machine learning techniques and models; GPU acceleration; pre-built optimizers and loss functions.
Design philosophy:
- be easy to read, understand and use,
- be entirely hackable,
- built on PyTorch.
Install Forge and its required dependencies as follows:
git clone https://github.com/GeorgeWilliamStrong/forge.git
cd forge
pip install -e .
For a tutorial of how to use Forge, please refer to the demo notebook. There is also a breast imaging example which contains two notebooks, one for forward modelling, the other for solving the inverse problem.
Plotting functionality used in the demos employs PySlice, which can be installed as follows:
git clone https://github.com/GeorgeWilliamStrong/pyslice
cd pyslice
pip install -e .
from forge.model import FullWaveformInversion
import torch
# Instantiate model using the starting model
model = FullWaveformInversion(model = m0,
dx = dx,
dt = dt,
r_pos = r_pos)
# Instantiate PyTorch optimizer
opt = torch.optim.SGD([model.m], lr=1e-5, momentum=0.4)
# Define loss function
l2_loss = torch.nn.MSELoss()
# Run the optimisation loop
model.fit(data = true_model.d,
s_pos = s_pos,
source = source,
optimizer = opt,
loss = l2_loss,
num_iter = 10,
bs = 10,
blocks = [1e5, 2e5])
Currently, Forge only supports two-dimensional modelling as it was designed for rapid experimental prototyping. Extending the codes to three-dimensional modelling is trivial in principle, although multi-GPU support has not yet been implemented.