Skip to main content

Role of Cyclic Prefix in OFDM


Role of Cyclic Prefix in OFDM

The simple frequency-domain equalizer is possible only if the channel performs circular convolution. However, in practice, all wireless channels perform linear convolution.

This linear convolution is converted into circular convolution by adding a cyclic prefix (CP) in the OFDM architecture. The cyclic prefix makes the linear convolution imparted by the channel appear as circular convolution to the DFT process at the receiver.

Demonstration Concept

To demonstrate this, consider an OFDM signal s[n] of length 8 and a channel impulse response h[n] of length 3. When s[n] is convolved with h[n]:

  • Linear convolution and circular convolution give different results.
  • This mismatch causes interference in OFDM systems.

Adding Cyclic Prefix

A cyclic prefix is added by copying the last NCP samples of the OFDM symbol and appending them to the beginning. If the cyclic prefix length is at least equal to the channel delay spread, the following occurs:

  • Inter-symbol interference is confined to the cyclic prefix.
  • The useful received signal behaves as circular convolution.

Receiver Processing

At the receiver, the cyclic prefix samples are removed. The remaining samples correspond exactly to the circular convolution of the transmitted signal and the channel impulse response.

DFT Property

After removing the cyclic prefix, the received signal satisfies:

r[n] = IDFT { H[k] · S[k] }

This confirms that circular convolution in time domain corresponds to simple multiplication in the frequency domain.


Why OFDM needs circular convolution

In OFDM:

  • Each OFDM symbol is processed using an N-point DFT
  • DFT diagonalizes circular convolution, not linear convolution

So without CP:

DFT{x[n] * h[n]} ≠ X[k] H[k]

Subcarriers interfere → ICI + ISI

What the cyclic prefix actually does

The cyclic prefix:

  • Copies the last L samples of the OFDM symbol
  • Appends them to the front of the symbol
Original OFDM symbol:
[x0 x1 x2 ... x(N−1)]

After CP:
[x(N−L) ... x(N−1) | x0 x1 ... x(N−1)]

Where L ≥ channel delay spread

Mathematical proof

Let:

  • x[n] be an N-sample OFDM symbol
  • CP length L ≥ Lh - 1

Then after CP removal:

y[n] = x[n] ⊛ h[n]

Taking DFT:

Y[k] = X[k] H[k]

Equalization becomes:

ฤคX[k] = Y[k] / H[k]

One complex multiplication per subcarrier

Practical example (LTE / Wi-Fi numbers)

  • FFT size = 2048
  • CP ≈ 4.7 ยตs
  • Channel delay spread ≈ 1–3 ยตs

Because CP length > delay spread:

  • No ISI
  • No ICI
  • Simple frequency-domain equalizer works

Without CP:

  • Symbols overlap
  • Subcarriers mix
  • Equalizer becomes very complex

Physical interpretation

Think of CP as a guard interval in time, not frequency:

  • Absorbs multipath echoes
  • Makes each OFDM symbol appear periodic
  • DFT “sees” a periodic extension → circular convolution


What happens if CP is too short?

If CP length < channel delay spread:

  • Linear convolution leaks into FFT window
  • Circularity breaks
  • ISI + ICI appear
  • Orthogonality is lost

Summary

By adding a cyclic prefix, OFDM systems convert linear channel convolution into circular convolution, enabling low-complexity frequency-domain equalization and eliminating inter-symbol interference.

Cyclic prefix converts linear convolution into circular convolution, so that the FFT sees a diagonal frequency response, allowing simple frequency-domain equalization.



Further Reading


People are good at skipping over material they already know!

View Related Topics to







Contact Us

Name

Email *

Message *

Popular Posts

Theoretical BER vs SNR for binary ASK, FSK, and PSK with MATLAB Code + Simulator

๐Ÿ“˜ Overview & Theory ๐Ÿงฎ MATLAB Codes ๐Ÿ“š Further Reading Bit Error Rate (BER) Equations In ASK, noise directly affects the signal amplitude, making it the most vulnerable since the data is carried in amplitude changes. In FSK, data is represented by frequency variations, and because noise typically impacts amplitude more than frequency, FSK is more robust than ASK. In PSK, data is encoded in the signal phase, and BPSK specifically uses 180-degree phase shifts, creating the greatest separation between signal points and therefore achieving the lowest bit error rate (BER) for the same power level. 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-func...

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

How to use MATLAB Simulink

Introduction to MATLAB Simulink MATLAB Simulink is a popular add-on of MATLAB. Here, you can use different blocks like modulator, demodulator, AWGN channel, etc. And you can do experiments on your own. Steps to Get Started 1. Go to the 'Simulink' tab at the top navbar of MATLAB. If not found, click on the add-on tab, search 'Simulink,' and then click on it to add. 2. Once you installed the simulation, click the 'new' tap at the top left corner. 3. Then, search the required blocks in the 'Simulink library.' Then, drag it to the editor space. 4. You can double-click on the blocks to see the input parameters. 5. Then, connect the blocks by dragging a line from one block's output terminal to another block's input. 6. If the connection is complete, click the 'run' tab in the middle of the top navbar. 7. After clicking on the run ...

OFDM Waveform with MATLAB Code (with Simulator)

  In OFDM (Orthogonal Frequency Division Multiplexing) , we transmit multiple orthogonal subcarriers simultaneously. Since the subcarriers are orthogonal , they do not interfere with each other, which is one of the main advantages of OFDM. Practically, OFDM converts a wideband signal into multiple narrowband orthogonal subcarriers. For typical wireless communication, if the signal bandwidth (or symbol duration) exceeds the coherence bandwidth of the channel, the signal experiences frequency-selective fading . Fading distorts the signal, making it difficult to recover the original information. By using OFDM, we transmit the same wideband signal across multiple orthogonal narrowband subcarriers, reducing the effect of fading. For example, if we want to transmit a signal of bandwidth 1024 kHz , we can divide it into N = 8 subcarriers . Each subcarrier is then spaced by: ฮ”f = Total Bandwidth N = 1024 8 kHz...

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

๐Ÿ“˜ Overview of QAM ๐Ÿงฎ 4-QAM MATLAB ๐Ÿงฎ 16-QAM MATLAB ๐Ÿš€ Online Simulator ๐Ÿ“‚ Other Topics on Constellation Diagrams... ▼ ๐Ÿงฎ MATLAB Code for 4-QAM ๐Ÿงฎ MATLAB Code for 16-QAM ๐Ÿงฎ MATLAB Code for m-ary QAM ๐Ÿงฎ Simulator for m-ary PSK ๐Ÿงฎ Simulator for m-ary QAM ๐Ÿงฎ Overview of Energy per Bit (Eb / N0) ๐Ÿงฎ Simulator for ASK, FSK, and PSK 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 modulatio...

Online Simulator for ASK, FSK, and PSK

Try our new Digital Signal Processing Simulator!   •   Interactive ASK, FSK, and BPSK tools updated for 2025. Start Now Interactive Modulation Simulators Visualize binary modulation techniques (ASK, FSK, BPSK) in real-time with adjustable carrier and sampling parameters. ๐Ÿ“ก ASK Simulator ๐Ÿ“ถ FSK Simulator ๐ŸŽš️ BPSK Simulator ๐Ÿ“š More Topics ASK Modulator FSK Modulator BPSK Modulator More Topics Simulator for Binary ASK Modulation Digital Message Bits Carrier Freq (Hz) Sampl...

Simulation of ASK, FSK, and PSK using MATLAB Simulink (with Online Simulator)

๐Ÿ“˜ Overview ๐Ÿงฎ How to use MATLAB Simulink ๐Ÿงฎ Simulation of ASK using MATLAB Simulink ๐Ÿงฎ Simulation of FSK using MATLAB Simulink ๐Ÿงฎ Simulation of PSK using MATLAB Simulink ๐Ÿงฎ Simulator for ASK, FSK, and PSK ๐Ÿงฎ Digital Signal Processing Simulator ๐Ÿ“š Further Reading ASK, FSK & PSK HomePage MATLAB Simulation Simulation of Amplitude Shift Keying (ASK) using MATLAB Simulink In Simulink, we pick different components/elements from MATLAB Simulink Library. Then we connect the components and perform a particular operation. Result A sine wave source, a pulse generator, a product block, a mux, and a scope are shown in the diagram above. The pulse generator generates the '1' and '0' bit sequences. Sine wave sources produce a specific amplitude and frequency. The scope displays the modulated signal as well as the original bit sequence created by the pulse generator. Mux i...

FastAPI Static Files – Overview

FastAPI Static Files Often, a web application needs to include resources that do not change, even when dynamic data is rendered. These resources are called static assets . Examples of static files include: Images ( .png , .jpg ) JavaScript files ( .js ) Stylesheets ( .css ) Installing Required Library To handle static files in FastAPI, you need the aiofiles library. pip install aiofiles Mounting Static Files FastAPI uses the StaticFiles class to serve static content. You mount a folder (usually named static ) so that all files inside it can be accessed via a URL. from fastapi import FastAPI from fastapi.staticfiles import StaticFiles app = FastAPI() app.mount("/static", StaticFiles(directory="static"), name="static") Example 1: Using an Image Place an image file (for example, fa-logo.png ) inside the static folder. main.py from fastapi import FastAPI, Request from fastapi.responses import HTMLRespon...