Skip to main content

Coherence Bandwidth and Coherence Time (with MATLAB + Simulator)



For Doppler Delay or Multi-path Delay

Coherence time
Tcoh ∝ 1 / vmax (For slow fading, coherence time Tcoh is greater than the signaling interval.)

Coherence bandwidth
Wcoh ∝ 1 / Ï„max (For frequency-flat fading, coherence bandwidth Wcoh is greater than the signaling bandwidth.)


Where:

  • Tcoh = coherence time
  • Wcoh = coherence bandwidth
  • vmax = maximum Doppler frequency (or maximum Doppler shift)
  • Ï„max = maximum excess delay (maximum time delay spread)

Notes:

  • The notation vmax−1 and Ï„max−1 indicate inverse proportionality.
  • Doppler spread refers to the range of frequency shifts caused by relative motion, determining Tcoh.
  • Delay spread (or multipath delay spread) determines Wcoh.
  • Frequency-flat fading occurs when Wcoh is greater than the signaling bandwidth.

Coherence Bandwidth

Coherence bandwidth is a concept in wireless communication and signal processing that relates to the frequency range over which a wireless channel remains approximately constant in terms of its characteristics.

Coherence bandwidth is inversely related to the delay spread time (e.g., RMS delay spread). The coherence bandwidth is related to the delay spread of the channel, which is a measure of the time it takes for signals to traverse the channel due to multipath. The two are related by the following approximation:

Coherence Bandwidth ≈ 1/(delay spread time)

Or, Coherence Bandwidth ≈ 1/(root-mean-square delay spread time)

(Coherence bandwidth in Hertz)

For instance, if the root-mean-square delay spread is 500 ns (i.e., {1/(2*10^6)} seconds), the coherence bandwidth is approximately 2 MHz (1 / 500e-9) in a household indoor environment.

For narrowband approximation:

Coherence Bandwidth ≈ 1/root-mean-square delay spread time

 

Frequency Auto-correlation Function

The frequency auto-correlation function RH(Δf) of the channel transfer function H(f) is defined as:

RH(Δf) = E{H(f)H*(f+Δf)}

E{⋅} denotes the expectation operator, and H*(f) is the complex conjugate of H(f).

  • The Coherence Bandwidth (B_c) is precisely derived from this function. It's defined as the maximum Δf for which R_H(Δf) remains above a certain threshold (e.g., 0.5 or 1/e of its peak value).

  • This threshold indicates the point where the channel response at f and f + Δf becomes sufficiently "uncorrelated" or "different" that they can no longer be considered "coherently" related.

 

Coherence Bandwidth Definition

The coherence bandwidth is often defined as the frequency separation Δf over which the auto-correlation function RH(Δf) drops to a certain fraction of its maximum value, typically 0.5 or 1/e:

Bc ≈ 1 / (β * Tm)

Where Tm is the root-mean-square delay spread time, which characterizes the extent of multi-path propagation, and β is a constant (e.g., 5 for a 0.5 correlation drop or 2π for other definitions).

 

Coherence Time

Coherence time represents the duration for which the channel conditions remain approximately constant. It describes the amount of time during which the wireless channel's characteristics, including phase, amplitude, and delay, can be considered relatively stable.

The relationship between coherence time and Doppler spread is inverse. A larger Doppler spread (faster change) corresponds to a shorter coherence time and vice versa.

 

Time Auto-correlation Function

The time auto-correlation function Rh(Δt) of the channel impulse response h(t) is defined as:

Rh(Δt) = E{h(t)h*(t+Δt)}

E{⋅} denotes the expectation operator, and h*(t) is the complex conjugate of h(t).

  • The Coherence Time (T_c) is precisely derived from this function. It's defined as the maximum Δt for which R_H(Δt) remains above a certain threshold (e.g., 0.5 or 1/e of its peak value).

  • This threshold indicates the point where the channel response at t and t + Δt becomes sufficiently "uncorrelated" or "different" that they can no longer be considered "coherently" related.

 

Coherence Time Definition

The coherence time is often defined as the time lag Δt over which the auto-correlation function Rh(Δt) drops to a certain fraction of its maximum value, typically 0.5 or 1/e:

Tc ≈ 1 / fD

Where fD is the Doppler spread, which characterizes the rate of change of the channel due to relative motion.

If a vehicle is moving at 30 m/s and the carrier frequency is 2 GHz:

fD = v * f / c = (30 * 2 * 10^9) / (3 * 10^8) = 200 Hz

So, the coherence time using the general approximation is 1 / (200) = 5 ms (approx).

 

MATLAB Code Example for Approximating Coherence Time and Bandwidth

% The code is written by SalimWireless.Com
clc;
clear all;
close all;

% Example: Define Doppler Spread and RMS Delay Spread directly for approximation
% (In a real scenario, these would be measured or estimated from channel data)

% --- Parameters for Coherence Time ---
vehicle_speed = 30; % m/s
carrier_frequency = 2e9; % Hz (2 GHz)
speed_of_light = 3e8; % m/s

doppler_spread = (vehicle_speed * carrier_frequency) / speed_of_light; % Hz

% Approximate Coherence Time (Tc ~ 1/fD)
coherence_time_approx = 1 / doppler_spread; % seconds

disp(['Doppler Spread (fD): ', num2str(doppler_spread), ' Hz']);
disp(['Approximate Coherence Time (Tc): ', num2str(coherence_time_approx), ' seconds']);

% --- Parameters for Coherence Bandwidth ---
rms_delay_spread = 500e-9; % seconds (e.g., 500 ns)

% Approximate Coherence Bandwidth (Bc ~ 1/rms_delay_spread, using a common factor like 1/5)
% A typical constant 'beta' is often used, for example, 5 for 0.5 correlation drop
beta_for_Bc = 5;
coherence_bandwidth_approx = 1 / (beta_for_Bc * rms_delay_spread); % Hz

disp(['RMS Delay Spread (Tm): ', num2str(rms_delay_spread), ' seconds']);
disp(['Approximate Coherence Bandwidth (Bc): ', num2str(coherence_bandwidth_approx), ' Hz']);
 

Output from the MATLAB Code above

Doppler Spread (fD): 200 Hz

Approximate Coherence Time (Tc): 0.005 seconds

RMS Delay Spread (Tm): 5e-07 seconds

Approximate Coherence Bandwidth (Bc): 400000 Hz

 

Relationship between Coherence Time and Doppler Spread, and Coherence Bandwidth and Delay Spread

The coherence time of a wireless channel is inversely proportional to its Doppler spread. Doppler spread refers to the range of Doppler shifts experienced by different multipath components, indicating how rapidly the channel changes due to motion.

Conversely, the coherence bandwidth of a wireless channel is inversely proportional to its delay spread. Delay spread refers to the time difference between the arrival of the first and last significant multipath components of a signal, indicating the frequency selectivity of the channel.

The relationship between coherence time (Tc) and Doppler spread (fD) can be approximated using the formula:

Tc ≈ 1 / fD

And for coherence bandwidth (Bc) and delay spread (Tm):

Bc ≈ 1 / (β ⋅ Tm)

Where β is a factor depending on the specific characteristics of the wireless environment and the correlation level considered, typically ranging from 1 to 5 or 2π.

 

MATLAB Code Example for Coherence Time Approximation (based on Doppler Spread)

% The code is written by SalimWireless.Com
clc;
clear all;
close all;

% Define parameters for Doppler Spread
vehicle_speed = 30; % m/s
carrier_frequency = 2e9; % Hz (2 GHz)
speed_of_light = 3e8; % m/s

% Calculate Doppler spread
doppler_spread = (vehicle_speed * carrier_frequency) / speed_of_light;

% Calculate coherence time using approximation
coherence_time = 1 / doppler_spread;

% Display coherence time
disp(['Calculated Doppler Spread (fD): ', num2str(doppler_spread), ' Hz']);
disp(['Approximate Coherence Time (Tc): ', num2str(coherence_time), ' seconds']);
 

Output from the MATLAB Code above

Calculated Doppler Spread (fD): 200 Hz

Approximate Coherence Time (Tc): 0.005 seconds

 

Further Reading

  1. Relationship Between Fading, Coherence Time, and Coherence Bandwidth
  2. Coherence Bandwidth Online Simulator
     
  3. Example of coherence time in wireless communication
  4. Further study on time-bandwidth product
  5. Slow fading vs. fast fading
  6. Flat fading vs. Frequency Selective fading 

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 ...

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...

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...

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...

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...