Lab 1
Lab 1
Lab 1
Objective:
To write a program in MATLAB to generate signals in discrete & continuous form.
To introduce students with MATLAB simulation software.
Algorithm:
1. Get the value of n for the sequences.
2. Use the desired formula for generating the signals.
3. Use the keyword stem for generating the discrete signal.
4. Use the keyword plot for generating the continuous signal.
5. Plot the graph.
6. Stop.
Formula used:
Unit sample sequence:
δ(n) = 1, n = 0
0, n ≠ 0
Unit ramp:
r(n) = n, n ≥ 0
0, n < 0
Q1.1 Run program (1) below to generate the unit sample sequence δ(n) and display it.
*Q1.2 What are the purposes of the commands clf, axis, title, xlabel, and ylabel?
*Q1.3 Modify the program to generate a delayed unit sample sequence δ(n -11). Run the
modified program and display the sequence generated.?
N.B: the questions with asterix (*) must be answered in your report.
_____________________________________________________________________________________________
Page | 1
Prepared by: Alem T.
Program 1:
% Generation of a Unit Sample Sequence
clf;
% Generate a vector from -10 to 20
n = -10:20;
% Generate the unit sample sequence
u = [zeros(1,10) 1 zeros(1,20)];
% Plot the unit sample sequence
stem(n,u);
xlabel('Time index n');ylabel('Amplitude');
title('Unit Sample Sequence');
axis([-10 20 0 1.2]);
Q1.4 Run program (2) to generate the unit step sequence u[n] and display it.
*Q1.5 Modify the program to generate advanced unit step sequence u[n + 7]. Run the modified
program and display the sequence generated.
Program 2:
% Generation of a Unit Step Sequence
clf;
% Generate a vector from -10 to 20
n = -10:20;
% Generate the unit step sequence
s = [zeros(1,10) ones(1,21)];
% Plot the unit step sequence
stem(n,s);
xlabel('Time index n');ylabel('Amplitude');
title('Unit Step Sequence');
axis([-10 20 0 1.2]);
Q1.6 Run program (3) to generate the unit ramp sequence r[n] and display it.
Program 3:
% Generation of a Unit Ramp Sequence
clf;
% Generate a vector from 0 to 20
n=0:1:20;
x=n;
stem(n,x);
xlabel('n'); ylabel('x(n)'); title('ramp signal');
_____________________________________________________________________________________________
Page | 2
Prepared by: Alem T.
Program 4:
% Generation of a sinusoidal sequence
n = 0:40;
f = 0.1;
phase = 0;
A = 1.5;
arg = 2*pi*f*n - phase;
x = A*cos(arg);
clf; % Clear old graph
stem(n,x); % Plot the generated sequence
axis([0 40 -2 2]);
grid;
title('Sinusoidal Sequence');
xlabel('Time index n');
ylabel('Amplitude');
axis;
Q1.7: Run Program (4) to generate the sinusoidal sequence and display it.
*Q1.8: What is the frequency of this sequence and how can it be changed? Which parameter
controls the phase of this sequence? Which parameter controls the amplitude of this
sequence? What is the period of this sequence?
*Q1.9: What is the length of this sequence and how can it be changed? Compute the average
power of the generated sinusoidal sequence.
*Q1.10: What is the purposes of the command grid?
Program 5:
% Generation of a complex exponential sequence
clf;
c = -(1/12)+(pi/6)*i;
K = 2;
n = 0:40;
x = K*exp(c*n);
subplot(2,1,1);
stem(n,real(x));
xlabel('Time index n');ylabel('Amplitude');
title('Real part');
subplot(2,1,2);
stem(n,imag(x));
xlabel('Time index n');ylabel('Amplitude');
title('Imaginary part');
Q1.11: Run Program (5) and generate the complex-valued exponential sequence.
*Q1.12: Which parameter controls the rate of growth or decay of this sequence and Which
parameter controls the amplitude of this sequence?
*Q1.13: What will happen if the parameter c is changed to (1/12)+(pi/6)*i?
*Q1.14: What are the purposes of the operators real and imag?
*Q1.15: What is the purpose of the command subplot?
N.B: when you Replace the “stem” command in all Programs with the “plot” command, you
will generate continous time (Analog) signal so if you went to plot Analog signals use the
command “plot”. But DT. Signals “stem” command is used.
_____________________________________________________________________________________________
Page | 3
Prepared by: Alem T.