How to generate BPSK signal

459 vues (au cours des 30 derniers jours)
Meshari Alsahli
Meshari Alsahli le 20 Avr 2020
  1. Generate 1000 random binary data bits.
  2. Convert unipolar to bipolar in the databits.
  3. Modulate the bipolar bits with Binary Phase Shift Keying (BPSK).
  4. Multiply the baseband BPSK with a carrier fc = 100 Hz.
  5. The modulated BPSK signals will be transmitted through a Noiseless channel. At the receiver side demodulate the received signal by multiplying it with a carrier and passing it through a Low Pass Filter (LPF).
  6. Decode the BPSK signal using match filtering and sgn function.
  1 commentaire
Usama Saleem
Usama Saleem le 27 Déc 2021
: Apply the concept of conversion of a double word into another word and implement it on Arduino and verify with the help of an Example.

Connectez-vous pour commenter.

Réponse acceptée

MathWorks Support Team
MathWorks Support Team le 13 Juil 2021
Modifié(e) : MathWorks Support Team le 13 Juil 2021
% Set up
% Specified parameters
M = 2; % Modulation order (BPSK)
nData = 1000; % Number of bits
Fc = 100; % Carrier frequency, Hz
% Assumed parameters
Fb = 100; % Bit (baud) rate, bps
Fs = 8*Fc; % Sampling frequency, Hz
Ts = 1/Fs; % Sample time, sec
Td = nData/Fb; % Time duration, sec
spb = Fs/Fb; % Samples per bit
fSpan = 4; % Filter span in symbols
% Visualize the spectrum of baseband BPSK & modulated carrier
specAn1 = dsp.SpectrumAnalyzer("SampleRate", Fs, "Method","Filter bank","AveragingMethod","Exponential","Title", "Pulse Shaped Baseband BPSK");
specAn2 = dsp.SpectrumAnalyzer("SampleRate", Fs, "Method","Filter bank","AveragingMethod","Exponential","Title", "BPSK Modulated Carrier");
% Transmitter
% Generate random data bits
data = randi([0 M-1],nData,1);
% Modulate and plot the data
% pskmod() effectively converts unipolar to bipolar bits and performs BPSK
% modulation
modData = real(pskmod(data,M));
% Pulse shape & upsample to match carrier's sampling rate. Pulse shaping is
% used to reduce intersymbol interference and to reduce spectral width of
% the modulated signal.
txFilter = comm.RaisedCosineTransmitFilter("FilterSpanInSymbols",fSpan,"OutputSamplesPerSymbol",spb);
txfilterOut = txFilter(modData);
specAn1(txfilterOut);
% Multiply modulated & pulse shaped signal with carrier
sine = dsp.SineWave("Frequency",Fc,"SampleRate",Fs,"ComplexOutput",false,"SamplesPerFrame",Td/Ts);
carrier = sine();
txSignal = txfilterOut .* carrier;
specAn2((txSignal));
% Receiver
% Multiply received signal with carrier
rxSignal = txSignal .* conj(carrier);
% Low pass match filter to account for pulse shaping
rxFilter = comm.RaisedCosineReceiveFilter("FilterSpanInSymbols",fSpan,"InputSamplesPerSymbol",spb,"DecimationFactor",spb);
rxFilterOut = rxFilter(rxSignal);
% Demodulate
% For BPSK, pskdemod() is equivalent to sign function
dataOut = pskdemod(rxFilterOut,M);
% Each of the tx and rx filters introduces a delay of fSpan/2 symbols, for
% a total delay of fSpan symbols (= bits for BPSK). Delay received bits by
% fDelay for accurate comparison with transmitted bits.
fDelay = fSpan;
[numErr, ber] = biterr(data(1:nData-fDelay),dataOut(fDelay+1:nData))
  2 commentaires
Jaweed Raza
Jaweed Raza le 16 Sep 2023
I tried running the above scripts but generated that there are errors in
specAn1 = dsp.SpectrumAnalyzer("SampleRate", Fs, "Method","Filter bank","AveragingMethod","Exponential","Title", "Pulse Shaped Baseband BPSK");
specAn2 = dsp.SpectrumAnalyzer("SampleRate", Fs, "Method","Filter bank","AveragingMethod","Exponential","Title", "BPSK Modulated Carrier");
I am not sure why these errors are generated. The lines are identical for SpecAn1 and SoecAn2. What's the difference and how do they differentiate to display the pulse and spectrum?
Idin Motedayen-Aval
Idin Motedayen-Aval le 30 Mai 2024
Note: dsp.SpectrumAnalyzer will be removed in a future release (it's on a deprecation path).
You can simply replace "dsp.SpectrumAnalyzer" with "spectrumAnalyzer" in the above code, and everything will work as expected.
When running the code above in the latest MATLAB release (R2024a), there are no errors (it will produce warnings if you continue to use dsp.SpectrumAnalyzer).
@Jaweed Raza, there are two lines creating two spectrum analyzer objects named specAn1 and specAn2 (when you run this code, two different spectrum analyzer windows pop up; this is how those two figures are generated).

Connectez-vous pour commenter.

Plus de réponses (1)

Maadhav Akula
Maadhav Akula le 23 Avr 2020

Tags

Aucun tag saisi pour le moment.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by