Skip to main content

Constellation Diagrams of M-ary PSK | M-ary Modulation


What is the difference between Bit and Symbol in the perspective of transmission?

Symbols use bandwidth more efficiently than bits. For example, in the case of QPSK, one symbol or signal waveform is represented by 2 bits. Hence symbol rate is one-half of the bit rate. As a result, it occupies half bandwidth compared to the BPSK waveform.

We know the primary purpose of modulation [↗] is to multiplex data. Here multiplexing is done so that there is less interference between parallel data streams. Suppose there is a communication channel; we can transmit a single data stream simultaneously. But if we send a symbol instead of a bit, we can send more than 1 bit at a time. In ASK modulation, we assign two amplitude levels to a signal where a higher level is represented by binary '1' and another level as '0'. For BFSK, we apply phase shift in signal (for example, 0 phase shift for consecutive binary '0' bits and 180 phase shift for a binary bit '1'. ASK, FSK, and PSK [↗] - are primary modulation techniques. With the help of those modulation techniques, we derive many other digital modulations capable of carrying more bits thru a channel as a symbol at a time. For example, in QPSK (Quadrature Phase Shift Keying), we can transmit a symbol two bits at a time thru a channel. A total of 4 symbols use 2 bits per symbol and a phase difference of 90 degrees between them. An example of QPSK is shown below. Here you see that the data rate of the channel is getting double when we transmit 2 bits at a time.


1. What is a constellation diagram


A constellation diagram represents a signal modulated by a digital signal, such as quadrature amplitude modulation (QAM) or quadrature phase shift keying (QPSK). [Read More]


QPSK


Assume we need to modulate four signals or symbols with phase differences of π/2 so that the signals can be orthogonal, which will minimize their mutual interference. Then we can modulate those signals in the following way:

s(t)=Acos(2πfct) for 00

= A cos (2πfct + 90) for 01

= A cos (2πfct + 180) for 10

= A cos (2πfct + 270) for 11

Here, the first signal is modulated with a carrier signal. The next signal is modulated with π/2 shifted same carrier signal, the third signal with additional π/2 shifted to the same carrier signal, and so on. The modulated first signal is represented by the symbol '00', the second modulated signal by the symbol '01', and so forth.





In the above figure, we've shown a constellation diagram of 4 QPSK modulations.


Also, read about the Constellation Diagrams of ASK, FSK, and PSK, Constellation Diagrams of M-ary QAM


2. What is the significance of M-ary PSK?


In Mary PSK, given data bits are modulated with any of the M numbers of phase-shifted carrier signals. Let's send M number of data bits modulated with M number of phase-shifted carriers. Theoretically, there will be no interference (theoretically) between them, and we will achieve 8 times the previous data rate (without modulation).

The RF carrier's phase (or frequency) varies instead of only varying the RF signal's phase, frequency, or amplitude. Mary modulation algorithms transfer baseband data into four or more alternative RF carrier signals since the envelope and phase provide two degrees of freedom. We are talking about four carrier signals because here, 2 or more bits form a symbol, and from 2 bits, we can represent 2^(2) or 4 different signals. M-ary modulation is the name given to such modulation schemes. Two or more bits are joined together to create symbols in the M-ary modulation scheme, and one of the available signals S1(t), S2(t),..., Sm(t) is sent during each symbol period Ts. M = 2^n, where n is an integer that defines the number of bits/symbols, the total number of possible signals.

The modulation is called M-ary ASK, M-ary PSK, or M-ary FSK, depending on whether the amplitude, phase, or frequency is altered. M-ary modulation techniques are appealing for application in bandlimited channels because they improve bandwidth efficiency while sacrificing power efficiency. For example, an 8-PSK system utilizes the channel log8 (base 2) = 3 times more efficiently than a 2-PSK (also known as BPSK) system, as the bandwidth of a physical channel is always limited. M-ary signaling, on the other hand, has lower error performance due to the reduced distances between signals in the constellation diagram. The following sections go through a few of the most common M-ary signaling methods.

8-PSK 

 

16-PSK

 

 
 

MATLAB Code for M-ary PSK (e.g, 4, 8, 16, 32, 64, 128)

%The code is developed by SalimWireless.com
% M-ary PSK Modulation and Demodulation
clc;
clear;
close all;

% Parameters
M = 32;  % Order of PSK (M-PSK)
N = 1000;  % Number of symbols
SNR = 10;  % Signal-to-Noise Ratio in dB

% Generate random data symbols
dataSymbols = randi([0 M-1], N, 1);

% Modulate using M-PSK
txSignal = pskmod(dataSymbols, M);

% Add AWGN noise
rxSignal = awgn(txSignal, SNR, 'measured');

% Demodulate
demodulatedSymbols = pskdemod(rxSignal, M);

% Calculate symbol error rate
symbolErrors = sum(dataSymbols ~= demodulatedSymbols);
SER = symbolErrors / N;

% Display results
disp(['Symbol Error Rate (SER): ', num2str(SER)]);

% Plot constellation diagrams
figure;
subplot(2, 1, 1);
plot(real(txSignal), imag(txSignal), 'o');
grid on;
title('Transmitted Signal Constellation');
xlabel('In-Phase');
ylabel('Quadrature');

subplot(2, 1, 2);
plot(real(rxSignal), imag(rxSignal), 'o');
grid on;
title('Received Signal Constellation');
xlabel('In-Phase');
ylabel('Quadrature');

Output






Copy the MATLAB Code above from here



3. What can we conclude from the above M-ary PSK


Both QPSK and QAM are used to send signals in the form of symbols and to increase the bit rate. If you send a symbol instead of a single bit at a time, then multiple prior data rates will be achieved. Those mary modulation techniques are used to multiplex data.

If you are using simple ASK, FSK, or 2-PSK, and if the data rate is N

Then, the following modulation techniques increase data rates further.

4-PSK, 4-QAM ==>2N

Because here 2 bits are sent as a symbol once

8-PSK, 8-QAM ==>3N

Because here 3 bits are sent as a symbol once

Read More about OFDM, QAM, QPSK, BPSK, FSK, etc.


constellation diagram of qpsk  # qpsk constellation diagram  # Constellation diagram of ask psk fsk

People are good at skipping over material they already know!

View Related Topics to







Admin & Author: Salim

profile

  Website: www.salimwireless.com
  Interests: Signal Processing, Telecommunication, 5G Technology, Present & Future Wireless Technologies, Digital Signal Processing, Computer Networks, Millimeter Wave Band Channel, Web Development
  Seeking an opportunity in the Teaching or Electronics & Telecommunication domains.
  Possess M.Tech in Electronic Communication Systems.


Contact Us

Name

Email *

Message *

Popular Posts

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

Modulation Constellation Diagrams BER vs. SNR BER vs SNR for M-QAM, M-PSK, QPSk, BPSK, ... 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. It is defined as,  In mathematics, BER = (number of bits received in error / total number of transmitted bits)  On the other hand, SNR refers to the signal-to-noise power ratio. For ease of calculation, we commonly convert it to dB or decibels.   What is Signal the signal-to-noise ratio (SNR)? SNR = signal power/noise power (SNR is a ratio of signal power to noise power) SNR (in dB) = 10*log(signal power / noise power) [base 10] For instance, the SNR for a given communication system is 3dB. So, SNR (in ratio) = 10^{SNR (in dB) / 10} = 2 Therefore, in this instance, the s...

Antenna Gain-Combining Methods - EGC, MRC, SC, and RMSGC

 There are different antenna gain-combining methods. They are as follows. 1. Equal gain combining (EGC) 2. Maximum ratio combining (MRC) 3. Selective combining (SC) 4. Root mean square gain combining (RMSGC) 1. Equal gain combining method We add the correlated data streams from different antennas in the equal gain combining method. Then we multiply the resultant data with (1/(number of antennas)) For example, for two antenna gain-combining  If the received symbols are y1 and y2, then  Equal combing gain, y_egc = 0.5 * (y1 + y2) 2. Maximum ratio combining method We multiply the individual data streams with weights in the maximum ratio combining method. More weightage is multiplied by those data streams with maximum {|h|^2}, where h denotes the channel impulse response. And less weightage is multiplied by those data streams with corresponding small value of  {|h|^2}.  Then we sum the data streams to improve SNR. In the case of Maximum Ratio Combining, if y1 an...

Comparisons among ASK, PSK, and FSK | And the definitions of each

Modulation ASK, FSK & PSK Constellation MATLAB Simulink MATLAB Code Comparisons among ASK, PSK, and FSK    Comparisons among ASK, PSK, and FSK Comparison among ASK,  FSK, and PSK Performance Comparison: 1. Noise Sensitivity:    - ASK is the most sensitive to noise due to its reliance on amplitude variations.    - PSK is less sensitive to noise compared to ASK.    - FSK is relatively more robust against noise, making it suitable for noisy environments. 2. Bandwidth Efficiency:    - PSK is the most bandwidth-efficient, requiring less bandwidth than FSK for the same data rate.    - FSK requires wider bandwidth compared to PSK.    - ASK's bandwidth efficiency lies between FSK and PSK. Bandwidth Calculator for ASK, FSK, and PSK The baud rate represents the number of symbols transmitted per second Select Modulation Type: ASK...

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

Modulation Constellation Diagrams BER vs. SNR MATLAB code for BER vs SNR for M-QAM, M-PSK, QPSk, BPSK, ...   MATLAB Script for  BER vs. SNR for M-QAM, M-PSK, QPSk, BPSK %Written by Salim Wireless %Visit www.salimwireless.com for study materials on wireless communication %or, if you want to learn how to code in MATLAB clc; clear; close all; % Parameters num_symbols = 1e5; % Number of symbols snr_db = -20:2:20; % Range of SNR values in dB % PSK and QAM orders to be tested psk_orders = [2, 4, 8, 16, 32]; qam_orders = [4, 16, 64, 256]; % Initialize BER arrays ber_psk_results = zeros(length(psk_orders), length(snr_db)); ber_qam_results = zeros(length(qam_orders), length(snr_db)); % BER calculation for each PSK order and SNR value for i = 1:length(psk_orders) psk_order = psk_orders(i); for j = 1:length(snr_db) % Generate random symbols data_symbols = randi([0, psk_order-1], 1, num_symb...

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

  BER vs. SNR denotes how many bits in error are received in a communication process for a particular Signal-to-noise (SNR) ratio. In most cases, SNR is measured in decibel (dB). For a typical communication system, a signal is often affected by two types of noises 1. Additive White Gaussian Noise (AWGN) 2. Rayleigh Fading In the case of additive white Gaussian noise (AWGN), random magnitude is added to the transmitted signal. On the other hand, Rayleigh fading (due to multipath) attenuates the different frequency components of a signal differently. A good signal-to-noise ratio tries to mitigate the effect of noise.  Calculate BER for Binary ASK Modulation The theoretical BER for binary ASK (BASK) in an AWGN channel is given by: BER  = (1/2) * erfc(0.5 * sqrt(SNR_ask));   Enter SNR (dB): Calculate BER BER vs. SNR curves for ASK, FSK, and PSK Calculate BER for Binary FSK Modulation The theoretical BER for binary FSK (BFSK) in a...

Constellation Diagrams of ASK, PSK, and FSK

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: +√Eb​ or -√Eb (they differ by 180 degree phase shift), where Eb​ is the energy per bit. These signals represent binary 0 and 1.  Key Points For Binary Amplitude Shift Keying (BASK), binary bit '0' can be represented as lower level voltage or no signal and bit '1' as higher level voltage.  For Binary Frequency Shift Keying (BFSK), you can map binary bit '0' to 'j' and bit '1' to '1'. So, signals are in phase.  A phase shift of 0 degrees could represent a binary '1...

MATLAB Code for Pulse Amplitude Modulation (PAM) and Demodulation

  Pulse Amplitude Modulation (PAM) & Demodulation MATLAB Script clc; clear all; close all; fm= 10; % frequency of the message signal fc= 100; % frequency of the carrier signal fs=1000*fm; % (=100KHz) sampling frequency (where 1000 is the upsampling factor) t=0:1/fs:1; % sampling rate of (1/fs = 100 kHz) m=1*cos(2*pi*fm*t); % Message signal with period 2*pi*fm (sinusoidal wave signal) c=0.5*square(2*pi*fc*t)+0.5; % square wave with period 2*pi*fc s=m.*c; % modulated signal (multiplication of element by element) subplot(4,1,1); plot(t,m); title('Message signal'); xlabel ('Time'); ylabel('Amplitude'); subplot(4,1,2); plot(t,c); title('Carrier signal'); xlabel('Time'); ylabel('Amplitude'); subplot(4,1,3); plot(t,s); title('Modulated signal'); xlabel('Time'); ylabel('Amplitude'); %demdulated d=s.*c; % At receiver, received signal is multiplied by carrier signal filter=fir1(200,fm/fs,'low'); % low-pass FIR fi...

MATLAB code for GMSK

  Copy the MATLAB code from here  % The code is developed by SalimWireless.com clc; clear; close all; % Parameters samples_per_bit = 36; bit_duration = 1; num_bits = 20; sample_interval = bit_duration / samples_per_bit; time_vector = 0:sample_interval:(num_bits * bit_duration); time_vector(end) = []; % Generate and modulate binary data binary_data = randi([0, 1], 1, num_bits); modulated_bits = 2 * binary_data - 1; upsampled_signal = kron(modulated_bits, ones(1, samples_per_bit)); figure; plot(time_vector, upsampled_signal); title('Message Signal'); % Apply Gaussian filter filtered_signal = conv(GMSK_gaussian_filter1(bit_duration, samples_per_bit), upsampled_signal); filtered_signal = [filtered_signal, filtered_signal(end)]; figure; plot(filtered_signal); title('Filtered Signal'); % Integration & GMSK modulation integrated_signal = cumsum(filtered_signal); gmsk_signal = exp(1i * integrated_signal); % Plotting the real and imaginary parts of the GMSK signal ...