49
Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular, and tridiagonal. Knowing how to perform matrix multiplication and being able to assess when it is feasible. Knowing how to represent a system of linear equations in matrix form. Knowing how to solve linear algebraic equations with left division and matrix inversion in MATLAB.

Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Embed Size (px)

Citation preview

Page 1: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Chapter 8 Objectives

• Understanding matrix notation.• Being able to identify the following types of

matrices: identify, diagonal, symmetric, triangular, and tridiagonal.

• Knowing how to perform matrix multiplication and being able to assess when it is feasible.

• Knowing how to represent a system of linear equations in matrix form.

• Knowing how to solve linear algebraic equations with left division and matrix inversion in MATLAB.

Page 2: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Overview

• A matrix consists of a rectangular array of elements represented by a single symbol (example: [A]).

• An individual entry of a matrix is an element (example: a23)

Page 3: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Overview (cont)

• A horizontal set of elements is called a row and a vertical set of elements is called a column.

• The first subscript of an element indicates the row while the second indicates the column.

• The size of a matrix is given as m rows by n columns, or simply m by n (or m x n).

• 1 x n matrices are row vectors.• m x 1 matrices are column vectors.

Page 4: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Special Matrices

• Matrices where m=n are called square matrices.• There are a number of special forms of square

matrices:

Symmetric

A 5 1 2

1 3 7

2 7 8

Diagonal

A a11

a22

a33

Identity

A 1

1

1

Upper Triangular

A a11 a12 a13

a22 a23

a33

Lower Triangular

A a11

a21 a22

a31 a32 a33

Banded

A

a11 a12

a21 a22 a23

a32 a33 a34

a43 a44

Page 5: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Matrix Operations

• Two matrices are considered equal if and only if every element in the first matrix is equal to every corresponding element in the second. This means the two matrices must be the same size.

• Matrix addition and subtraction are performed by adding or subtracting the corresponding elements. This requires that the two matrices be the same size.

• Scalar matrix multiplication is performed by multiplying each element by the same scalar.

Page 6: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Matrix Multiplication

• The elements in the matrix [C] that results from multiplying matrices [A] and [B] are calculated using:

c ij aikbkjk1

n

Page 7: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Matrix Inverse and Transpose

• The inverse of a square, nonsingular matrix [A] is that matrix which, when multiplied by [A], yields the identity matrix.– [A][A]-1=[A]-1[A]=[I]

• The transpose of a matrix involves transforming its rows into columns and its columns into rows.– (aij)T=aji

Page 8: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Representing Linear Algebra

• Matrices provide a concise notation for representing and solving simultaneous linear equations:

a11x1 a12x2 a13x3 b1

a21x1 a22x2 a23x3 b2

a31x1 a32x2 a33x3 b3

a11 a12 a13

a21 a22 a23

a31 a32 a33

x1

x2

x3

b1

b2

b3

[A]{x} {b}

Page 9: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Solving With MATLAB

• MATLAB provides two direct ways to solve systems of linear algebraic equations [A]{x}={b}:– Left-divisionx = A\b

– Matrix inversionx = inv(A)*b

• The matrix inverse is less efficient than left-division and also only works for square, non-singular systems.

Page 10: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Chapter 9 Objectives

• Knowing how to solve small sets of linear equations with the graphical method and Cramer’s rule.

• Understanding how to implement forward elimination and back substitution as in Gauss elimination.

• Understanding how to count flops to evaluate the efficiency of an algorithm.

• Understanding the concepts of singularity and ill-condition.• Understanding how partial pivoting is implemented and how

it differs from complete pivoting.• Recognizing how the banded structure of a tridiagonal

system can be exploited to obtain extremely efficient solutions.

Page 11: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Graphical Method

• For small sets of simultaneous equations, graphing them and determining the location of the intercept provides a solution.

Page 12: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Graphical Method (cont)

• Graphing the equations can also show systems where:

a) No solution exists

b) Infinite solutions exist

c) System is ill-conditioned

Page 13: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Determinants

• The determinant D=|A| of a matrix is formed from the coefficients of [A].

• Determinants for small matrices are:

• Determinants for matrices larger than 3 x 3 can be very complicated.

11 a11 a11

2 2a11 a12

a21 a22

a11a22 a12a21

33

a11 a12 a13

a21 a22 a23

a31 a32 a33

a11

a22 a23

a32 a33

a12

a21 a23

a31 a33

a13

a21 a22

a31 a32

Page 14: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Cramer’s Rule

• Cramer’s Rule states that each unknown in a system of linear algebraic equations may be expressed as a fraction of two determinants with denominator D and with the numerator obtained from D by replacing the column of coefficients of the unknown in question by the constants b1, b2, …, bn.

Page 15: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Cramer’s Rule Example

• Find x2 in the following system of equations:

• Find the determinant D

• Find determinant D2 by replacing D’s second column with b

• Divide

0.3x1 0.52x2 x3 0.01

0.5x1 x2 1.9x3 0.67

0.1x1 0.3x2 0.5x3 0.44

D0.3 0.52 1

0.5 1 1.9

0.1 0.3 0.5

0.31 1.9

0.3 0.5 0.52

0.5 1.9

0.1 0.51

0.5 1

0.1 0.4 0.0022

D2 0.3 0.01 1

0.5 0.67 1.9

0.1 0.44 0.5

0.30.67 1.9

0.44 0.5 0.01

0.5 1.9

0.1 0.51

0.5 0.67

0.1 0.440.0649

x2 D2

D

0.0649

0.0022 29.5

Page 16: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Naïve Gauss Elimination

• For larger systems, Cramer’s Rule can become unwieldy.

• Instead, a sequential process of removing unknowns from equations using forward elimination followed by back substitution may be used - this is Gauss elimination.

• “Naïve” Gauss elimination simply means the process does not check for potential problems resulting from division by zero.

Page 17: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Naïve Gauss Elimination (cont)• Forward elimination

– Starting with the first row, add or subtract multiples of that row to eliminate the first coefficient from the second row and beyond.

– Continue this process with the second row to remove the second coefficient from the third row and beyond.

– Stop when an upper triangular matrix remains.

• Back substitution– Starting with the last row, solve for the

unknown, then substitute that value into the next highest row.

– Because of the upper-triangular nature of the matrix, each row will contain only one more unknown.

Page 18: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Naïve Gauss Elimination Program

Page 19: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Gauss Program Efficiency

• The execution of Gauss elimination depends on the amount of floating-point operations (or flops). The flop count for an n x n system is:

• Conclusions:– As the system gets larger, the computation time increases greatly.– Most of the effort is incurred in the elimination step.

ForwardElimination

2n3

3O n2

BackSubstitution n2 O n

Total2n3

3O n2

Page 20: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Pivoting

• Problems arise with naïve Gauss elimination if a coefficient along the diagonal is 0 (problem: division by 0) or close to 0 (problem: round-off error)

• One way to combat these issues is to determine the coefficient with the largest absolute value in the column below the pivot element. The rows can then be switched so that the largest element is the pivot element. This is called partial pivoting.

• If the rows to the right of the pivot element are also checked and columns switched, this is called complete pivoting.

Page 21: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Partial Pivoting Program

Page 22: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Tridiagonal Systems

• A tridiagonal system is a banded system with a bandwidth of 3:

• Tridiagonal systems can be solved using the same method as Gauss elimination, but with much less effort because most of the matrix elements are already 0.

f1 g1

e2 f2 g2

e3 f3 g3

en 1 fn 1 gn 1

en fn

x1

x2

x3

xn 1

xn

r1r2r3rn 1

rn

Page 23: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Tridiagonal System Solver

Page 24: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Chapter 10 Objectives

• Understanding that LU factorization involves decomposing the coefficient matrix into two triangular matrices that can then be used to efficiently evaluate different right-hand-side vectors.

• Knowing how to express Gauss elimination as an LU factorization.

• Given an LU factorization, knowing how to evaluate multiple right-hand-side vectors.

• Recognizing that Cholesky’s method provides an efficient way to decompose a symmetric matrix and that the resulting triangular matrix and its transpose can be used to evaluate right-hand-side vectors efficiently.

• Understanding in general terms what happens when MATLAB’s backslash operator is used to solve linear systems.

Page 25: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

LU Factorization

• Recall that the forward-elimination step of Gauss elimination comprises the bulk of the computational effort.

• LU factorization methods separate the time-consuming elimination of the matrix [A] from the manipulations of the right-hand-side [b].

• Once [A] has been factored (or decomposed), multiple right-hand-side vectors can be evaluated in an efficient manner.

Page 26: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

LU Factorization

• LU factorization involves two steps:– Factorization to decompose

the [A] matrix into a product of a lower triangular matrix [L] and an upper triangular matrix [U]. [L] has 1 for each entry on the diagonal.

– Substitution to solve for {x}

• Gauss elimination can be implemented using LU

factorization

Page 27: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Gauss Elimination asLU Factorization

• [A]{x}={b} can be rewritten as [L][U]{x}={b} using LU factorization.

• The LU factorization algorithm requires the same total flops as for Gauss elimination.

• The main advantage is once [A] is decomposed, the same [L] and [U] can be used for multiple {b} vectors.

• MATLAB’s lu function can be used to generate the [L] and [U] matrices:

[L, U] = lu(A)

Page 28: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Gauss Elimination asLU Factorization (cont)

• To solve [A]{x}={b}, first decompose [A] to get [L][U]{x}={b}

• Set up and solve [L]{d}={b}, where {d} can be found using forward substitution.

• Set up and solve [U]{x}={d}, where {x} can be found using backward substitution.

• In MATLAB:[L, U] = lu(A)d = L\bx = U\d

Page 29: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Cholesky Factorization

• Symmetric systems occur commonly in both mathematical and engineering/science problem contexts, and there are special solution techniques available for such systems.

• The Cholesky factorization is one of the most popular of these techniques, and is based on the fact that a symmetric matrix can be decomposed as [A]= [U]T[U], where T stands for transpose.

• The rest of the process is similar to LU decomposition and Gauss elimination, except only one matrix, [U], needs to be stored.

Page 30: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

MATLAB

• MATLAB can perform a Cholesky factorization with the built-in chol command:

U = chol(A)• MATLAB’s left division operator \ examines the

system to see which method will most efficiently solve the problem. This includes trying banded solvers, back and forward substitutions, Cholesky factorization for symmetric systems. If these do not work and the system is square, Gauss elimination with partial pivoting is used.

Page 31: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Chapter 11 Objectives

• Knowing how to determine the matrix inverse in an efficient manner based on LU factorization.

• Understanding how the matrix inverse can be used to assess stimulus-response characteristics of engineering systems.

• Understanding the meaning of matrix and vector norms and how they are computed.

• Knowing how to use norms to compute the matrix condition number.

• Understanding how the magnitude of the condition number can be used to estimate the precision of solutions of linear algebraic equations.

Page 32: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Matrix Inverse

• Recall that if a matrix [A] is square, there is another matrix [A]-1, called the inverse of [A], for which [A][A]-1=[A]-1[A]=[I]

• The inverse can be computed in a column by column fashion by generating solutions with unit vectors as the right-hand-side constants:

A x1 100

A x2

010

A x3

001

A 1 x1 x2 x3

Page 33: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Matrix Inverse (cont)

• Recall that LU factorization can be used to efficiently evaluate a system for multiple right-hand-side vectors - thus, it is ideal for evaluating the multiple unit vectors needed to compute the inverse.

Page 34: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Stimulus-Response Computations

• Many systems can be modeled as a linear combination of equations, and thus written as a matrix equation:

• The system response can thus be found using the matrix inverse.

Interactions response stimuli

Page 35: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Vector and Matrix Norms

• A norm is a real-valued function that provides a measure of the size or “length” of multi-component mathematical entities such as vectors and matrices.

• Vector norms and matrix norms may be computed differently.

Page 36: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Vector Norms

• For a vector {X} of size n, the p-norm is:

• Important examples of vector p-norms include:

p1:sum of the absolute values X1 xii1

n

p2 :Euclidian norm (length) X2 X

e xi

2

i1

n

p :maximum magnitude X

1inmax xi

Xp x i

p

i1

n

1/ p

Page 37: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Matrix Norms

• Common matrix norms for a matrix [A] include:

• Note - max is the largest eigenvalue of [A]T[A].

column - sum norm A1

1jnmax aij

i1

n

Frobenius norm Af aij

2

j1

n

i1

n

row - sum norm A

1inmax aij

j1

n

spectral norm (2 norm) A

2 max 1/2

Page 38: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Matrix Condition Number

• The matrix condition number Cond[A] is obtained by calculating Cond[A]=||A||·||A-1||

• In can be shown that:

• The relative error of the norm of the computed solution can be as large as the relative error of the norm of the coefficients of [A] multiplied by the condition number.

• If the coefficients of [A] are known to t digit precision, the solution [X] may be valid to onlyt-log10(Cond[A]) digits.

XX

Cond A AA

Page 39: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

MATLAB Commands

• MATLAB has built-in functions to compute both norms and condition numbers:– norm(X,p)

• Compute the p norm of vector X, where p can be any number, inf, or ‘fro’ (for the Euclidean norm)

– norm(A,p)• Compute a norm of matrix A, where p can be 1, 2, inf, or ‘fro’

(for the Frobenius norm)

– cond(X,p) or cond(A,p)• Calculate the condition number of vector X or matrix A using the

norm specified by p.

Page 40: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Chapter 12 Objectives

• Understanding the difference between the Gauss-Seidel and Jacobi methods.

• Knowing how to assess diagonal dominance and knowing what it means.

• Recognizing how relaxation can be used to improve convergence of iterative methods.

• Understanding how to solve systems of nonlinear equations with successive substitution and Newton-Raphson.

Page 41: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Gauss-Seidel Method

• The Gauss-Seidel method is the most commonly used iterative method for solving linear algebraic equations [A]{x}={b}.

• The method solves each equation in a system for a particular variable, and then uses that value in later equations to solve later variables. For a 3x3 system with nonzero elements along the diagonal, for example, the jth iteration values are found from the j-1th iteration using:

x1j b1 a12x2

j 1 a13x3j 1

a11

x2j b2 a21x1

j a23x3j 1

a22

x3j b3 a31x1

j a32x2j

a33

Page 42: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Jacobi Iteration

• The Jacobi iteration is similar to the Gauss-Seidel method, except the j-1th information is used to update all variables in the jth iteration:

a) Gauss-Seidel

b) Jacobi

Page 43: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Convergence

• The convergence of an iterative method can be calculated by determining the relative percent change of each element in {x}. For example, for the ith element in the jth iteration,

• The method is ended when all elements have converged to a set tolerance.

a,i xij xi

j 1

xij 100%

Page 44: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Diagonal Dominance

• The Gauss-Seidel method may diverge, but if the system is diagonally dominant, it will definitely converge.

• Diagonal dominance means:

aii aijj1ji

n

Page 45: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

MATLAB Program

Page 46: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Relaxation

• To enhance convergence, an iterative program can introduce relaxation where the value at a particular iteration is made up of a combination of the old value and the newly calculated value:

where is a weighting factor that is assigned a value between 0 and 2.– 0<<1: underrelaxation =1: no relaxation– 1<≤2: overrelaxation

xinew xi

new 1 xiold

Page 47: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Nonlinear Systems

• Nonlinear systems can also be solved using the same strategy as the Gauss-Seidel method - solve each system for one of the unknowns and update each unknown using information from the previous iteration.

• This is called successive substitution.

Page 48: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

Newton-Raphson

• Nonlinear systems may also be solved using the Newton-Raphson method for multiple variables.

• For a two-variable system, the Taylor series approximation and resulting Newton-Raphson equations are:

f1,i1 f1,i x1,i1 x1,i f1,i

x1

x2,i1 x2,i f1,i

x2

x1,i1 x1,i f1,i

f2,i

x2

f2,i

f1,i

x2

f1,i

x1

f2,i

x2

f1,i

x2

f2,i

x1

f2,i1 f2,i x1,i1 x1,i f2,i

x1

x2,i1 x2,i f2,i

x2

x2,i1 x2,i f2,i

f1,i

x1

f1,i

f2,i

x1

f1,i

x1

f2,i

x2

f1,i

x2

f2,i

x1

Page 49: Chapter 8 Objectives Understanding matrix notation. Being able to identify the following types of matrices: identify, diagonal, symmetric, triangular,

MATLAB Program