CSE 245 Lecture Notes
Transcription
CSE 245 Lecture Notes
CSE 245: Computer Aided Circuit Simulation and Verification Fall 2004, Nov Nonlinear Equation Outline Nonlinear problems Iterative Methods Newton’s Method Derivation of Newton Quadratic Convergence Examples Convergence Testing Basic Algorithm Quadratic convergence Application to circuits Limiting Schemes Multidimensonal Newton Method Improve Convergence Direction Corrupting Non corrupting (Damped Newton) Source stepping Continuation Schemes January 11, 2017 2 courtesy Alessandra Nardi UCB Nonlinear Problems - Example 1 Vd I1 I d I s (e Id Ir Vt 1) 0 0 Need to Solve I r I d I1 0 e1 Vt 1 e1 I s (e 1) I1 0 R January 11, 2017 g (e1 ) I1 3 courtesy Alessandra Nardi UCB Nonlinear Equations Given g(V)=I It can be expressed as: f(V)=g(V)-I Solve g(V)=I equivalent to solve f(V)=0 Hard to find analytical solution for f(x)=0 Solve iteratively January 11, 2017 4 courtesy Alessandra Nardi UCB Nonlinear Equations – Iterative Methods Start from an initial value x0 Generate a sequence of iterate xn-1, xn, xn+1 which hopefully converges to the solution x* Iterates are generated according to an iteration function F: xn+1=F(xn) Ask • When does it converge to correct solution ? • What is the convergence rate ? January 11, 2017 5 courtesy Alessandra Nardi UCB Newton-Raphson (NR) Method Consists of linearizing the system. Want to solve f(x)=0 Replace f(x) with its linearized version and solve. * df ( x ) * f ( x) f ( x ) ( x x* ) dx k df ( x ) k 1 k k 1 k f (x ) f (x ) (x x ) dx x k 1 1 df ( x ) k x f (x ) dx k Taylor Ser ies k Iteration function Note: at each step need to evaluate f and f’ January 11, 2017 6 courtesy Alessandra Nardi UCB Newton-Raphson Method January 11, 2017 7 – Graphical View courtesy Alessandra Nardi UCB Newton-Raphson Method Define iteration Do k = 0 to …. x k 1 df ( x ) x dx k k – Algorithm 1 k f (x ) until convergence How about convergence? An iteration {x(k)} is said to converge with order q if there exists a vector norm such that for each k N: January 11, 2017 x k 1 xˆ 8x xˆ k q courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence ~ df ( x ) d f ( x) * * k * k k 2 0 f (x ) f (x ) (x x ) ( x x ) 2 dx dx k 2 Mean Value theorem truncates Taylor series But k df ( x ) k 1 k 0 f (x ) (x xk ) dx by Newton definition January 11, 2017 9 courtesy Alessandra Nardi UCB Newton-Raphson Method Subtracting – Convergence df ( x k ) k 1 * d 2 f (~ x) k * 2 (x x ) ( x x ) 2 dx dx Dividing through 2 df d f k 1 * k 1 k * 2 ( x x ) [ ( x )] ( x )( x x ) 2 dx d x df k 1 d 2 f k Let [ ( x )] ( x ) K 2 dx d x then x k 1 x K x x * k k * 2 Convergence is quadratic January 11, 2017 10 courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence Local Convergence Theorem If df a) dx d2 f b) 2 dx bounded away from zero K is bounded bounded Then Newton’s method converges given a sufficiently close initial guess (and convergence is quadratic) January 11, 2017 11 courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence Example 1 f ( x) x 2 1 0, df k ( x ) 2 xk dx find x ( x* 1) 2 k k 1 x ) x k k 1 x ) 2x (x x ) x 2x (x 2x (x or ( x k 1 k * k k 1 k * k x 2 * 2 1 x ) k ( x k x* ) 2 2x Convergence is quadratic January 11, 2017 * 12 courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence Example 2 f ( x) x 0, x 0 df k ( x ) 2 xk dx k k 1 k 2 2 x ( x 0) ( x 0) 2 * 1 df not bounded dx Note : away from zero 1 k x 0 x 0 for x k x* 0 2 1 * * or ( xk 1 x ) ( xk x ) 2 k 1 Convergence is linear January 11, 2017 13 courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence Example 1,2 January 11, 2017 14 courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence x = Initial Guess, k 0 0 Repeat { f x k x x k 1 x k f x k k k 1 } Until ? x k 1 x threshold ? k January 11, 2017 f x 15 k 1 threshold ? courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence Convergence Check Need a "delta-x" check to avoid false convergence f(x) x x k 1 x k 1 x xa xr x k k x k 1 * f x k 1 fa January 11, 2017 16 courtesy Alessandra Nardi UCB X Newton-Raphson Method – Convergence Convergence Check Also need an "f x " check to avoid false convergence f(x) f x x x January 11, 2017 k 1 k 1 fa * X x k 1 x k x xa xr x k 17 k 1 courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence demo2 January 11, 2017 18 courtesy Alessandra Nardi UCB Newton-Raphson Method – Convergence Local Convergence Convergence Depends on a Good Initial Guess f(x) 1 x 1 x x January 11, 2017 19 2 x 0 x 0 courtesy Alessandra Nardi UCB X Newton-Raphson Method – Convergence Local Convergence Convergence Depends on a Good Initial Guess January 11, 2017 20 courtesy Alessandra Nardi UCB Nonlinear Problems – Multidimensional Example v1 i2 + v2b - v2 Nodal Analysis i3 i1 + + b 1 b 3 v v - - At Node 1: i1 i2 0 g v1 g v1 v2 0 At Node 2: i3 i2 0 g v3 g v1 v2 0 Nonlinear Resistors Two coupled nonlinear equations in two unknowns i g v January 11, 2017 21 courtesy Alessandra Nardi UCB Outline Nonlinear problems Iterative Methods Newton’s Method Derivation of Newton Quadratic Convergence Examples Convergence Testing Basic Algorithm Quadratic convergence Application to circuits Limiting Schemes Multidimensonal Newton Method Improve Convergence Direction Corrupting Non corrupting (Damped Newton) Source stepping Continuation Schemes January 11, 2017 22 courtesy Alessandra Nardi UCB Multidimensional Newton Method Problem: Find x such that F x 0 * x * N * and F : F ( x) F ( x ) J ( x )( x x ) * * * F1 ( x) F1 ( x) x x 1 N J ( x) FN ( x) FN ( x) x1 x N k 1 k k 1 k x x J (x ) F (x ) January 11, 2017 23 N N Taylor Ser ies Jacobian Matrix Iteration function courtesy Alessandra Nardi UCB Multidimensional Newton Method Computational Aspects Iteration : x k 1 x k J ( x k ) 1 F ( x k ) k 1 Do not compute J ( x ) (it is not sparse). Instead solve : J ( x k )( x k 1 x k ) F ( x k ) Each iteration requires: 1. Evaluation of F(xk) 2. Computation of J(xk) 3. Solution of a linear system of algebraic equations whose coefficient matrix is J(xk) and whose RHS is -F(xk) January 11, 2017 24 courtesy Alessandra Nardi UCB Multidimensional Newton Method Algorithm x = Initial Guess, k 0 0 Repeat { x x x F x for x Compute F x k , J F x k Solve J F k k 1 k k k 1 k k 1 } Until January 11, 2017 x k 1 x k , f x k 1 25 small enough courtesy Alessandra Nardi UCB Multidimensional Newton Method Convergence Local Convergence Theorem If a) J F1 x k Inverse is bounded b) J F x J F y Derivative is Lipschitz Cont x y Then Newton’s method converges given a sufficiently close initial guess (and convergence is quadratic) January 11, 2017 26 courtesy Alessandra Nardi UCB Application of NR to Circuit Equations Companion Network Applying NR to the system of equations we find that at iteration k+1: all the coefficients of KCL, KVL and of BCE of the linear elements remain unchanged with respect to iteration k Nonlinear elements are represented by a linearization of BCE around iteration k This system of equations can be interpreted as the STA of a linear circuit (companion network) whose elements are specified by the linearized BCE. January 11, 2017 27 courtesy Alessandra Nardi UCB Application of NR to Circuit Equations Companion Network General procedure: the NR method applied to a nonlinear circuit whose eqns are formulated in the STA form produces at each iteration the STA eqns of a linear resistive circuit obtained by linearizing the BCE of the nonlinear elements and leaving all the other BCE unmodified After the linear circuit is produced, there is no need to stick to STA, but other methods (such as MNA) may be used to assemble the circuit eqns January 11, 2017 28 courtesy Alessandra Nardi UCB Application of NR to Circuit Equations Companion Network – MNA templates Note: G0 and Id depend on the iteration count k G0=G0(k) and Id=Id(k) January 11, 2017 29 courtesy Alessandra Nardi UCB Application of NR to Circuit Equations Companion Network – MNA templates January 11, 2017 30 courtesy Alessandra Nardi UCB Modeling a MOSFET (MOS Level 1, linear regime) d January 11, 2017 31 courtesy Alessandra Nardi UCB Modeling a MOSFET January 11, 2017 (MOS Level 1, linear regime) 32 courtesy Alessandra Nardi UCB DC Analysis Flow Diagram For each state variable in the system January 11, 2017 33 courtesy Alessandra Nardi UCB Implications Device model equations must be continuous with continuous derivatives (not all models do this - - be sure models are decent - beware of user-supplied models) Watch out for floating nodes (If a node becomes disconnected, then J(x) is singular) Give good initial guess for x(0) Most model computations produce errors in function values and derivatives. Want to have convergence criteria || x(k+1) - x(k) || < such that > than model errors. January 11, 2017 34 courtesy Alessandra Nardi UCB Outline Nonlinear problems Iterative Methods Newton’s Method Derivation of Newton Quadratic Convergence Examples Convergence Testing Basic Algorithm Quadratic convergence Application to circuits Limiting Schemes Multidimensonal Newton Method Improve Convergence Direction Corrupting Non corrupting (Damped Newton) Source stepping Continuation Schemes January 11, 2017 35 courtesy Alessandra Nardi UCB Improving convergence Improve Models (80% of problems) Improve Algorithms (20% of problems) Focus on new algorithms: Limiting Schemes Continuations Schemes January 11, 2017 36 courtesy Alessandra Nardi UCB Improve Convergence Limiting Schemes Direction Corrupting Non corrupting (Damped Newton) Globally Convergent if Jacobian is Nonsingular Difficulty with Singular Jacobians Continuation Schemes Source stepping January 11, 2017 37 courtesy Alessandra Nardi UCB Multidimensional Newton Method Convergence Problems – Local Minimum Local Minimum f At a local minimum, 0 x Multidimensional Case: J F x is singular January 11, 2017 38 courtesy Alessandra Nardi UCB Multidimensional Newton Method Convergence Problems – Nearly singular f(x) x1 x0 Must Somehow Limit the changes in X January 11, 2017 39 courtesy Alessandra Nardi UCB X Multidimensional Newton Method Convergence Problems - Overflow f(x) x X 0 1 x Must Somehow Limit the changes in X January 11, 2017 40 courtesy Alessandra Nardi UCB Newton Method with Limiting Newton Algorithm for Solving F x 0 x = Initial Guess, k 0 0 Repeat { x x F x for x limited x Compute F x k , J F x k Solve J F x k 1 x k } k k 1 k k 1 k 1 k k 1 k 1 k 1 x , F x small enough Until January 11, 2017 41 courtesy Alessandra Nardi UCB Newton Method with Limiting Limiting Methods • Direction Corrupting limited x k 1 i xik 1 if xik 1 limited x k 1 sign xik 1 otherwise x k 1 • NonCorrupting limited x k 1 x k 1 min 1, k 1 x limited x k 1 Heuristics, No Guarantee of Global Convergence January 11, 2017 42 courtesy Alessandra Nardi UCB x k 1 Newton Method with Limiting Damped Newton Scheme General Damping Scheme Solve J F x k x k 1 F x k for x k 1 x k 1 x k k x k 1 Key Idea: Line Search Pick to minimize F x x k F x x k k k 1 2 2 k k k 1 F x x k k 2 2 k 1 T F x k k x k 1 Method Performs a one-dimensional search in Newton Direction January 11, 2017 43 courtesy Alessandra Nardi UCB Newton Method with Limiting Damped Newton – Convergence Theorem If a) J F1 x k Inverse is bounded b) J F x J F y Derivative is Lipschitz Cont x y Then There exists a set of k ' s 0,1 such that F x k 1 F x k k x k 1 F xk with <1 Every Step reduces F-- Global Convergence! January 11, 2017 44 courtesy Alessandra Nardi UCB Newton Method with Limiting Damped Newton – Nested Iteration x = Initial Guess, k 0 Repeat { 0 Solve J x x F x for x Find 0,1 such that F x x Compute F x k , J F x k k k 1 k 1 k F k k k k 1 is minimized x k 1 x k k x k 1 k k 1 } Until January 11, 2017 x k 1 , F x k 1 small enough 45 courtesy Alessandra Nardi UCB Newton Method with Limiting Damped Newton – Singular Jacobian Problem x2 1 D x 1 x x 0 X Damped Newton Methods “push” iterates to local minimums Finds the points where Jacobian is Singular January 11, 2017 46 courtesy Alessandra Nardi UCB Newton with Continuation schemes Basic Concepts - General setting Newton converges given a close initial guess Idea: Generate a sequence of problems, s.t. a problem is a good initial guess for the following one F (x) 0 Solve F x , 0 where: a) F x 0 , 0 0 is easy to solve Starts the continuation b) F x 1 ,1 F x Ends the continuation c) x is sufficiently smooth Hard to insure! January 11, 2017 47 courtesy Alessandra Nardi UCB Newton with Continuation schemes Basic Concepts – Template Algorithm Solve F x 0 , 0 , x prev x 0 =0.01, While 1 { x0 x prev Try to Solve F x , 0 with Newton } If Newton Converged x prev x , , 2 Else 1 , prev 2 January 11, 2017 48 courtesy Alessandra Nardi UCB Newton with Continuation schemes Basic Concepts – Source Stepping Example January 11, 2017 49 courtesy Alessandra Nardi UCB Newton with Continuation schemes Basic Concepts – Source Stepping Example R Vs + - v Diode 1 f v , idiode v v Vs 0 R f v, v idiode v v 1 Not dependent! R Source Stepping Does Not Alter Jacobian January 11, 2017 50 courtesy Alessandra Nardi UCB Transient Analysis Flow Diagram Predict values of variables at tl Replace C and L with resistive elements via integration formula Replace nonlinear elements with G and indep. sources via NR Assemble linear circuit equations Solve linear circuit equations NO Did NR converge? YES Test solution accuracy Save solution if acceptable Select new t and compute new integration formula coeff. January 11, 2017 Done? 51 NO courtesy Alessandra Nardi UCB