Algorithm Deep Dive: Fixed-Point Iteration Methods

The Mathematical Backbone of Modern Solvers for MDO

Understanding Fixed-Point Iteration Methods

In Multidisciplinary Design Optimization, optimizing highly coupled systems requires specialised solvers like Nonlinear Block Jacobi or Nonlinear Block Gauss-Seidel. These advanced algorithms can be difficult to understand without grasping their foundational concept: the fixed-point iteration method.

Despite its simplicity, fixed-point iteration underpins many modern solvers used in numerical analysis to solve linear and nonlinear systems of equations. In this third instalment of the Algorithm Deep Dive series, we’ll explore how fixed-point iteration works and why it’s essential for modern optimization methods.

Curious about other algorithms? Check out our previous articles in this series:

The Basics of Fixed-Point Iteration: A Simple Example

Suppose you want to solve the following equation:

    \[\cos(x) = x\]

The solution is the value of x that satisfies the equation. However, this equation doesn’t lend itself to straightforward manipulation for a direct solution. A more natural and instinctive approach is to test different values for x. For example, substituting x=2 gives \cos(2) \approx -0.416, but that’s clearly not the solution.

What about x = -0.416? Substituting it yields \cos(-0.416) \approx 0.915. We’re still not there, but upon repeating the process for a few more times, we see that the result can actually lead to the solution! Precisely, after 16 iterations, the value of x settles at around 0.739, satisfying the equation \cos(0.739) = 0.739

Applying fixed-point iteration to ???(?) = ?
Applying fixed-point iteration to \cos(x) = x, created by author using Canva

The value 0.739 is known as a fixed point of the cosine function. Conceptually, we can visualise the function alongside the line y = x. The process of iteratively updating x can be represented by the cobweb-like trajectory, where we begin from y = x and converge to the solution at x \approx 0.739.

Fixed-point iteration trajectory of ???(?) = ?
Fixed-point iteration trajectory of ???(?) = ?, created by author using matplotlib

Solving Systems of Equations with Fixed Point Iteration

The previous example demonstrates how fixed-point iteration works in a simple case. But how can we generalise this to solve systems of equations? The key is to rearrange the function into the form g(x) = x, where we can substitute x into the function g in order to get an update in x and repeat the process again.

For linear systems, this target form is often written as:

    \[u_{k+1}=G(u_k)\]

Here, u represents the vector of variables, and G is a function derived from the system matrix. The subscripts k and k+1 represent the current and next iterations respectively.

In this section, we’ll introduce two methods, Jacobi and Gauss-Seidel, which utilise the fixed-point iteration concept by reformulating a linear system into the above target form to solve it efficiently.

The Jacobi Algorithm

Given the general form of a linear system of equations:

    \[Au = b\]

Where A and b are matrix and vector of some known values respectively, and u is the vector of variables that we are trying to solve for.

The Jacobi algorithm works by splitting A into a diagonal matrix R and a matrix D with zeros on the diagonal:

Splitting of matrix ? in the Jacobi method
Splitting of matrix ? in the Jacobi method, created by author using Canva

Substituting into Au=b and rearranging gives:

    \[u = D^{-1}(b-Ru)\]

Since D is a diagonal matrix, its inverse is easy to compute. The Jacobi method updates u iteratively by calculating the new u based on the previous u, following the fixed-iteration framework.

The Gauss-Seidel Algorithm

The Gauss-Seidel algorithm takes a slightly different approach. Instead of splitting A into a diagonal matrix, it splits A into upper and lower triangular matrices U and L:

Splitting of matrix ? in the Gauss-Seidel method
Splitting of matrix ? in the Gauss-Seidel method, created by author using Canva

This gives the iteration form:

    \[Lu = b - Uu\]

Unlike Jacobi, Gauss-Seidel updates the variables one at a time, using the most recent values of the other variables as soon as they become available, which typically results in faster convergence.

Some Notes on Convergence

In the case of \cos(x) = x, the fixed point is attracting, meaning nearby starting points converge toward the solution. However, not all fixed points are attracting. For instance, the fixed point in the function f(x) = 1 - 2x - 5x^5 can repel, causing divergence during iteration.

Fixed-point iteration trajectory of ?(?) = ? ? ?? ? ???
Fixed-point iteration trajectory of f(x) = 1 - 2x - 5x^5, created by author using matplotlib

For linear systems, convergence is guaranteed if the matrix A is diagonally dominant, meaning the magnitude of the diagonal elements is larger than the off-diagonal elements in the same row. Pivoting, which reorders rows or columns to achieve diagonal dominance, can help ensure convergence and is often built into numerical solvers.

For nonlinear systems, convergence is less predictable. Factors such as the system’s nonlinearity, coupling strength, and initial guess play significant roles. Techniques like relaxation or under-relaxation can sometimes improve convergence in difficult cases.

Conclusions

Fixed-point iteration is a foundational concept in numerical solvers, especially for Multidisciplinary Design Optimization. Although the process may appear mindless, it eventually works given the right conditions of an attracting fixed point.

This method offers several key benefits, the most notable one being its simplicity. Fixed-point iteration transforms complex equations into a straightforward iterative process that can be applied repeatedly until convergence is achieved. Unlike direct solvers, which provide an exact solution only at the end, fixed-point iteration allows users to monitor progress and trade between computational cost and precision as needed.

In this article, we explored two key fixed-point algorithms — Jacobi and Gauss-Seidel. While both follow a similar iterative procedure, Gauss-Seidel generally offers faster convergence due to its update strategy.

Understanding these solvers is crucial in optimization tasks, helping engineers recognise limitations, improve performance, and diagnose irregularities. I hope this deep dive has been useful!

If you have suggestions for other algorithms you’d like to see covered, feel free to leave a comment!

At OptimiSE Academy, we’re excited to announce our upcoming microcourse on Optimization Mathematics. This course provides an intuitive foundation for design optimization. Sign up for the waitlist here!

Leave a Reply

Your email address will not be published. Required fields are marked *