330 likes | 342 Views
Explore a pipeline for discovering free-form differential equations from data using Bayesian approaches. Learn about curve fitting, operator composition, genetic programming, and quantification of uncertainty.
E N D
A Bayesian approach to discovering free-form differential equations from data Steven Atkinson1, Waad Subber1, Genghis Khan1, Liping Wang1, Roger Ghanem2 1GE Research 2USC
Motivation Background ML works in narrow domains; human knowledge generalizes. In science, knowledge takes the form of governing laws. Can ML be used as a partner in the scientific process? • Formulate hypotheses • Test and criticize theories • Guide experimentation and data acquisition • Provide interpretable results
Using raw numerical data, uncover governing equations. Compose Data Models Result Exploration Refine
Outline Differential equation discovery pipeline • Curve fitting • Operator composition • Genetic programming • Criticism and adaptive data acquisition Propagation of epistemic uncertainty Examples
Curve fitting Differential equation discovery pipeline Identify independent (spatiotemporal) and dependent variables in data set. Learn function representations of data (traditional supervised learning, highly flexible) Must mind differentiability of models e.g.
Function composition Differential equation discovery pipeline Define operator composition as a tree operands are functions, not data. Enables use of operators like derivatives, gradients, divergences, etc. through automatic differentiation (Theano, Chainer, TensorFlow, PyTorch, JAX, …)
Function composition Differential equation discovery pipeline m = Model() m.fit(x, y) f = m(x2) fx = m.grad()(x2) fxxfx = (m.grad().grad() + m.grad())(x2) plot(x2, [f, fx, fxxfx])
Function composition Differential equation discovery pipeline Example: synthetic function
Function composition Differential equation discovery pipeline Example:
Function composition Differential equation discovery pipeline Example:
Function composition Differential equation discovery pipeline Example:
Function composition Differential equation discovery pipeline Example:
Genetic programming Differential equation discovery pipeline Define a set of primitives: and terminals . Initialize a population of individuals (differential equations). Iterate, mutating and mating individuals Retain fit individuals, discard unfit
Genetic programming—fitness function Differential equation discovery pipeline Fitness of an individual: Only requires good curve fit at !
Notes Unlike traditional GP approaches, we operate on dependent variable functions, not independent variable data.
Quantification of epistemic uncertainty We use Bayesian modeling with Gaussian processes to capture epistemic uncertainty. (Could also use Bayesian NNs, etc…)
Overview Examples
First-order ODE Examples Ground truth: .
1D Elliptic problem (heterogeneous conductivity) Examples Ground truth: .
1D Elliptic problem (nonlinear conductivity) Examples Ground truth: (Using
2D Elliptic problem (heterogeneous conductivity) Examples Ground truth: . • Data taken from [Atkinson and Zabaras, 2019]
Effect of data on fitness uncertainty As more data become available, epistemic uncertainty is reduced and it becomes easier to distinguish between competing hypotheses.
Adaptive data acquisition Using elliptic.Heterogeneous Acquisition function: residual of fittest individual Iterate until .
Investigating poorly-explained regions reducing curve-fitting uncertainty!
Conclusions Demonstrated a method to uncover governing differential equations from data. Results are human-readable and compatible with traditional theoretical & simulation methods (incl. physics-informed ML...)
Code Gaussian processes with PyTorch: pip install gptorch PIRATE—Physics-Informed Research Assistant for Theory Extraction—coming soon
Thank you This work was funded through DARPA’s Artificial Intelligence Exploration (AIE) PA-18-02-02 Artificial Intelligence Research Assistant (AIRA) agreement no. HR00111990032 Presentation Title