University School of Automation & Robotics

Personal resource archive for various courses.

8.m

%pulse width modulation and demodulation
close all; clear; clc;

fc = 1000;        % Carrier frequency
fs = 10000;       % Sampling frequency
f1 = 200;         % Message frequency

t = 0:1/fs:((2/f1)-(1/fs));
x1 = 0.4 * cos(2*pi*f1*t) + 0.5;

% Modulation
y1 = modulate(x1, fc, fs, 'pwm');

subplot(3,1,1);
plot(x1);
axis([0 50 0 1]);
title('Original Signal (f1 = 200Hz, fs = 10000Hz)');
xlabel('Time (s)');
ylabel('Amplitude');

subplot(3,1,2);
plot(y1);
axis([0 50 -0.2 1.2]);
title('PWM Modulated Signal');
xlabel('Time (s)');
ylabel('Amplitude');

% Demodulation
x1_recover = demod(y1, fc, fs, 'pwm');
subplot(3,1,3);
plot(x1_recover);
axis([0 50 0 1]);
title('Recovered Signal (PWM Demodulated)');
xlabel('Time (s)');
ylabel('Amplitude');
sgtitle('Sujal Singh (04119051723)')