Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/liruilong940607/neuralode
The simplest pytorch implement (100 lines) of "Neural Ordinary Differential Equations" @ NeurIPS 2018 Best Paper.
https://github.com/liruilong940607/neuralode
Last synced: 3 months ago
JSON representation
The simplest pytorch implement (100 lines) of "Neural Ordinary Differential Equations" @ NeurIPS 2018 Best Paper.
- Host: GitHub
- URL: https://github.com/liruilong940607/neuralode
- Owner: liruilong940607
- Created: 2019-12-06T03:53:07.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2020-09-16T03:31:55.000Z (over 4 years ago)
- Last Synced: 2023-03-04T20:34:05.891Z (almost 2 years ago)
- Language: Python
- Homepage:
- Size: 10.7 KB
- Stars: 58
- Watchers: 4
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# NeuralODE.pytorch
This is the simplest pytorch implement (100 lines) of **["Neural Ordinary Differential Equations"](https://arxiv.org/pdf/1806.07366.pdf) @ NeurIPS 2018 Best Paper**.
### Train on MNIST
* resnet baseline (0.60M #Params): accu = 99.42%
```
python train_mnist.py
```* ode network (0.22M #Params): accu = 99.31%
```
python train_mnist.py --ode
```**Note:** This repo is not aim at reproducing the performace in the original paper, but to show the basic logics of how to do forward as well as backward in ode network in **100 lines** (`NeuralODE.py`). There are mutiple differences between my inplementation and the original implementation, including:
1. ODESolver: Only implement `rk4` in this repo.
2. Training strategy: inluding learning-rate schedule, optimizer and so on.
3. ODE network: timestamp is hard-code in this repo.### Usage of NeuralODE
```
from NeuralODE import NeuralODE# some kind of neural network.
model = NNet()# [ADD SINLGE LINE] using NeuralODE to update this network.
model = NeuralODE(model)# just train as usual, nothing need to change
optimizer = optim.Adadelta(model.parameters(), lr=args.lr)scheduler = StepLR(optimizer, step_size=1, gamma=args.gamma)
for epoch in range(1, args.epochs + 1):
train(args, model, device, train_loader, optimizer, epoch)
test(args, model, device, test_loader)
scheduler.step()```
**Note:** Currently, `NeuralODE` only support those models which don't change the resolution of input (input.shape == output.shape)
### Other Sources
[Author's Pytorch Implementation](https://github.com/rtqichen/torchdiffeq)
[TensorFlow Tutorial and Implementation](https://github.com/kmkolasinski/deep-learning-notes/tree/master/seminars/2019-03-Neural-Ordinary-Differential-Equations)