Skip to main content

Gauss Jacobi Method


Gauss Jacobi Method

In numerical linear algebra, the Gauss-Jacobi method (the Jacobi iteration method) is an iterative algorithm for determining the solutions of a strictly diagonally dominant system of linear equations.

Procedure

  1. Choose an n X n matrix

Otherwise- Show Pop up – please select the number of rows equal to the number of Columns

  1. Verify that the magnitude of the diagonal item in each row of the matrix is greater than or equal to the sum of the magnitudes of all other (non-diagonal) values in that row so that

Otherwise- Show Pop up – entered matrix is not diagonally dominant

Ensure that all of the diagonal elements are non-zero as well.

aii ≠ 0

Otherwise- Show Pop up – all of the diagonal elements must be non-zero

  1. Decompose the given matrix into a diagonal matrix D, a lower triangular matrix L, and an upper triangular matrix U:

Let’s assume, A linear system of the form ��=�Ax = b

A = $\begin{bmatrix} a11 & a12 & \cdots & a1n \\ a21 & a22 & .\ .\ . & a2n \\ \vdots & \vdots & \ddots & \vdots \\ an1 & an2 & \cdots & ann \end{bmatrix}$; D = $\begin{bmatrix} a11 & 0 & \cdots & 0 \\ 0 & a22 & .\ .\ . & 0 \\ \vdots & \vdots & \ddots & \vdots \\ 0 & 0 & \cdots & ann \end{bmatrix}$;

L + U = $\begin{bmatrix} 0 & a12 & \cdots & a1n \\ a21 & 0 & .\ .\ . & a2n \\ \vdots & \vdots & \ddots & \vdots \\ an1 & an2 & \cdots & 0 \end{bmatrix}$;

Where,

A = D + L + U

D contains only the main diagonal elements of matrix A & (L + U) = A – D

  1. Consider solving a n X n (n by n) matrix then initially take a column matrix X(0) of size n X 1 containing only 1s

X(0) = $\begin{bmatrix} x1 \\ x2 \\ \vdots \\ xn \end{bmatrix}$, where, x1 = x2 = x3 = . . . = xn = 1

  1. Then calculate,

X(1) = D-1 (b – (L + U) X(0))

Or, X(1) = D-1 (b – (L + U) X(0))

D-1 or the inverse of a diagonal matrix is a diagonal matrix where the elements of the main diagonal are the reciprocals of the corresponding elements of the original diagonal matrix. Or,

D-1 = $\begin{bmatrix} 1/a11 & 0 & \cdots & 0 \\ 0 & 1/a22 & .\ .\ . & 0 \\ \vdots & \vdots & \ddots & \vdots \\ 0 & 0 & \cdots & 1/ann \end{bmatrix}$;

Then check, ||AX(1) – b|| is small or not

If ||A X1 – b|| is not small then go for the 2nd iteration

X(2) = D-1 (b – (L + U)X(1))

Continue to the next iteration if the condition is still unsatisfied

Example

Use the iterative Gauss-Jacobi method to solve the problem. There are equations

2x + y = 13

5x + 7y = 11

Taking values from the aforementioned equations, we obtain,

A = $\begin{bmatrix} 2 & 1 \\ 5 & 7 \end{bmatrix}$; b = $\begin{bmatrix} 13 \\ 11 \end{bmatrix}$;

Now, D = $\begin{bmatrix} 2 & 0 \\ 0 & 7 \end{bmatrix}$; L + U = $\begin{bmatrix} 0 & 1 \\ 5 & 0 \end{bmatrix}$;

Let’s initialize, x(0) =$\begin{bmatrix} 1 \\ 1 \end{bmatrix}$;

Then calculate,

1st iteration

X(1) = D-1 (b – (L + U)X(0))

= -D-1(L + U) X0 + D-1b

= $- \begin{bmatrix} 1/2 & 0 \\ 0 & 1/7 \end{bmatrix}\begin{bmatrix} 0 & 1 \\ 5 & 0 \end{bmatrix}$ $\begin{bmatrix} 1 \\ 1 \end{bmatrix}$ + $\begin{bmatrix} 1/2 & 0 \\ 0 & 1/7 \end{bmatrix}\begin{bmatrix} 13 \\ 11 \end{bmatrix}$

= - $\begin{bmatrix} 0 & 1/2 \\ 5/7 & 0 \end{bmatrix}\begin{bmatrix} 1 \\ 1 \end{bmatrix}$ + $\begin{bmatrix} 13/2 \\ 11/7 \end{bmatrix}$

= $\begin{bmatrix} - 1/2 \\ - 5/7 \end{bmatrix} + \ \begin{bmatrix} 13/2 \\ 11/7 \end{bmatrix}$

= $\begin{bmatrix} 6 \\ 6/7 \end{bmatrix}$

||A X(1) – b||

= ||$\begin{bmatrix} 2 & 1 \\ 5 & 7 \end{bmatrix}\begin{bmatrix} 6 \\ 6/7 \end{bmatrix}$ - $\begin{bmatrix} 13 \\ 11 \end{bmatrix}$ ||

= ||$\begin{bmatrix} 90/7 \\ 36 \end{bmatrix}$ - $\begin{bmatrix} 13 \\ 11 \end{bmatrix}||$

= ||$\begin{bmatrix} - 1/7 \\ 25 \end{bmatrix}||$

= $\sqrt[2]{\left( \frac{- 1}{7} \right)\hat{}2 + 25\hat{}2}$

= 25.0004

2nd Iteration

X(2) = D-1 (b – (L + U)X(1))

= $- \begin{bmatrix} 1/2 & 0 \\ 0 & 1/7 \end{bmatrix}\begin{bmatrix} 0 & 1 \\ 5 & 0 \end{bmatrix}$ $\begin{bmatrix} 6 \\ 6/7 \end{bmatrix}$ + $\begin{bmatrix} 1/2 & 0 \\ 0 & 1/7 \end{bmatrix}\begin{bmatrix} 13 \\ 11 \end{bmatrix}$

= - $\begin{bmatrix} 0 & 1/2 \\ 5/7 & 0 \end{bmatrix}\begin{bmatrix} 4 \\ 10/7 \end{bmatrix}$ + $\begin{bmatrix} 13/2 \\ 11/7 \end{bmatrix}$

= $\begin{bmatrix} 58/14 \\ - 19/7 \end{bmatrix}$

||AX(2) – b||

= ||$\begin{bmatrix} 2 & 1 \\ 5 & 7 \end{bmatrix}\begin{bmatrix} 58/14 \\ - 19/7 \end{bmatrix}$ - $\begin{bmatrix} 13 \\ 11 \end{bmatrix}$ ||

= ||$\begin{bmatrix} 39/7 \\ 12/7 \end{bmatrix}$ - $\begin{bmatrix} 13 \\ 11 \end{bmatrix}||$

= ||$\begin{bmatrix} - 52/7 \\ - 65/7 \end{bmatrix}||$

= $\sqrt[2]{\left( - \frac{52}{7} \right)^{2} + {( - \frac{65}{7})}^{2}}$

= 11.8915

Repeat the above iteration process until it converges, i.e. until the value of ||Ax (n) – b|| is small.

You can set a threshold value of (1e-10). If ||Ax (n) – b|| < (1e-10), the iteration loop will terminate. And initially, you can keep the total number of iterations = 1000

People are good at skipping over material they already know!

View Related Topics to







Contact Us

Name

Email *

Message *

Popular Posts

How to use MATLAB Simulink

Introduction to MATLAB Simulink MATLAB Simulink is a popular add-on of MATLAB. Here, you can use different blocks like modulator, demodulator, AWGN channel, etc. And you can do experiments on your own. Steps to Get Started 1. Go to the 'Simulink' tab at the top navbar of MATLAB. If not found, click on the add-on tab, search 'Simulink,' and then click on it to add. 2. Once you installed the simulation, click the 'new' tap at the top left corner. 3. Then, search the required blocks in the 'Simulink library.' Then, drag it to the editor space. 4. You can double-click on the blocks to see the input parameters. 5. Then, connect the blocks by dragging a line from one block's output terminal to another block's input. 6. If the connection is complete, click the 'run' tab in the middle of the top navbar. 7. After clicking on the run ...

OFDM Waveform with MATLAB Code (with Simulator)

  In OFDM (Orthogonal Frequency Division Multiplexing) , we transmit multiple orthogonal subcarriers simultaneously. Since the subcarriers are orthogonal , they do not interfere with each other, which is one of the main advantages of OFDM. Practically, OFDM converts a wideband signal into multiple narrowband orthogonal subcarriers. For typical wireless communication, if the signal bandwidth (or symbol duration) exceeds the coherence bandwidth of the channel, the signal experiences frequency-selective fading . Fading distorts the signal, making it difficult to recover the original information. By using OFDM, we transmit the same wideband signal across multiple orthogonal narrowband subcarriers, reducing the effect of fading. For example, if we want to transmit a signal of bandwidth 1024 kHz , we can divide it into N = 8 subcarriers . Each subcarrier is then spaced by: Δf = Total Bandwidth N = 1024 8 kHz...

Theoretical BER vs SNR for binary ASK, FSK, and PSK with MATLAB Code + Simulator

📘 Overview & Theory 🧮 MATLAB Codes 📚 Further Reading Bit Error Rate (BER) Equations In ASK, noise directly affects the signal amplitude, making it the most vulnerable since the data is carried in amplitude changes. In FSK, data is represented by frequency variations, and because noise typically impacts amplitude more than frequency, FSK is more robust than ASK. In PSK, data is encoded in the signal phase, and BPSK specifically uses 180-degree phase shifts, creating the greatest separation between signal points and therefore achieving the lowest bit error rate (BER) for the same power level. BER formulas for ASK, FSK, and PSK modulation schemes. ASK BER = 0.5 × erfc(0.5 × √SNR) FSK BER = 0.5 × erfc(√(SNR / 2)) PSK BER = 0.5 × erfc(√SNR) erfc / Q-func...

BER vs SNR for M-ary QAM, M-ary PSK, QPSK, BPSK, ...(MATLAB Code + Simulator)

Bit Error Rate (BER) & SNR Guide Analyze communication system performance with our interactive simulators and MATLAB tools. 📘 Theory 🧮 Simulators 💻 MATLAB Code 📚 Resources BER Definition SNR Formula BER Calculator MATLAB Comparison 📂 Explore M-ary QAM, PSK, and QPSK Topics ▼ 🧮 Constellation Simulator: M-ary QAM 🧮 Constellation Simulator: M-ary PSK 🧮 BER calculation for ASK, FSK, and PSK 🧮 Approaches to BER vs SNR What is Bit Error Rate (BER)? The BER indicates how many corrupted bits are received compared to the total number of bits sent. It is the primary figure of merit for a...

MATLAB Code for Constellation Diagram of QAM configurations such as 4, 8, 16, 32, 64, 128, and 256-QAM

📘 Overview of QAM 🧮 4-QAM MATLAB 🧮 16-QAM MATLAB 🚀 Online Simulator 📂 Other Topics on Constellation Diagrams... ▼ 🧮 MATLAB Code for 4-QAM 🧮 MATLAB Code for 16-QAM 🧮 MATLAB Code for m-ary QAM 🧮 Simulator for m-ary PSK 🧮 Simulator for m-ary QAM 🧮 Overview of Energy per Bit (Eb / N0) 🧮 Simulator for ASK, FSK, and PSK Overview of QAM One of the best-performing modulation techniques is QAM [↗] . Here, we modulate the symbols by varying the carrier signal's amplitude and phase in response to the variation in the message signal (or voltage variation). So, we may say that QAM is a combination of phase and amplitude modulation. Additionally, it performs better than ASK or PSK [↗] . In fact, any constellation for any type of modulatio...

Theoretical vs. simulated BER vs. SNR for ASK, FSK, and PSK (MATLAB Code + Simulator)

📘 Overview 🧮 Simulator 💻 Theoretical Code 📊 Simulated Code 📚 Resources Overview BER vs. SNR denotes how many bits in error are received for a given signal-to-noise ratio, typically measured in dB. Common noise types in wireless systems: 🚀 1. Additive White Gaussian Noise (AWGN) 🌊 2. Rayleigh Fading AWGN adds random noise; Rayleigh fading attenuates the signal variably. A good SNR helps reduce these effects. Bit Error Rate (BER) Equations BER formulas for ASK, FSK, and PSK modulation schemes. ASK BER = 0.5 × erfc(0.5 × √SNR) FSK BER = 0.5 × erfc(√(SNR / 2)) PSK BER = 0.5 × erfc(√SNR) erfc / Q-function (Click here) Live BER S...

FastAPI Static Files – Overview

FastAPI Static Files Often, a web application needs to include resources that do not change, even when dynamic data is rendered. These resources are called static assets . Examples of static files include: Images ( .png , .jpg ) JavaScript files ( .js ) Stylesheets ( .css ) Installing Required Library To handle static files in FastAPI, you need the aiofiles library. pip install aiofiles Mounting Static Files FastAPI uses the StaticFiles class to serve static content. You mount a folder (usually named static ) so that all files inside it can be accessed via a URL. from fastapi import FastAPI from fastapi.staticfiles import StaticFiles app = FastAPI() app.mount("/static", StaticFiles(directory="static"), name="static") Example 1: Using an Image Place an image file (for example, fa-logo.png ) inside the static folder. main.py from fastapi import FastAPI, Request from fastapi.responses import HTMLRespon...

Online Simulator for ASK, FSK, and PSK

Try our new Digital Signal Processing Simulator!   •   Interactive ASK, FSK, and BPSK tools updated for 2025. Start Now Interactive Modulation Simulators Visualize binary modulation techniques (ASK, FSK, BPSK) in real-time with adjustable carrier and sampling parameters. 📡 ASK Simulator 📶 FSK Simulator 🎚️ BPSK Simulator 📚 More Topics ASK Modulator FSK Modulator BPSK Modulator More Topics Simulator for Binary ASK Modulation Digital Message Bits Carrier Freq (Hz) Sampl...