Skip to main content

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


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 modulation, signal set (or, symbols) is structured in a way that prevents them from interacting further by being distinct by phase, amplitude, or frequency.

MATLAB Script (for 4-QAM)

This is an example of 4-QAM. Here constellation size is 4 or total number of symbols/signals is 4. We map the decimal value of the input symbols (00, 01, 10, 11) to complex coordinates.

MATLAB Code 4-QAM
% This code is written by SalimWirelss.Com
clc;clear all;close all;
M = 4; % Number of levels
k = log2(M); % Bits per symbol
rng(10) % seed
N = 10000; % Number of bits
InputBits = randi([0 1],1,N); 
InputSymbol_matrix = reshape(InputBits,length(InputBits)/k,k); 
InputSymbols_decimal = bi2de(InputSymbol_matrix); 

for n= 1:N/k
    if InputSymbols_decimal(n)==0
        QAM(n)= complex(1,1);
    elseif InputSymbols_decimal(n)==1
        QAM(n)= complex(-1,1);
    elseif InputSymbols_decimal(n)==2
        QAM(n)= complex(1,-1);
    else
        QAM(n)= complex(-1,-1);
    end
end

% Transmission over AWGN
snrdB = 10;
Y=awgn(QAM,snrdB); 

% Threshold Detection
for n= 1:N/k
    if (real(Y(n))>0 && imag(Y(n))>0)
        Z(n)=complex(1,1);
    elseif (real(Y(n))>0 && imag(Y(n))<0 complex="" elseif="" imag="" n="" real="" z="">0)
        Z(n)=complex(-1,1);
    else
        Z(n)=complex(-1,-1);
    end
end

figure(1); scatter(real(QAM), imag(QAM)); xlim([-3, 3]); ylim([-3, 3]); title('Transmitted');
figure(2); scatter(real(Y), imag(Y)); xlim([-3, 3]); ylim([-3, 3]); title('Received');
4-QAM Transmitted
Fig 1: Constellation points of 4-QAM (Transmitted)
4-QAM Received
Fig 2: Constellation points of 4-QAM (Received)

Another MATLAB Code (for 16-QAM)

A custom implementation for 16-QAM modulation and demodulation including normalization to unit average power.

MATLAB Code 16-QAM
% The code is developed by SalimWireless.Com
clc; clear; close all;
M = 16; 
numSymbols = 10000; 
data = randi([0 M-1], numSymbols, 1); 
modData = qammod_custom(data, M);
snrdB = 15;
Y = awgn(modData,snrdB); 

figure;
subplot(2,1,1); scatter(real(modData), imag(modData), 'o'); grid on;
title('Constellation Diagram (16-QAM)');
subplot(2,1,2); scatter(real(Y), imag(Y), 'o'); grid on;
title('Received Noisy Signal');

% Custom Functions
function modData = qammod_custom(data, M)
    constellation = [-3-3i, -3-1i, -1-3i, -1-1i, -3+3i, -3+1i, -1+3i, -1+1i, ...
                      +3-3i, +3-1i, +1-3i, +1-1i, +3+3i, +3+1i, +1+3i, +1+1i];
    constellation = constellation / sqrt(mean(abs(constellation).^2)); 
    modData = constellation(data + 1);
end
16-QAM Output

MATLAB for M-ary QAM (General)

This code supports multiple configurations such as 4, 8, 16, 32, 64, 128, and 256-QAM using MATLAB's built-in functions.

MATLAB Code M-ary QAM
% The code is developed by SalimWireless.com
M = 32;  % Order of QAM
N = 1000;  % Symbols
SNR = 10; 
dataSymbols = randi([0 M-1], N, 1);
txSignal = qammod(dataSymbols, M);
rxSignal = awgn(txSignal, SNR, 'measured');
demodulatedSymbols = qamdemod(rxSignal, M);
SER = sum(dataSymbols ~= demodulatedSymbols) / N;
disp(['Symbol Error Rate: ', num2str(SER)]);

figure;
subplot(2, 1, 1); plot(real(txSignal), imag(txSignal), 'o'); title('Transmitted');
subplot(2, 1, 2); plot(real(rxSignal), imag(rxSignal), 'o'); title('Received');
M-ary QAM Constellation

BER vs SNR Analysis

Evaluate the performance of various QAM configurations by plotting Bit Error Rate against Signal-to-Noise Ratio.

Interactive QAM Simulator

Visualize 4-QAM, 16-QAM, 64-QAM, and 256-QAM constellations instantly with our online tool.

Simulator Preview
Launch Simulator Now Other Simulations

Contact Us

Name

Email *

Message *