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 

Contact Us

Name

Email *

Message *

Popular Posts

Rayleigh vs Rician Fading (with MATLAB + Simulator)

  In Rayleigh fading , the channel coefficients tend to have a Rayleigh distribution, which is characterized by a random phase and magnitude with an exponential distribution. This means the magnitude of the channel coefficient follows an exponential distribution with a mean of 1. In Rician fading , there is a dominant line-of-sight component in addition to the scattered components. The channel coefficients in Rician fading can indeed tend towards 1, especially when the line-of-sight component is strong. When the line-of-sight component dominates, the Rician fading channel behaves more deterministically, and the channel coefficients may tend towards the value of the line-of-sight component, which could be close to 1.   MATLAB Script clc; clear all; close all; % Define parameters numSamples = 1000; % Number of samples K_factor = 5; % K-factor for Rician fading SNR_dB = 20; % Signal-to-noise ratio (in dB) % Generate complex Gaussian random variable for Rayleigh fading channel h_r...

UGC-NET Electronic Science Question Paper With Answer Key and Full Explanation [Dec 2023]

    UGC-NET Electronic Science Question Paper With Answer Key Download Pdf [Dec 2023] Download Question Paper               See Answers   2025 | 2024 | 2023 | 2022 | 2021 | 2020 UGC-NET Electronic Science  2023 Answers with Explanations 51. (A): The stacking fault is the most common area defect found in silicon. These faults typically occur along the 111 plane. In the crystalline structure of silicon, atoms are arranged in a specific pattern known as a diamond lattice. A stacking fault refers to a disruption in the normal order of atomic layers within this lattice, which usually occurs in the 111 plane due to the geometric arrangement of the atoms. This type of defect can affect the electrical and mechanical properties of the material, such as the mobility of charge carriers and mechanical strength. 52. (C): The important figure of merit for the microwave application of a Schot...

UGC NET Electronic Science Previous Year Question Papers

Home / Engineering & Other Exams / UGC NET 2022 PYQ 📥 Download UGC NET Electronics PDFs Complete collection of previous year question papers, answer keys and explanations for Subject Code 88. Start Downloading UGC-NET (Electronics Science, Subject code: 88) Subject_Code : 88; Department : Electronic Science; 📂 View All Question Papers Q. UGC Net Electronic Science Question Paper [June 2025] A. UGC Net Electronic Science Question Paper With Answer Key Download Pdf [June 2025] with full explanation Q. UGC Net Electronic Science Question Paper [December 2024] A. UGC Net Electronic Science Question Paper With Answer Key Download Pdf [December 2024] Q. UGC Net Electronic Science Question Paper [Aug 2024] A. UGC Net Electronic Scien...

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

Constellation Diagrams of ASK, PSK, and FSK (with MATLAB Code + Simulator)

Constellation Diagrams: ASK, FSK, and PSK Comprehensive guide to signal space representation, including interactive simulators and MATLAB implementations. 📘 Overview 🧮 Simulator ⚖️ Theory 📚 Resources Definitions Constellation Tool Key Points MATLAB Code 📂 Other Topics: M-ary PSK & QAM Diagrams ▼ 🧮 Simulator for M-ary PSK Constellation 🧮 Simulator for M-ary QAM Constellation BASK (Binary ASK) Modulation Transmits one of two signals: 0 or -√Eb, where Eb​ is the energy per bit. These signals represent binary 0 and 1. BFSK (Binary FSK) Modulation Transmits one...

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

OFDM vs SC-OFDM

  The main difference between OFDM and SC-OFDM is that SC-OFDM transmits the signal using a single carrier, while OFDM uses multiple subcarriers. However, in SC-OFDM, the signal is generated with different sub-bands, but it is transmitted through a single carrier (more technically, through a wideband carrier signal). Block Diagram of OFDM: Data → Modulation → Serial-to-Parallel → IFFT → Add CP → Transmit Received Signal → Remove CP → FFT → Parallel-to-Serial → Demodulation → Data Block Diagram of SC-OFDM: Data → Modulation → DFT → IFFT → Add CP → Transmit Received Signal → Remove CP → FFT → Demodulation → Data    In the case of OFDM, the input modulated data is converted from a serial stream to parallel streams, and different subcarriers are assigned to each chunk. Then, IFFT is applied to these chunks, and a cyclic prefix is added to each one. Each chunk is technically referred to as an OFDM symbol . Unlike OFDM, SC-OFDM does not perform serial-to-parallel conversion ...

Fourier Transform of Unit Step Function Using MATLAB

  MATLAB Script  clc; clear; close all; % Time domain setup Fs = 1000;               % Sampling frequency T = 1/Fs;                % Sampling interval L = 2048;                % Number of samples t = (-L/2 : L/2 -1)*T;   % Symmetric time vector % Unit step function u(t) ≈ heaviside(t) x = double(t >= 0);      % Discrete unit step % FFT and frequency axis X = fftshift(fft(x));    % Shift zero freq to center f = (-Fs/2):(Fs/L):(Fs/2 - Fs/L);   % Frequency vector % Normalize FFT output X = X / L; % Plot time-domain signal figure(); plot(t, x, 'LineWidth', 1.5); title('Unit Step Function u(t)'); xlabel('Time (s)'); ylabel('Amplitude'); grid on; xlim([-0.01 0.01]); % Plot frequency-domain magnitude figure(); plot(f, abs(X), 'LineWidth', 1.5); title('Fourier Transform of a Rectangular Function'); xlabel('Frequency (Hz...