Skip to content

Trainingยค

Two following ways are possible to train Neural DDEs / Neural ODEs :

  • optimize-then-discretize (with the adjoint method)
  • discretize-then-optimize (regular backpropagation)

Please see the doctorial thesis On Neural Differential Equations for more information on both procedures.

To choose from either two possibilities is easy, you just need to set the bool discretize_then_optimize.

A simple training loop would look like:

for step, data in enumerate(train_loader):
    optimizer.zero_grad()
    data = data.to(device)
    ys_pred = integrate(
        model,
        solver=...,
        t0=ts[0],
        t1=ts[-1],
        ts=ts,
        y0=...,
        args=None,
        dt0=ts[1] - ts[0],
        delays=...,
    )
    loss = loss_fn(ys_pred, data)
    loss.backward()
    optimizer.step()

If you are training an ODE then delays=None and y0=data[:, 0] is a Tensor.
If you are training an DDE then delays is a Tensor and y0 is a Callable.