Gaussian elimination, with some improvements, is the basis of most numerical routines to solve systems of linear equations. Its rationale is that the following system is easy to solve:
data:image/s3,"s3://crabby-images/51951/5195173ab1d2737d3d8be838b8dfbe6687cd3683" alt="images"
Such a system is said to be in upper triangular form, as nonzero coefficients form a triangle in the upper part of the layout. A system in upper triangular form is easy to solve by a process called backsubstitution. From the last equation, we immediately obtain
data:image/s3,"s3://crabby-images/fe2af/fe2afe9f3e48b092c726ce468dbdd5749a1673ff" alt="images"
Then, we plug this value into the second-to-last (penultimate) equation:
data:image/s3,"s3://crabby-images/fa94f/fa94f9924406cfff577f4eab6d40273a155bc70b" alt="images"
In general, we proceed backward as follows:
data:image/s3,"s3://crabby-images/d776c/d776cde541ff7adc83643603cf1260042050d6e5" alt="images"
Now, how can we transform a generic system into this nice triangular form? To get a system in triangular form, we form combinations of equations in order to eliminate some coefficients from some equations, according to a systematic pattern. Starting from the system in its original form
data:image/s3,"s3://crabby-images/1f3d0/1f3d0544720023ba15514d9105926d4d5269053b" alt="images"
where (Ek) denotes the kth equation, k = 1, …, n, we would like to get an equivalent system featuring a column of zeros under the coefficient a11. By “equivalent” system we mean a new system that has the same solution as the first one. If we multiply equations by some number, we do not change their solution; by the same token, if we add equations, we do not change the solution of the overall system.
For each equation (Ek) (k = 2, …, n), we must apply the transformation
data:image/s3,"s3://crabby-images/cc53d/cc53d74700181ceb3fc1cd58c04e6cd90b924e56" alt="images"
which leads to the equivalent system:
data:image/s3,"s3://crabby-images/372bc/372bc5b22a011671d987d03c9c581da7d1d7a989" alt="images"
Now we may repeat the procedure to obtain a column of zeros under the coefficient , and so on, until the desired form is obtained, allowing for backsubstitution. The idea is best illustrated by a simple example.
Example 3.2 Consider the following system:
data:image/s3,"s3://crabby-images/bdec4/bdec4b572a08db90f602596ee8b69a8be3e16110" alt="images"
It is convenient to represent the operations of Gaussian elimination in a tabular form, which includes both the coefficients in each equation and the related right-hand side:
data:image/s3,"s3://crabby-images/9f2a2/9f2a26061b30c073088a978e300fc0df28624f93" alt="images"
It is easy to apply backsubstitution to this system in triangular form, and we find x3 = 1, x2 = −1, and x1= 1
Gaussian elimination is a fairly straightforward approach, but it involves a few subtle issues:
- To begin with, is there anything that could go wrong? The careful reader, we guess, has already spotted a weak point in Eq. (3.5): What if akk = 0? This issue is easily solved, provided that the system admits a solution. We may just swap two equations or two variables. If you prefer, we might just swap two rows or two columns in the tabular form above.
- What about numerical precision if we have a large-scale system? Is it possible that small errors due to limited precision in the calculation creep into the solution process and ultimately lead to a very inaccurate solution? This is a really thorny issue, which is way outside the scope. Let us just say that state-of-the-art commercial software is widely available to tackle such issues in the best way, which means avoiding or minimizing the difficulty if possible, or warning the user otherwise.
Leave a Reply