Download presentation
Presentation is loading. Please wait.
Published byEthelbert Dickerson Modified over 9 years ago
1
Case Study in Computational Science & Engineering - Lecture 5 1 Iterative Solution of Linear Systems Jacobi Method while not converged do { }
2
Case Study in Computational Science & Engineering - Lecture 5 2 Gauss Seidel Method while not converged do { }
3
Case Study in Computational Science & Engineering - Lecture 5 3 Stationary Iterative Methods Iterative method can be expressed as: x new =c + Mx old, where M is an iteration matrix. Jacobi: Ax = b, where A = L+D+U, i.e., (L+D+U)x = b => Dx = b - (L+U)x => x = D -1 (b-(L+U)x) = D -1 b - D -1 (L+U)x x n+1 = D -1 (b-(L+U)x n ) = c + Mx n Gauss Seidel: (L+D+U)x = b => (L+D)x = b - Ux => x n+1 = (L+D) -1 (b-Ux n ) = (L+D) -1 b - (L+D) -1 Ux n
4
Case Study in Computational Science & Engineering - Lecture 5 4 Conjugate Gradient Method A non-stationary iterative method that is very effective for symmetric positive definite matrices. The method was derived in the context of quadratic function optimization: f(x) = x T Ax - 2bx has a minimum when Ax = b Algorithm starts with initial guess and proceeds along a set of orthogonal “search” directions in successive steps. Guaranteed to reach solution (in exact arithmetic) in at most n steps for an nxn system, but in practice gets close enough to solution in far fewer iterations.
5
Case Study in Computational Science & Engineering - Lecture 5 5 Conjugate Gradient Algorithm Steps in CG algorithm in solving system Ax=y: s o = r 0 = y - Ax 0 a k = r k T r k /s k T As k x k+1 = x k + a k s k r k+1 = r k - a k As k b k+1 = r k+1 T r k+1 /r k T r k s k+1 = r k+1 + b k+1 s k s is the search direction, r is the residual vector, x is the solution vector; a and b are scalars a represents the extent of move along the search direction New search direction is the new residual plus fraction b of the old search direction.
6
Case Study in Computational Science & Engineering - Lecture 5 6 Pre-conditioning The convergence rate of an iterative method depends on the spectral properties of the matrix, i.e. the range of eigenvalues of the matrix. Convergence is not always guaranteed - for some systems the solution may diverge. Often, it is possible to improve the rate of convergence (or facilitate convergence in a diverging system) by solving an equivalent system with better spectral properties Instead of solving Ax=b, solve MAx = Mb,where M is chosen to be close to A -1. The closer MA is to the identity matrix, the faster the convergence. The product MA is not explicitly computed, but its effect incorporated via an additional matrix-vector multiplication or a triangular solve.
7
Case Study in Computational Science & Engineering - Lecture 5 7 Communication Requirements Each iteration of an iterative linear system solver requires a sparse matrix-vector multiplication Ax. A processor needs x i iff any of its rows has a nonzero in column i. P0 P1 P2 P3
8
Case Study in Computational Science & Engineering - Lecture 5 8 Communication Requirements The associated graph of a sparse matrix is very useful in determining the communication requirements for parallel sparse matrix-vector multiply. P0 P1 P2 P3 P0 P1 P2 P3 Comm required: 8 values P3P2P1P0 Alternate mapping: 5 values
9
Case Study in Computational Science & Engineering - Lecture 5 9 Minimizing communication Communication for parallel sparse matrix-vector multiplication can be minimized by solving a graph partitioning problem.
10
Case Study in Computational Science & Engineering - Lecture 5 10 Communication for Direct Solvers The communication needed for a parallel direct sparse solver is very different from that for an iterative solver. If rows are mapped to processors, comm. is reqd. between procs owning rows j and k (k>j) iff A kj is nonzero. The associated graph of thematrix is not very useful in producing a load-balanced partitioning since it does not capture the temporal dependences in the elimination process. A different graph structure called the elimination tree is useful in determining a load-balanced low-communication mapping.
11
Case Study in Computational Science & Engineering - Lecture 5 11 Elimination Tree The e-tree is a tree data structure that succintly captures the essential temporal dependences between rows during the elimination process. The parent of node j in the tree is the row# of first non-zero below diagonal in row j (using the “filled-in” matrix). If row j updates row k, k must be an ancestor in the e-tree. Row k can only be updated by a node that is in its subtree.
12
Case Study in Computational Science & Engineering - Lecture 5 12 Using the E-Tree for Mapping Recursive mapping strategy. Sub-trees that are entirely mapped to a processor need no communication between those rows. Subtrees that are mapped amongst a subset of procs only need communication among that group, e.g. rows 36 only needs comm. from P1
13
Case Study in Computational Science & Engineering - Lecture 5 13 Iterative vs. Direct Solvers Direct solvers: –Robust: not sensitive to spectral properties of matrix –User can effectively apply solver without much understanding of algorithm or properties of matrix –Best for 1D problems; very effective for many 2D problems –Significant increase in fill-in for 3D problems –More difficult to parallelize than iterative solvers; poorer scalability Iterative solvers: –No fill-in problem; no explosion of operation count for 3D problems; excellent scalability for large sparse problems –But convergence depends on eigenvalues of matrix –Preconditioners are very important; good ones usually domain-specific –The effectiveness of iterative solvers may require good understanding of mathematical properties of equations in order to derive good preconditioners
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.