Gauss-Seidel method
Gauss-Seidel is an iterative method used to solve systems of linear equations. It is named after the German mathematicians' Carl Friedrich Gauss and Philipp Ludwig von Seidel.
The Gauss-Seidel method is an iterative technique that starts with an initial guess for the solution of the system of equations and then improves that guess by updating each component of the solution vector using the current values of the other components. This process is repeated until a desired level of accuracy is achieved.
The algorithm for the Gauss-Seidel method is as follows:
- Start with an initial guess for the solution vector x.
- For each equation in the system, use the current values of the other components of x to solve for the next component of x.
- Update the value of the current component of x with the value obtained in step 2.
- Repeat steps 2 and 3 for all components of x until the desired level of accuracy is achieved.
The iteration formula for Gauss-Seidel can be written as:
x_i^{(k+1)} = (b_i - \sum_{j=1}^{i-1} a_{ij}x_j^{(k+1)} - \sum_{j=i+1}^{n} a_{ij}x_j^{(k)})/a_{ii}
where i = 1,2,...,n and k is the iteration number.
The convergence of the Gauss-Seidel method depends on the properties of the coefficient matrix of the system of equations. In general, the method converges if the matrix is diagonally dominant, which means that the absolute value of each diagonal element is greater than or equal to the sum of the absolute values of the other elements in the same row.
The Gauss-Seidel method can be computationally efficient for solving large systems of linear equations, particularly if the coefficient matrix is sparse. However, the method may not converge for all systems of equations and may converge slowly for some systems. Let us summarize and solve an example. In the following, the Matlab code is written based on the methodology. After that, a typical result is obtained based on the stoping criteria. IN the example the stoping criteria are the maximum error and maximum iteration.
Here is the result of the computation:
=================================================
1.000000 2.416667 -2.791667 7.011667 1.000000
2.000000 2.791056 -2.496515 7.006338 0.060014
3.000000 2.800539 -2.496879 7.006046 0.001195
4.000000 2.800507 -2.496891 7.006047 0.000004
5.000000 2.800507 -2.496891 7.006047 0.000000
Solution: x =
2.8005
-2.4969
7.0060
Number of iterations: 5
No comments:
Post a Comment