analytic sensitivities in large-scale production applications via ...€¦ · sensitivity analysis...

20
Sandia is a multiprogram laboratory operated by Sandia Corporation, a Lockheed Martin Company, for the United States Department of Energys National Nuclear Security Administration under contract DE-AC04-94AL85000. Eric Phipps Roscoe Bartlett, David Gay Optimization & Uncertainty Quantification Department Sandia National Laboratories Albuquerque, NM USA Parallel Processing for Scientific Computing March 13, 2008 Analytic Sensitivities in Large-scale Production Applications via Automatic Differentiation with Sacado

Upload: others

Post on 07-Jun-2020

3 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Sandia is a multiprogram laboratory operated by Sandia Corporation, a Lockheed Martin Company,for the United States Department of Energy’s National Nuclear Security Administration

under contract DE-AC04-94AL85000.

Eric PhippsRoscoe Bartlett, David Gay

Optimization & Uncertainty Quantification DepartmentSandia National Laboratories

Albuquerque, NM USA

Parallel Processing for Scientific ComputingMarch 13, 2008

Analytic Sensitivities in Large-scale Production Applications via Automatic

Differentiation with Sacado

Page 2: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Analytic Derivatives Enable Robust Simulation and Design Capabilities

• We need analytic first & higher derivatives for predictive simulations– Computational design, optimization and parameter estimation– Stability analysis– Uncertainty quantification– Verification and validation

• Analytic derivatives improve robustness and efficiency– Very hard to make finite differences accurate

• Infeasible to expect application developers to code analytic derivatives

– Time consuming, error prone, and difficult to verify– Thousands of possible parameters in a large code– Developers must understand what derivatives are needed

• Automatic differentiation solves these problems

Page 3: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

2.000 1.000

7.389 7.389

0.301 0.500

0.602 1.301

7.991 8.690

0.991 -1.188

What is Automatic Differentiation (AD)?

• Technique to compute analytic derivatives without hand-coding the derivative computation

• How does it work -- freshman calculus– Computations are composition of

simple operations (+, *, sin(), etc…) with known derivatives

– Derivatives computed line-by-line, combined via chain rule

• Derivatives accurate as original computation

– No finite-difference truncation errors

• Provides analytic derivatives without the time and effort of hand-coding them

d

dxx

x! 2dx

dx! 1

t! ex dt

dx! t

dx

dx

u! log xdu

dx! 1

x

dx

dx

v ! xudv

dx! u

dx

dx+ x

du

dx

w ! t + vdw

dx! dt

dx+

dv

dx

y ! sinwdy

dx! cos(w)

dw

dx

y = sin(ex + x log x), x = 2

Page 4: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Automatic Differentiation Projects

• Many AD projects around the world, e.g., – ADIFOR/ADIC (ANL, Rice) -- Fortran 77, C– OpenAD (ANL, Rice, Aachen) -- Fortran 77/95, C/C++ (maybe)– ADOL-C (TU-Desden) -- C/C++ – TFAD<> -- C/C++

• Most source transformation tools limited to Fortran

• Most operator overloading based tools are slow– TFAD<> shows how to do this efficiently

• Many AD projects are geared towards “black-box” solutions

• We need efficient OO tools optimized for Sandia’s large-scale, parallel, C++ applications

Page 5: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Sandia Physics Simulation Codes• Element-based

– Finite element, finite volume, finite difference, network, etc…

• Large-scale– Billions of unknowns

• Parallel– MPI-based SPMD– Distributed memory

• C++– Object oriented– Some coupling to legacy Fortran

libraries

• We need AD techniques that fit these requirements

Fluids Combustion

StructuresCircuits

Plasmas

MEMS

Page 6: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Sacado: AD Tools for C++ Applications

• Trilinos package: www.trilinos.sandia.gov

• Implements several modes of AD– Forward (Jacobians, Jacobian-vector products, …)– Reverse (Gradients, Jacobian-transpose-vector products, …)– Taylor (High-order univariate Taylor series)

• AD via operator overloading and C++ templating– Expression templates for OO efficiency– Application code templating for easy incorporation

• Designed for use in large-scale C++ codes– Apply AD at “element-level”– Manually integrate derivatives into parallel data structures and solvers–Sacado::FEApp example demonstrates approach

Page 7: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

// The function to differentiate

double func(double a, double b, double c) { double r = c*std::log(b+1.)/std::sin(a); return r;}

int main(int argc, char **argv) { double a = std::atan(1.0); // pi/4 double b = 2.0; double c = 3.0;

// Compute function double r = func(a, b, c);

Simple Sacado Example

Page 8: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

#include "Sacado.hpp"

// The function to differentiatetemplate <typename ScalarT>ScalarT func(const ScalarT& a, const ScalarT& b, const ScalarT& c) { ScalarT r = c*std::log(b+1.)/std::sin(a); return r;}

int main(int argc, char **argv) { double a = std::atan(1.0); // pi/4 double b = 2.0; double c = 3.0;

int num_deriv = 2; // Number of independent variables Sacado::Fad::DFad<double> afad(num_deriv, 0, a); // First (0) indep. var Sacado::Fad::DFad<double> bfad(num_deriv, 1, b); // Second (1) indep. var Sacado::Fad::DFad<double> cfad(c); // Passive variable // Compute function double r = func(a, b, c);

// Compute function and derivative with AD Sacado::Fad::DFad<double> rfad = func(afad, bfad, cfad);

// Extract value and derivatives double r_ad = rfad.val(); // r double drda_ad = rfad.dx(0); // dr/da double drdb_ad = rfad.dx(1); // dr/db

Simple Sacado Example

Page 9: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

• Global residual computation (ignoring boundary computations):

• Time-step Jacobian computation:

• Parameter derivative computation:

• Hybrid symbolic/AD procedure

Differentiating Element-Based Production Applications

f(x, x, t, p) =N!

i=1

QTi eki(Pix, Pix, t, p)

!"f

"x+ #

"f

"x=

N!

i=1

QTi

"!

"eki

"xi+ #

"eki

"xi

#Pi, xi = Pix, xi = Pix

!f

!p=

N!

i=1

QTi

!eki

!p

Page 10: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Integrating AD with Solver Capabilities

NOX LOCA Rythmos

Thyra::ModelEvaluator

Application::ModelEvaluator

Evaluate Jacobian

Loop over elements gather element solution initialize element AD types evaluate templated element residual extract derivative values sum into global derivative matrixend loop

Nonlinear Solvers

Abstract application interface

Concrete application interface

Method implementation

Page 11: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

2Xj ! Xj!1 + Xj+1, j = 2, . . . , N ! 1

u ·!Yj +!2Yj = !j , j = 1, . . . , N " 1N!

j=1

Yj = 1

Steady-state mass transfer equations:

Scalability of This Approach

Scalability of the element-level derivative computationSet of N hypothetical chemical species:

DOF per element = 4*N

0 100 200 300 4000

200

400

600

DOF Per Element

Re

lative

Eva

l. T

ime Jacobian Eval

1.02

0.27

0 100 200 300 4000

500

1000

DOF Per Element

Re

lative

Flo

p C

ou

nt Jacobian Eval

0.94

1.55

0 100 200 300 4007

8

9

10

DOF Per Element

Re

lative

Eva

l. T

ime Adjoint Eval

0 100 200 300 4005.6

5.7

5.8

5.9

DOF Per Element

Re

lative

Flo

p C

ou

nt Adjoint Eval

FD

FAD

FD

FAD

RAD

RADForward mode AD✓Faster than FD✓Better scalability in number of PDEs✓Analytic Derivative

Reverse mode AD✓Scalable adjoint/gradient

JT w = !(wT f(x))

Page 12: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Si interstitial (I) (+2,+1,0,–1,–2)

Vacancy (V) (+2,+1,0,–1,–2)

VV (+1,0,–1,–2)

BI (+,0,–)

CI (+,0,-)

VP (0,–)

VB (+,0)

VO (0,–)

BIB (0,–)

BIO (+,0)

BIC

Annihilation

Annihilation

Defect reactions

QASPR Qualification of electronic devices in hostile environments

PDE semiconductor device simulation

Stockpile BJT

Page 13: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Charon Drift-Diffusion Formulation with Defects

Defect Continuity

Include electron capture and hole capture by defect species and reactions between various defect species

Electric potential

Electron emission/capture

Current Conservation for

e- and h+

Cross section

Activation Energy

!n

!t!" · Jn = !Rn(", n, p, Y1, . . . , YN ), Jn = !nµn"" + Dn"n

!p

!t+" · Jp = !Rp(", n, p, Y1, . . . , YN ), Jp = !pµp"" !Dp"p

!Yi

!t+" · JYi = !RYi(", n, p, Y1, . . . , YN ), JYi = !µiYi"" !Di"Yi

!"(!""(x)) = !q!p(x)! n(x) + N+

D (x)!N!A (x)

"!

N#

i=1

qiYi(x)

Recombination/generation

source termsRX

Zi ! Zi+1 + e!R[Zi!Zi+1+e!] ! ![Zi!Zi+1+e!]Z

i exp!

!E[Zi!Zi+1+e!]

kT

"

Page 14: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Forward Sensitivity Analysis with Rythmos• Discretized PDE system:

• Forward sensitivity problem

• Rythmos time integration package– Todd Coffey, Ross Bartlett (SNL)– Implicit BDF time integration method– Variable order, step size– Staggered corrector forward sensitivity

method

f(x, x, p, t) = 0g(p, t) = g(x(t), x(t), p, t)

!f

!x

!!x

!p

"+

!f

!x

!!x

!p

"+

!f

!p= 0

!g

!p=

!g

!x

!x

!p+

!g

!x

!x

!p+

!g

!p

ImplicitBDFStepper ExplicitRKStepper …

NonlinearSolver

NOX TimeStepSolver

LinearSolver

Amesos

AztecOO Belos

Preconditioner

Ifpack ML

Epetra

Linear algebra data structures

Algebraic preconditioners and direct solvers

Iterative linear solvers

Iterative nonlinear solvers

RythmosTransient ODE/DAE forward sensitivity solvers

Derivatives Sacado

Page 15: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Sensitivity Analysis of a Pseudo-1D BJT• 9x0.1 micron pseudo-1D simulation• 1046x1 quad cells, linear finite elements + SUPG• 2 carriers + 35 defect species• 108,030 unknowns on 32 processors• 84 carrier-defect reactions• 126 parameters for sensitivity analysis• AD Jacobian, parameter deriv’s• Base current provides observation function

Transient Base Current

!"!#

!"!$

!"!%

!"!&

!""

"

&

%

$

#

'(!"!)

*+,-(./0

12/-(3455-67

!"!#

!"!$

!"!%

!"!&

!""

"

!

&

'

%

()*!"

!+

,-./*012

34/56/7*89-41

Radiation Pulse

Page 16: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Transient Base Current Sensitivities

p

I

dI

dp

# Reaction Parameter Value

14 activation energy 0.09

16 cross-section 2.40E-14

46 cross-section 1.50E-15

V !! ! e! + V !

e! + V 0 ! V !

e! + PV 0 ! PV 0

!" #" $" %" &" '" (" )" *" !"" !!" !#"!"+'

!"+%

!"+#

"

"+#

"+%

"+'

,-./012,0345657568

65902:2!+"0!"$

!" #" $" %" &" '" (" )" *" !"" !!" !#"!"+'

!"+%

!"+#

"

"+#

"+%

"+'

;.<.9060<

,-./012,0345657568

65902:2!+"

Scaled Sensitivities

!"!#

!"!$

!"!%

!"!&

!""

!!

!"'(

"

"'(

!

)*+,-./0

1234,5-1,6/*7*8*79

-

-

:3;3+,7,;-!$

:3;3+,7,;-%$

Scaled Sensitivities

!"!#

!"!$

!"!%

!"!&

!""

!'

!%

!(

!&

!!

")*!"

%

+,-.*/01

2.30,4,5,46

*

*

7898-.4.9*!$

7898-.4.9*%$

Unscaled Sensitivities

Page 17: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Comparison to Black-Box Finite Differences

• Run-times:– Forward simulation: 105 min.– Direct sensitivities: 931 min.– Black-box, first-order FD: ~13,000 min.

• Direct approach more efficient– 14x speed-up

• Direct approach more accurate– 1-2 correct digits w/FD– FD requires tighter tolerances to

achieve higher accuracy• Direct approach more robust

– Accuracy solely dictated by time-integration error

1st-order Finite Difference Error

!"!#

!"!$

!"!%

!"!!

!""

"

"&!

"&%

"&$

"&#

"&'

()*+,-./

0+123)4+,56676

,

,

!+!!

!+!%

!+!$

!+!#

!+!'

Page 18: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Summary

• Templating key to AD approach– Simple, fast Sacado AD tools– Apply at “element” level– Hooks for future program

transformation

• Vertical integration of Trilinos technologies provide remarkable capabilities

– Efficient, accurate, robust sensitivities

– Foundation for transient optimization

– Requires all levels to be effective

ImplicitBDFStepper ExplicitRKStepper …

NonlinearSolver

NOX TimeStepSolver

LinearSolver

Amesos

AztecOO Belos

Preconditioner

Ifpack ML

Epetra

Linear algebra data structures

Algebraic preconditioners and direct solvers

Iterative linear solvers

Iterative nonlinear solvers

RythmosTransient ODE/DAE forward sensitivity solvers

Derivatives Sacado

Page 19: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Auxiliary Slides

Page 20: Analytic Sensitivities in Large-scale Production Applications via ...€¦ · Sensitivity Analysis of a Pseudo-1D BJT • 9x0.1 micron pseudo-1D simulation • 1046x1 quad cells,

Difficulties With This Approach

• Template code introduces excessive compiler overhead– Explicit template instantiation– Preprocessor macros make this easy

• Real codes always call other libraries– BLAS/LAPACK– CHEMKIN– Linear/nonlinear solvers– Template interfaces (partial template specialization) are general solution

• Operator overloading overhead– Residual/derivative fills are not dominant cost