Skip to main content

Effect of Rayleigh Fading on the Constellation Diagram of Binary PSK


In real-world wireless communication, the direct line-of-sight (LOS) path between transmitter and receiver is often blocked or unavailable. As a result, the transmitted signal experiences Rayleigh fading. This phenomenon arises from multipath propagation, where the signal reaches the receiver through several different paths with varying delays and phase shifts. While constellation diagrams primarily show the effects of Additive White Gaussian Noise (AWGN), multipath fading can heavily distort these diagrams. This distortion impacts the accuracy of symbol detection, leading to increased error rates and degraded system performance. To combat these challenges, communication systems employ techniques such as equalization and diversity methods to reduce the adverse effects of multipath fading. 

 

MATLAB Simulation of Rayleigh Fading Impact on BPSK Constellation


// MATLAB code courtesy of SalimWireless.com
clc; clear; close all;
% Parameters
N = 10000; % Number of symbols
SNR = 20; % Signal-to-Noise Ratio in dB (for AWGN)
M = 2; % Modulation Order (2 for BPSK)
Fs = 100; % Sampling frequency (not used directly, but for clarity)
L = 4; % Oversampling factor
Rayleigh_factor = 0.5; % Rayleigh fading factor (scaling of fading)
% Generate random bits for BPSK
% BPSK Mapping: 0 -> -1 + 0j, 1 -> 1 + 0j (complex-valued with imaginary part 0)
data = randi([0 1], N, 1);
modData = (2*data - 1) + 0i; % Map 0 to -1 + 0j, 1 to 1 + 0j (complex)
% Upsample to simulate higher symbol rate
modData_upsampled = upsample(modData, L);
% Create Rayleigh fading channel (without division)
% Generate random fading gains for Rayleigh fading
rayleigh_fading = [0.8, 0.6];
% Apply Rayleigh fading to the modulated signal (only real part affected by fading)
fadedSignal = modData_upsampled .* rayleigh_fading;
% Assuming fadedSignal is a complex vector/matrix

% Add AWGN noise to both real and imaginary parts
noise = generateComplexGaussianNoise(length(fadedSignal));
% Normalize the noise (to match the noise power based on SNR)
snrLinear = 10^(SNR / 10); % Linear scale of SNR
noise = noise / sqrt(2 * snrLinear); % Normalize the noise
% Add the noise to the faded signal (real and imaginary components)
noisySignal = fadedSignal + noise;
threshold = 0.4;
idx = abs(noisySignal) > -threshold & abs(noisySignal) < threshold; % between -0.1 and 0.1 is just abs < 0.1
noisySignal(idx) = 0;
% Plot the constellation diagram
figure;
scatter(real(noisySignal), imag(noisySignal), '.');
title('Received Signal Constellation for BPSK (Rayleigh Fading + AWGN)');
xlabel('In-Phase');
ylabel('Quadrature');
axis equal;
grid on;
% Function to generate Complex Gaussian Noise
function noise = generateComplexGaussianNoise(size)
u1 = rand(size, 1); % Uniform random variables
u2 = rand(size, 1);

% Box-Muller transform to generate complex Gaussian noise
z1 = sqrt(-2 * log(u1)) .* cos(2 * pi * u2); % Real part
z2 = sqrt(-2 * log(u1)) .* sin(2 * pi * u2); % Imaginary part

noise = complex(z1, z2); % Combine real and imaginary parts
end


web('https://www.salimwireless.com/search?q=fading', '-browser');

    

Simulation Output

For, channel impulse response, h = [0.8, 0.6] 

Constellation diagram showing BPSK under Rayleigh fading and AWGN
 

Fig: Constellation diagram of BPSK signal affected by Rayleigh fading and AWGN noise.

If you adjust the number of multipath components to one by changing the fading vector on line 20 from:

rayleigh_fading = [0.8, 0.6, 0.3];
    

to

rayleigh_fading = [1];
    

the output constellation will simplify as shown below: 

(Rayleigh fading occurs when there is no direct line-of-sight (LOS) between the transmitter and receiver. For illustration purposes, we consider the channel coefficient , representing a flat fading channel without multipath effects.)

 

For, channel impulse response, h = [1] 

Constellation diagram of BPSK with single-path AWGN channel
 

Simplified constellation diagram with a single-path Rayleigh fading (effectively no fading).

You can also experiment by adjusting the SNR parameter in the code to observe how the constellation diagram accuracy changes for Binary PSK under Rayleigh fading conditions. 

 

 

Further Reading



People are good at skipping over material they already know!

View Related Topics to







Contact Us

Name

Email *

Message *

Popular Posts

OFDM Symbols and Subcarriers Explained

This article explains how OFDM (Orthogonal Frequency Division Multiplexing) symbols and subcarriers work. It covers modulation, mapping symbols to subcarriers, subcarrier frequency spacing, IFFT synthesis, cyclic prefix, and transmission. Step 1: Modulation First, modulate the input bitstream. For example, with 16-QAM , each group of 4 bits maps to one QAM symbol. Suppose we generate a sequence of QAM symbols: s0, s1, s2, s3, s4, s5, …, s63 Step 2: Mapping Symbols to Subcarriers Assume N sub = 8 subcarriers. Each OFDM symbol in the frequency domain contains 8 QAM symbols (one per subcarrier): Mapping (example) OFDM symbol 1 → s0, s1, s2, s3, s4, s5, s6, s7 OFDM symbol 2 → s8, s9, s10, s11, s12, s13, s14, s15 … OFDM sym...

Constellation Diagrams of ASK, PSK, and FSK

๐Ÿ“˜ Overview of Energy per Bit (Eb / N0) ๐Ÿงฎ Online Simulator for constellation diagrams of ASK, FSK, and PSK ๐Ÿงฎ Theory behind Constellation Diagrams of ASK, FSK, and PSK ๐Ÿงฎ MATLAB Codes for Constellation Diagrams of ASK, FSK, and PSK ๐Ÿ“š Further Reading ๐Ÿ“‚ Other Topics on Constellation Diagrams of ASK, PSK, and FSK ... ๐Ÿงฎ Simulator for constellation diagrams of m-ary PSK ๐Ÿงฎ Simulator for constellation diagrams of m-ary QAM 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 of two signals: +√Eb​ ( On the y-axis, the phase shift of 90 degrees with respect to the x-axis, which is also termed phase offset ) or √Eb (on x-axis), where Eb​ is the energy per bit. These signals represent binary 0 and 1.  BPSK (Binary PSK) Modulation: Transmits one of two signals...

BER vs SNR for M-ary QAM, M-ary PSK, QPSK, BPSK, ...

๐Ÿ“˜ Overview of BER and SNR ๐Ÿงฎ Online Simulator for BER calculation of m-ary QAM and m-ary PSK ๐Ÿงฎ MATLAB Code for BER calculation of M-ary QAM, M-ary PSK, QPSK, BPSK, ... ๐Ÿ“š Further Reading ๐Ÿ“‚ View Other Topics on M-ary QAM, M-ary PSK, QPSK ... ๐Ÿงฎ Online Simulator for Constellation Diagram of m-ary QAM ๐Ÿงฎ Online Simulator for Constellation Diagram of m-ary PSK ๐Ÿงฎ MATLAB Code for BER calculation of ASK, FSK, and PSK ๐Ÿงฎ MATLAB Code for BER calculation of Alamouti Scheme ๐Ÿงฎ Different approaches to calculate BER vs SNR What is Bit Error Rate (BER)? The abbreviation BER stands for Bit Error Rate, which indicates how many corrupted bits are received (after the demodulation process) compared to the total number of bits sent in a communication process. BER = (number of bits received in error) / (total number of tran...

Power Spectral Density Calculation Using FFT in MATLAB

๐Ÿ“˜ Overview ๐Ÿงฎ Steps to calculate the PSD of a signal ๐Ÿงฎ MATLAB Codes ๐Ÿ“š Further Reading Power spectral density (PSD) tells us how the power of a signal is distributed across different frequency components, whereas Fourier Magnitude gives you the amplitude (or strength) of each frequency component in the signal. Steps to calculate the PSD of a signal Firstly, calculate the first Fourier transform (FFT) of a signal Then, calculate the Fourier magnitude of the signal The power spectrum is the square of the Fourier magnitude To calculate power spectrum density (PSD), divide the power spectrum by the total number of samples and the frequency resolution. {Frequency resolution = (sampling frequency / total number of samples)} Sampling frequency (fs): The rate at which the continuous-time signal is sampled (in Hz). ...

Fundamentals of Channel Estimation

Channel Estimation Techniques Channel Estimation is an auto‑regressive process that may be performed with a number of iterations. There are commonly three types of channel estimation approaches: Pilot estimation Blind estimation Semi‑blind estimation. For Channel Estimation, CIR [↗] is used. The amplitudes of the impulses decrease over time and are not correlated. For example: y(n) = h(n) * x(n) + w(n) where y(n) is the received signal, x(n) is the sent signal, and w(n) is the additive white Gaussian noise. At the next stage: h(n+1) = a * h(n) + w(n) The channel coefficient will be modified as stated above at the subsequent stage. The scaling factor “a” determines the impulse’s amplitude, whereas h(n+1) represents the channel coefficient at the following stage. Pilot Estimation Method To understand how a communication medium is currently behaving, a channel estimate is necessary...

Pulse Position Modulation (PPM)

Pulse Position Modulation (PPM) is a type of signal modulation in which M message bits are encoded by transmitting a single pulse within one of 2แดน possible time positions within a fixed time frame. This process is repeated every T seconds , resulting in a data rate of M/T bits per second . PPM is a form of analog modulation where the position of each pulse is varied according to the amplitude of the sampled modulating signal , while the amplitude and width of the pulses remain constant . This means only the timing (position) of the pulse carries the information. PPM is commonly used in optical and wireless communications , especially where multipath interference is minimal or needs to be reduced. Because the information is carried in timing , it's more robust in some noisy environments compared to other modulation schemes. Although PPM can be used for analog signal modulation , it is also used in digital communications where each pulse position represents a symbol or bit...

Theoretical vs. simulated BER vs. SNR for ASK, FSK, and PSK

๐Ÿ“˜ Overview ๐Ÿงฎ Simulator for calculating BER ๐Ÿงฎ MATLAB Codes for calculating theoretical BER ๐Ÿงฎ MATLAB Codes for calculating simulated BER ๐Ÿ“š Further Reading 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. Simulator for calculating BER vs SNR for binary ASK, FSK, and PSK Calculate BER for Binary ASK Modulation Enter SNR (dB): Calculate BER Calculate BER for Binary FSK Modulation Enter SNR (dB): Calculate BER Calculate BER for Binary PSK Modulation Enter SNR (dB): Calculate BER BER vs. SNR Curves MATLAB Code for Theoretical BER % The code is written by SalimWireless.Com clc; clear; close all; % SNR v...

MATLAB code for BER vs SNR for M-QAM, M-PSK, QPSk, BPSK, ...

๐Ÿงฎ MATLAB Code for BPSK, M-ary PSK, and M-ary QAM Together ๐Ÿงฎ MATLAB Code for M-ary QAM ๐Ÿงฎ MATLAB Code for M-ary PSK ๐Ÿ“š Further Reading MATLAB Script for BER vs. SNR for M-QAM, M-PSK, QPSK, BPSK % Written by Salim Wireless clc; clear; close all; num_symbols = 1e5; snr_db = -20:2:20; psk_orders = [2, 4, 8, 16, 32]; qam_orders = [4, 16, 64, 256]; ber_psk_results = zeros(length(psk_orders), length(snr_db)); ber_qam_results = zeros(length(qam_orders), length(snr_db)); for i = 1:length(psk_orders) psk_order = psk_orders(i); for j = 1:length(snr_db) data_symbols = randi([0, psk_order-1], 1, num_symbols); modulated_signal = pskmod(data_symbols, psk_order, pi/psk_order); received_signal = awgn(modulated_signal, snr_db(j), 'measured'); demodulated_symbols = pskdemod(received_signal, psk_order, pi/psk_order); ber_psk_results(i, j) = sum(data_symbols ~= demodulated_symbols) / num_symbols; end end for i...