GeometricMachineLearning.jl
offers a flexible tool for designing neural networks for dynamical systems with geometric structure, such as Hamiltonian (symplectic) or Lagrangian (variational) systems.
At its core every neural network comprises three components: a neural network architecture, a loss function and an optimizer.
Traditionally, physical properties have been encoded into the loss function (PINN approach), but in GeometricMachineLearning.jl
this is exclusively done through the architectures and the optimizers of the neural network, thus giving theoretical guarantees that these properties are actually preserved.
Using the package is very straightforward and is very flexible with respect to the device (CPU, CUDA, Metal, ...)
and the type (Float16, Float32, Float64, ...)
you want to use. The following is a simple example to learn a SympNet on data coming from a pendulum:
using GeometricMachineLearning
using CUDA # Metal
using Plots
include("scripts/pendulum.jl")
type = Float32 # Float16 etc.
# get data
qp_data = GeometricMachineLearning.apply_toNT(a -> CuArray(type.(a)), pendulum_data((q=[0.], p=[1.]); tspan=(0.,100.)))
# call the DataLoader
dl = DataLoader(qp_data)
# call the SympNet architecture
gsympnet = GSympNet(dl)
# specify the backend
backend = CUDABackend()
# initialize the network (i.e. the parameters of the network)
g_nn = NeuralNetwork(gsympnet, backend, type)
# call the optimizer
g_opt = Optimizer(AdamOptimizer(), g_nn)
const nepochs = 300
const batch_size = 100
# train the network
g_loss_array = g_opt(g_nn, dl, Batch(batch_size), nepochs)
# plot the result
ics = (q=qp_data.q[:,1], p=qp_data.p[:,1])
const steps_to_plot = 200
g_trajectory = Iterate_Sympnet(g_nn, ics; n_points = steps_to_plot)
p2 = plot(qp_data.q'[1:steps_to_plot], qp_data.p'[1:steps_to_plot], label="training data")
plot!(p2, g_trajectory.q', g_trajectory.p', label="G Sympnet")
More examples like this can be found in the docs.
- Brantner B. Generalizing Adam To Manifolds For Efficiently Training Transformers. arXiv preprint arXiv:2305.16901, 2023.
- Brantner B., Kraus M. Symplectic Autoencoders for Model Reduction of Hamiltonian Systems. arXiv preprint arXiv:2312.10004, 2023.
- Brantner B., Romemont G., Kraus M., Li Z. Structure-Preserving Transformers for Learning Parametrized Hamiltonian Systems. arXiv preprint arXiv:2312.11166, 2023.