Unknown

Dataset Information

0

Adaptive Checkpoint Adjoint Method for Gradient Estimation in Neural ODE.


ABSTRACT: Neural ordinary differential equations (NODEs) have recently attracted increasing attention; however, their empirical performance on benchmark tasks (e.g. image classification) are significantly inferior to discrete-layer models. We demonstrate an explanation for their poorer performance is the inaccuracy of existing gradient estimation methods: the adjoint method has numerical errors in reverse-mode integration; the naive method directly back-propagates through ODE solvers, but suffers from a redundantly deep computation graph when searching for the optimal stepsize. We propose the Adaptive Checkpoint Adjoint (ACA) method: in automatic differentiation, ACA applies a trajectory checkpoint strategy which records the forward-mode trajectory as the reverse-mode trajectory to guarantee accuracy; ACA deletes redundant components for shallow computation graphs; and ACA supports adaptive solvers. On image classification tasks, compared with the adjoint and naive method, ACA achieves half the error rate in half the training time; NODE trained with ACA outperforms ResNet in both accuracy and test-retest reliability. On time-series modeling, ACA outperforms competing methods. Finally, in an example of the three-body problem, we show NODE with ACA can incorporate physical knowledge to achieve better accuracy. We provide the PyTorch implementation of ACA: https://github.com/juntang-zhuang/torch-ACA.

SUBMITTER: Zhuang J 

PROVIDER: S-EPMC8299461 | biostudies-literature |

REPOSITORIES: biostudies-literature

Similar Datasets

| S-EPMC6022646 | biostudies-literature
| S-EPMC9880423 | biostudies-literature
| S-EPMC6628113 | biostudies-literature
| S-EPMC6022662 | biostudies-literature
| S-EPMC5993334 | biostudies-literature
| S-EPMC4081021 | biostudies-literature
| S-EPMC5796467 | biostudies-literature
| S-EPMC1135903 | biostudies-other
| S-EPMC5573134 | biostudies-literature
| S-EPMC10657412 | biostudies-literature