bpsk_qpsk_builtin.m

来自「Mat lab code of OFDM using BPSK」· M 代码 · 共 62 行

M
62
字号

%   -------------
%    TRANSMITTER
%   -------------

clear all
close all

disp('Here is the code of OFDM using (01)=BPSK ......(02) =QPSK. ');
disp('SET M 2 for BPSK & 4 for QPSK. ');

M = input('Enter value of M 2 = BPSK..... 4 = QPSK etc ... =   ');    

bits = input('enter no of bits ....=  '); ;        
nc = input('enter no of carrier....=  ');                 
len_cp = ceil(0.1*nc);  %   length of cyclic prefix
ifft_points = nc;           
fft_points = nc;

data = randsrc(1, bits, 0:M-1);
figure(1)
stem(data); grid on; xlabel('Data Points'); ylabel('Amplitude')
title('Transmitted Data "O"')

modulated_data = pskmod(data, M,pi/4);

scatterplot(modulated_data);

title('QPSK Modulation')

num_cols=length(modulated_data)/nc;

data_matrix = reshape(modulated_data, nc, num_cols);

cp_start = nc-len_cp;
cp_end = nc;


for i=1:num_cols
    ifft_data_matrix(:,i) = ifft((data_matrix(:,i)),ifft_points);
    
    for j=1:len_cp,
       actual_cp(j,i) = ifft_data_matrix(j+cp_start,i);
    end
       ifft_data(:,i) = vertcat(actual_cp(:,i),ifft_data_matrix(:,i));
end

[rows_ifft_data cols_ifft_data]=size(ifft_data);

ofdm_data = rows_ifft_data*cols_ifft_data;

ofdm_signal = reshape(ifft_data, 1, ofdm_data);

figure(3)

plot(real(ofdm_signal)); 
title('Real part of OFDM Signal');grid on;
figure(4)
plot(imag(ofdm_signal)); 
title('Imaginary part of OFDM Signal');grid on;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?