Skip to main content

Pulse Shaping using Raised Cosine Filter (with MATLAB + Simulator)

 

MATLAB Code for Raised Cosine Filter Pulse Shaping

clc; clear; close all;
%% =====================================================
%% PARAMETERS
%% =====================================================
N = 64; % Number of OFDM subcarriers
cpLen = 16; % Cyclic prefix length
modOrder = 4; % QPSK
oversample = 8; % Oversampling factor
span = 10; % RRC filter span in symbols
rolloff = 0.25; % RRC roll-off factor
%% =====================================================
%% Generate Baseband OFDM Symbols
%% =====================================================
data = randi([0 modOrder-1], N, 1); % Random bits
txSymbols = pskmod(data, modOrder, pi/4); % QPSK modulation
% IFFT to get OFDM symbol
tx_ofdm = ifft(txSymbols, N);
% Add cyclic prefix
tx_cp = [tx_ofdm(end-cpLen+1:end); tx_ofdm];
%% =====================================================
%% Oversample the Baseband Signal
%% =====================================================
tx_oversampled = upsample(tx_cp, oversample);
%% =====================================================
%% Root Raised Cosine (RRC) Pulse Shaping
%% =====================================================
rrcFilter = rcosdesign(rolloff, span, oversample, 'sqrt'); % RRC filter
tx_shaped = conv(tx_oversampled, rrcFilter, 'same');
%% =====================================================
%% Visualize Time-Domain Waveform
%% =====================================================
figure;
subplot(2,1,1);
plot(real(tx_oversampled), 'b'); hold on;
plot(real(tx_shaped), 'r');
xlabel('Sample Index'); ylabel('Amplitude');
title('OFDM Time-Domain Waveform');
legend('Before RRC','After RRC');
grid on;
%% =====================================================
%% Visualize Spectrum
%% =====================================================
subplot(2,1,2);
nFFT = 1024;
f = linspace(-0.5,0.5,nFFT)*oversample; % Normalized freq axis
TX_OS_F = fftshift(abs(fft(tx_oversampled,nFFT)));
TX_SH_F = fftshift(abs(fft(tx_shaped,nFFT)));
plot(f, TX_OS_F/max(TX_OS_F), 'b'); hold on;
plot(f, TX_SH_F/max(TX_SH_F), 'r');
xlabel('Normalized Frequency'); ylabel('Normalized Magnitude');
title('OFDM Spectrum');
legend('Before RRC','After RRC');
grid on;
%% =====================================================

 

Output

 


Summary

In the above figure, it is shown that Root Raised Cosine (RRC) pulse shaping further band-limits the OFDM waveform. Band-limiting a signal allows it to pass more efficiently through a bandwidth-limited channel. The signal bandwidth should not exceed the coherence bandwidth of the channel to avoid frequency-selective distortion. Another important purpose of pulse shaping is to reduce spectral leakage, ensuring that critical frequency components are not lost during transmission.
 

Further Reading


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

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

Calculation of SNR from FFT bins in MATLAB

📘 Overview 💻 FFT Bin Method 💻 Kaiser Window 📚 Further Reading SNR Estimation Overview In digital signal processing, estimating the Signal-to-Noise Ratio (SNR) accurately is crucial. Below, we demonstrate how to calculate SNR from periodogram and FFT bins using the Kaiser Window . The beta (β) parameter is the key—it allows you to control the trade-off between main-lobe width and side-lobe levels for precise spectral analysis. 1 Define Sampling rate and Time vector 2 Compute FFT and Periodogram PSD 3 Identify Signal Bin and Frequency resolution 4 Segment Signal Power from Noise floor 5 Logarithmic calculation of SNR in dB Method 1: Estimation from FFT Bins This approach uses a Hamming window to estimate SNR directly from the spectral bins. MATLAB Source Code Copy Code clc...

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) Sampling Rate (...

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

FIR vs IIR Digital Filters and Recursive vs Non Recursive Filters

Filters >> FIR vs. IIR Digital Filters and Recursive vs. Non-Recursive Filters Key Features The higher the order of a filter, the sharper the stopband transition The sharpness of FIR and IIR filters is very different for the same order A FIR filter has an equal time delay at all frequencies, while the IIR filter's time delay varies with frequency. Usually, the biggest time delay in the IIR filter is at the filter's cutoff frequency. The term 'IR' (impulse response) is in both FIR and IIR. The term 'impulse response' refers to the appearance of the filter in the time domain. 1. What Is the Difference Between an FIR and an IIR Filters? The two major classifications of digital filters used for signal filtration are FIR and IIR....

MATLAB Code for ASK, FSK, and PSK (with Online Simulator)

MATLAB Code for ASK, FSK, and PSK Comprehensive implementation of digital modulation and demodulation techniques with simulation results. 📘 Theory 📡 ASK Code 📶 FSK Code 🎚️ PSK Code 🕹️ Simulator 📚 Further Reading Amplitude Shift Frequency Shift Phase Shift Live Simulator ASK, FSK & PSK HomePage MATLAB Code MATLAB Code for ASK Modulation and Demodulation COPY % The code is written by SalimWireless.Com clc; clear all; close all; % Parameters Tb = 1; fc = 10; N_bits = 10; Fs = 100 * fc; Ts = 1/Fs; samples_per_bit = Fs * Tb; rng(10); binar...

Theoretical BER vs SNR for m-ary PSK and QAM

Relationship Between Bit Error Rate (BER) and Signal-to-Noise Ratio (SNR) The relationship between Bit Error Rate (BER) and Signal-to-Noise Ratio (SNR) is a fundamental concept in digital communication systems. Here’s a detailed explanation: BER (Bit Error Rate): The ratio of the number of bits incorrectly received to the total number of bits transmitted. It measures the quality of the communication link. SNR (Signal-to-Noise Ratio): The ratio of the signal power to the noise power, indicating how much the signal is corrupted by noise. Relationship The BER typically decreases as the SNR increases. This relationship helps evaluate the performance of various modulation schemes. BPSK (Binary Phase Shift Keying) Simple and robust. BER in AWGN channel: BER = 0.5 × erfc(√SNR) Performs well at low SNR. QPSK (Quadrature...