Skip to main content

Optimal Precoding for Millimeter wave Massive MIMO Systems


 

Optimal Precoding for Millimeter wave Massive MIMO Systems

In case of MIMO system we deploy multiple transmitter antennas at receiver side and multiple receiver antennas at receiver side. MIMO technology was introduced to support multiple simultaneous data streams between transmitter and receiver to multiply the capacity of a system. But there is also interference between multiple data streams. Precoding technique minimizes the interference between multiple data streams. 



What Exactly Precoding Technique is

We all are familiar with the channel matrix of an MIMO system, that looks like, =


\      R1     R2     R3     R4

T1  h11    h12     h13   h14

T2  h21    h22     h23   h24

T3  h31    h32     h33   h34

T4  h41    h42     h43   h44


Here, in the above figure channel matrix, is shown. In channel matrix it shown different gains between different antennas. Now, we see in the above matrix for example, h11 represents the channel gain between transmitter antenna, T1 and receiver antenna, R1 and h11 also means connection between the antennas as well. R1 also receives the signals from T2, T3, and T4 antennas too. So, there is some kind of interface between multiple data streams when we process the signal at receiver side. Here, precoding help us to reduce interference between multiple data streams. 



Optimal Precoding in MIMO

Typically, received signal at receiver side is represented as,

y = Hx + n       .....(i)

Where, is channel matrix gain

y = Received signal vector 

= Transmitted signal vector 

= Additive white Gaussian noise

Here, in the above equation you can image channel matrix, as same as above channel matrix where we've shown channel gains between TX side antennas T1, T2, T3, T4, and receiver side antennas, R1, R2, R3, R4, respectively. We've also talked about interference with T1's signal at R1 antenna due to transmission from T2, T2, and T3. 

Now, let imagine your channel matrix looks like that, =


\       R1     R2     R3     R4

T1   h11     0        0         0

T2     0     h22      0        0

T3     0       0      h33      0

T4     0       0       0       h44


Now in equation (i), if you the put the above channel matrix value then you see there is no interference with T1' signal with T2, T3, and T4's transmission at receiver R1. 

Similar approach is performed for optimal precoding technique we channel matrix is decomposed in to two unitary matrix U, V, and one diagonal eigen value matrix, Î£. We've already talked about "Singular Value Decomposition in MIMO Channel" in a separate article. 

There is matrix, Î£we operate row and column matrix in a such way that Î£ becomes diagonal matrix where elements are in descending order. We do that by operating multiple operations in matrix as shown in the above mentioned article.

Generally, matrix is decomposed into, H = UΣVH

As and are unitary matrix so, multiplication of those matrix with its hermitian matrix itself are identity matrix. Alternatively, UUH = VVH = I



Signal Processing at Receiver Side for Optimal Precoding

During transmission we multiply original message signal vector with unitary matrix, V. So, now transmitted signal vector becomes, Vx. On the side at receiver side, received signal vector is multiplied with vector UH. So, as per above equation (i), received signal vector at receiver side as follows

y = UH (UΣVH) Vx + n

y= IΣIx + n

y = Î£x +n 

Now, you see Î£ is a diagonal matrix and signal vector, is multiplied with that diagonal matrix. So, you can observe there the simultaneous data streams between MIMO transmitter and receiver antennas without interference among them. Now we further do optimal power allocation to each antennas to maximize sum-rate or overall throughput as shown in a separate article. There is the URL link above.


# mimo beamforming

Why OFDM precoding modulation used in uplink?

People are good at skipping over material they already know!

View Related Topics to







Contact Us

Name

Email *

Message *

Popular Posts

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

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 fast Fourier transform (FFT) of a signal. Then, calculate the Fourier magnitude (absolute value) of the signal. Square the Fourier magnitude to get the power spectrum. To calculate the Power Spectral Density (PSD), divide the squared magnitude by the product of the sampling frequency (fs) and the total number of samples (N). Formula: PSD = |FFT|^2 / (fs * N) Sampling frequency (fs): The rate at which the continuous-time signal is sampled (in ...

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

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 UGC Net Electronic Science Question Paper With Answer Key Download Pdf [June 2025] with full explanation UGC Net Electronic Science Question Paper With Answer Key Download Pdf [December 2024] UGC Net Paper 1 With Answer Key Download Pdf [Sep 2024] with full explanation UGC Net Electronic Science Question Paper With Answer Key Download Pdf [Aug 2024] with full explanation UGC Net Paper 1 With Answer Key Download...

DFTs-OFDM vs OFDM: Why DFT-Spread OFDM Reduces PAPR Effectively (with MATLAB Code)

DFT-spread OFDM (DFTs-OFDM) has lower Peak-to-Average Power Ratio (PAPR) because it "spreads" the data in the frequency domain before applying IFFT, making the time-domain signal behave more like a single-carrier signal rather than a multi-carrier one like OFDM. Deeper Explanation: Aspect OFDM DFTs-OFDM Signal Type Multi-carrier Single-carrier-like Process IFFT of QAM directly QAM → DFT → IFFT PAPR Level High (due to many carriers adding up constructively) Low (less fluctuation in amplitude) Why PAPR is High Subcarriers can add in phase, causing spikes DFT "pre-spreads" data, smoothing it Used in Wi-Fi, LTE downlink LTE uplink (as SC-FDMA) In OFDM, all subcarriers can...

MATLAB code for BER vs SNR for M-QAM, M-PSK, QPSk, BPSK, ...(with Online Simulator)

🧮 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; snr_db = -5:2:25; 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) ber_psk_results(i, :) = berawgn(snr_db, 'psk', psk_orders(i), 'nondiff'); end for i = 1:length(qam_orders) ber_qam_results(i, :) = berawgn(snr_db, 'qam', qam_orders(i)); end figure; semilogy(snr_db, ber_psk_results(1, :), 'o-', 'LineWidth', 1.5, 'DisplayName', 'BPSK'); hold on; for i = 2:length(psk_orders) semilogy(snr_db, ber_psk_results(i, :), 'o-', 'DisplayName', sprintf('%d-PSK', psk_orde...

ASK, FSK, and PSK (with MATLAB + Online Simulator)

📘 ASK Theory 📘 FSK Theory 📘 PSK Theory 📊 Comparison 🧮 MATLAB Codes 🎮 Simulator ASK or OFF ON Keying ASK is a simple (less complex) Digital Modulation Scheme where we vary the modulation signal's amplitude or voltage by the message signal's amplitude or voltage. We select two levels (two different voltage levels) for transmitting modulated message signals. Example: "+5 Volt" (upper level) and "0 Volt" (lower level). To transmit binary bit "1", the transmitter sends "+5 Volts", and for bit "0", it sends no power. The receiver uses filters to detect whether a binary "1" or "0" was transmitted. Fig 1: Output of ASK, FSK, and PSK modulation using MATLAB for a data stream "1 1 0 0 1 0 1 0" ( Get MATLAB Code ) ...