Lab 02: Introduction To Complex Exponentials - Multipath: Signal Processing First
Lab 02: Introduction To Complex Exponentials - Multipath: Signal Processing First
Lab 02: Introduction To Complex Exponentials - Multipath: Signal Processing First
Pre-Lab and Warm-Up: You should read at least the Pre-Lab and Warm-up sections of this lab assignment and go over all exercises in the Pre-Lab section before going to your assigned lab session. Verication: The Warm-up section of each lab must be completed during your assigned Lab time and the steps marked Instructor Verication must also be signed off during the lab time. One of the laboratory instructors must verify the appropriate steps by signing on the Instructor Verication line. When you have completed a step that requires verication, simply demonstrate the step to the TA or instructor. Turn in the completed verication sheet to your TA when you leave the lab. Lab Report: It is only necessary to turn in a report on Sections 5 and 6 with graphs and explanations. You are asked to label the axes of your plots and include a title for every plot. In order to keep track of plots, include your plot inlined within your report. If you are unsure about what is expected, ask the TA who will grade your report.
Introduction
The goal of this laboratory is to gain familiarity with complex numbers and their use in representing sinusoidal signals such as x(t) = A cos(t + ) as complex exponentials z(t) = Aej ejt . The key is to use the appropriate complex amplitude together with the real part operator as follows: x(t) = A cos(t + ) = e{Aej ejt }
Overview
Manipulating sinusoidal functions using complex exponentials turns trigonometric problems into simple arithmetic and algebra. In this lab, we rst review the complex exponential signal and the phasor addition property needed for adding cosine waves. Then we will use M ATLAB to make plots of phasor diagrams that show the vector addition needed when adding sinusoids.
2.1
M ATLAB can be used to compute complex-valued formulas and also to display the results as vector or phasor diagrams. For this purpose several new M ATLAB functions have been written and are available on the SP First CD-ROM. Look for the MATLAB Files link just below the link for this lab. Make sure that this toolbox has been installed1 by doing help on the new M-les: zvect, zcat, ucplot, zcoords, and zprint. Each of these functions can plot (or print) several complex numbers at once, when the input is formed into a vector of complex numbers. For example, the following function call will plot ve vectors all on one graph: zvect( [ 1+j, j, 3-4*j, exp(j*pi), exp(2j*pi/3) ] )
1 Correct installation means that the spfirst directory will be on the M ATLAB path. Try help path if you need more information.
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
Here are some of M ATLABs built-in complex number operators: conj abs angle real imag i,j x = 3 + 4i exp(j*theta) Complex conjugate Magnitude Angle (or phase) in radians Real part Imaginary part pre-dened as 1
i sufx denes imaginary constant (same for j sufx) Function for the complex exponential ej
Each of these functions takes a vector (or matrix) as its input argument and operates on each element of the vector. Notice that the function names mag() and phase() do not exist in M ATLAB.2 When unsure about a command, use help.
2.2
Recall that sinusoids may be expressed as the real part of a complex exponential: x(t) = A cos (2f0 t + ) = e Aej ej2f0 t The Phasor Addition Rule shows how to add several sinusoids:
N
(1)
x(t) =
k=1
Ak cos(2f0 t + k )
(2)
assuming that each sinusoid in the sum has the same frequency, f0 . This sum is difcult to simplify using trigonometric identities, but it reduces to an algebraic sum of complex numbers when solved using complex exponentials. If we represent each sinusoid with its complex amplitude Xk = Ak ejk Then the complex amplitude of the sum is
N
(3)
Xs =
k=1
Xk = As ejs
(4)
Based on this complex number manipulation, the Phasor Addition Rule implies that the amplitude and phase of x(t) in equation (2) are As and s , so x(t) = As cos(2f0 t + s ) (5)
We see that the sum signal x(t) in (2) and (5) is a single sinusoid that still has the same frequency, f0 , and it is periodic with period T0 = 1/f0 .
2 In the latest release of M ATLAB a function called phase() is dened in a rarely used toolbox; it does more or less the same thing as angle() but also attempts to add multiples of 2 when processing a vector.
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
2.3
Harmonic Sinusoids
There is an important extension where x(t) is the sum of N cosine waves whose frequencies (fk ) are different. If we concentrate on the case where the (fk ) are all multiples of one basic frequency f0 , i.e., fk = kf0 (H ARMONIC F REQUENCIES )
xh (t) =
k=1
Ak cos(2kf0 t + k ) = e
k=1
Xk ej2kf0 t
(6)
This particular signal xh (t) has the property that it is also periodic with period T0 = 1/f0 , because each of the cosines in the sum repeats with period T0 . The frequency f0 is called the fundamental frequency, and T0 is called the fundamental period. (Unlike the single frequency case, there is no phasor addition theorem here to combine the harmonic sinusoids.)
Pre-Lab
Do all the exercises in this section before attending the regularly scheduled lab section.
3.1
Complex Numbers
This section will test your understanding of complex numbers. Use z1 = 10ej2/3 and z2 = 5 + j5 for all parts of this section. (a) Enter the complex numbers z1 and z2 in M ATLAB. Plot them with zvect() and print them with zprint(). When unsure about a command, use help. Whenever you make a plot with zvect() or zcat(), it is helpful to provide axes for reference. An x-y axis and the unit circle can be superimposed on your zvect() plot by doing the following: hold on, zcoords, ucplot, hold off (b) The function zcat() can be used to plot vectors in a head-to-tail format. Execute the statement zcat([j,-1,-2j,1]); to see how zcat() works when its input is a vector of complex numbers. (c) Compute z1 + z2 and plot the sum using zvect(). Then use zcat() to plot z1 and z2 as 2 vectors head-to-tail, thus illustrating the vector sum. Use hold on to put all 3 vectors on the same plot. If you want to see the numerical value of the sum, use zprint() to display it. (d) Compute z1 z2 and plot the answer using zvect() to show how the angles of z1 and z2 determine the angle of the product. Use zprint() to display the result numerically. (e) Compute z2 /z1 and plot the answers using zvect() to show how the angles of z1 and z2 determine the angle of the quotient. Use zprint() to display the result numerically. (f) Compute the conjugate z for both z1 and z2 and plot the results. In M ATLAB, see help conj. Display the results numerically with zprint.
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
(g) Compute the inverse 1/z for both z1 and z2 and plot the results. Display the results numerically with zprint.
(h) Make a 2 2 subplot that displays the following four plots in one gure window: (i) z1 and z2 (ii) z1 on the same plot; (iii) 1/z and 1/z on the same plot; and (iv) z z . Add a unit circle and x-y and z2 1 2 1 2 axis to each plot for reference.
3.2
ZDrill
There is a complex numbers drill program called: zdrill which uses a GUI to generate complex number problems and check your answers. Go to Appendix A demos to download and run. Please spend some time with this drill since it is very useful in helping you to get a feel for complex arithmetic.
n k h t
3.3
Vectorization
The power of M ATLAB comes from its matrix-vector syntax. In most cases, loops can be replaced with vector operations because functions such as exp() and cos() are dened for vector inputs, e.g., cos(vv) = [cos(vv(1)), cos(vv(2)), cos(vv(3)), ... cos(vv(N))]
where vv is an N -element row vector. Vectorization can be used to simplify your code. If you have the following code that plots a certain signal,
M = 200; for k=1:M x(k) = k; y(k) = cos( 0.001*pi*x(k)*x(k) ); end plot( x, y, ro- ) then you can replace the for loop and get the same result with 3 lines of code: M = 200; y = cos( 0.001*pi*(1:M).*(1:M) ); plot( 1:M, y, ro- ) Use this vectorization idea to write 2 or 3 lines of code that will perform the same task as the following M ATLAB script without using a for loop. (Note: there is a difference between the two operations xx*xx and xx.*xx when xx is a vector.) %--- make a plot of a weird signal N = 200; for k=1:N xk(k) = k/50; rk(k) = sqrt( xk(k)*xk(k) + 2.25 ); sig(k) = exp(j*2*pi*rk(k)); end plot( xk, real(sig), mo- )
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
3.4
Functions
Functions are a special type of M-le that can accept inputs (matrices and vectors) and also return outputs. The keyword function must appear as the rst word in the ASCII le that denes the function, and the rst line of the M-le denes how the function will pass input and output arguments. The le extension must be lower case m as in my func.m. See Section B.5 in Appendix B for more discussion. The following function has a few mistakes. Before looking at the correct one below, try to nd these mistakes (there are at least three): matlab mfile [xx,tt] = badcos(ff,dur) %BADCOS Function to generate a cosine wave % usage: % xx = badcos(ff,dur) % ff = desired frequency in Hz % dur = duration of the waveform in seconds % tt = 0:1/(100*ff):dur; %-- gives 100 samples per period badcos = cos(2*pi*freeq*tt); The corrected function should look something like: function [xx,tt] = goodcos(ff,dur) tt = 0:1/(100*ff):dur; %-- gives 100 samples per period xx = cos(2*pi*ff*tt); Notice the word function in the rst line. Also, freeq has not been dened before being used. Finally, the function has xx as an output and hence xx should appear in the left-hand side of at least one assignment line within the function body. The function name is not used to hold values produced in the function.
4.2
Since we will generate many functions that are a sum of sinusoids, it will be convenient to have a function for this operation. To be general, we will allow the frequency of each component (fk ) to be different. The following expressions are equivalent if we dene the complex amplitudes Xk as Xk = Ak ejk .
N
x(t)
e
k=1
Xk ej2fk t
(7)
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
x(t)
=
k=1
Ak cos(2fk t + k )
(8)
4.2.1
Write an M-le called syn sin.m that will synthesize a waveform in the form of (7). Although for loops are rather inefcient in M ATLAB, you must write the function with one loop in this lab. The rst few statements of the M-le are the comment linesthey should look like: function [xx,tt] = syn_sin(fk, Xk, fs, dur, tstart) %SYN_SIN Function to synthesize a sum of cosine waves % usage: % [xx,tt] = syn_sin(fk, Xk, fs, dur, tstart) % fk = vector of frequencies % (these could be negative or positive) % Xk = vector of complex amplitudes: Amp*e(j*phase) % fs = the number of samples per second for the time axis % dur = total time duration of the signal % tstart = starting time (default is zero, if you make this input optional) % xx = vector of sinusoidal values % tt = vector of times, for the time axis % % Note: fk and Xk must be the same length. % Xk(1) corresponds to frequency fk(1), % Xk(2) corresponds to frequency fk(2), etc. The M ATLAB syntax length(fk) returns the number of elements in the vector fk, so we do not need a separate input argument for the number of frequencies. On the other hand, the programmer (thats you) should provide error checking to make sure that the lengths of fk and Xk are the same. See help error. Finally, notice that the input fs denes the number of samples per second for the cosine generation; in other words, we are no longer constrained to using 20 samples per period. Include a copy of the M ATLAB code with your lab report.
4.2.2
Default Inputs
You can make the last input argument(s) take on default values if you use the nargin operator in M ATLAB. For example, tstart can be made optional by including the following line of code: if nargin<5, tstart=0, end %--default value is zero
4.2.3
Testing
In order to use this M-le to synthesize harmonic waveforms, you must choose the entries in the frequency vector to be integer multiples of some desired fundamental frequency. Try the following test and plot the result. [xx0,tt0] = syn_sin([0,100,250],[10,14*exp(-j*pi/3),8*j],10000,0.1,0); %-Period = ? Measure the period of xx0 by hand. Then compare the period of xx0 to the periods of the three sinusoids that make up xx0, and write an explanation on the verication sheet of why the period of xx0 is longer. Instructor Verication (separate page)
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
In M ATLAB consult help on exp, real and imag. Be aware that you can also use the DSP First function zprint to print the polar and rectangular forms of any vector of complex numbers. (a) Generate the signal x(t) = e{2ejt + 2ej(t 1.25) + (1 j)ejt } and make a plot versus t. Use the syn sin function and take a range for t that will cover three periods starting at t = 1 secs. Include the 2 M ATLAB code with your report. (b) From the plot of x(t) versus t, measure the frequency, phase and amplitude of the sinusoidal signal by hand. Show annotations on the plots to indicate how these measurements were made and what the values are. Compare to the calculation in part (c). (c) Use the phasor addition theorem and M ATLAB to determine the magnitude and phase of x(t).
y TRANSMITTER (0,dt)
RE F LE CT E D
PA TH
Figure 1: Scenario for multipath in mobile radio. A vehicle traveling on the roadway (to the right) receives signals from two sources: the transmitter and a reector located at (dxr , dyr ).
are themselves delayed versions of the transmitted signal, s(t). (a) The amount of the delay (in seconds) can be computed for both propagation paths. First of all, consider the direct path. The time delay is the distance divided by the speed of light (3 108 m/s). Write a mathematical expression for the time delay in terms of the vehicle position xv and the transmitter location (0, dt ). Call this delay time t1 and express it as a function of xv , i.e., t1 (xv ). (b) Now write a mathematical formula for the time delay of the signal that travels the reected path from the transmitter at (0, dt ) to the reector at (dxr , dyr ) and then to the vehicle at (xv , 0). Call this delay time t2 and make sure that you also express it as a function of xv , i.e., t2 (xv ). In this case, you must add together two delays: transmitter to reector and then reector to vehicle.
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
ATH TP EC DIR
VEHICLE
xv
(c) The received signal at the vehicle, rv (t), is the sum of the two delayed copies of the transmitter signal rv (t) = s(t t1 ) s(t t2 ) where s() is the transmitted signal, and the minus sign accounts for fact that the reection reverses the phase of the reected signal.3 Assume that the source signal s(t) is a zero-phase unit-amplitude sinusoid at frequency f0 = 150 MHz; and also assume that the transmitter is located at (0, 1500) meters and the reector at (100, 900) meters. Then the received signal is the sum of two sinusoids. Make a plot of rv (t) when the vehicle position is xv = 0 meters. Plot 3 periods of rv (t) and then measure its maximum amplitude. (d) Repeat the work in part (c), but use the complex amplitudes instead. Explain how a single complex addition, followed by a magnitude operation can be used to nd the amplitude of rv (t). (e) Our aim in the rest of this lab is to make a plot of signal strength versus vehicle position (xv ). One approach would be to repeat the process in part (c) for every position, i.e., generate the resultant sinusoid and measure its amplitude. However, that would be a huge waste of computation. Instead, the complex amplitude approach in part (d) is a much more efcient method. Derive a mathematical expression for complex amplitudes of each delayed sinusoid as a function of position xv . Then write a M ATLAB program that will generate the time delays, form the complex amplitudes, and then add the complex amplitudes. Have the M ATLAB program loop through the entire set of vehicle positions specied in part (f) below. Include this M ATLAB code in your report and explain how it works. Vectorization: It is likely that your previous programming skills would lead you to write a loop to do this implementation. The loop would run over all possible values of xv , and would add the two complex amplitudes calculated at each xv . However, there is a much more efcient way in M ATLAB, if you think in terms of vectors (which are really lists of numbers). In the vector strategy, you would make a vector containing all the vehicle positions; then do the distance and time delay calculations to generate a vector of time delays; next, a vector of complex amplitudes would be formed. In each of these calculations, only one line of code is needed and no loops. You need two vectors of complex amplitudes (one for the direct path and the other for the reected path), so the whole process is done twice and then you can perform a vector add of the two complex amplitudes. (f) Utilize the M ATLAB program from the previous part to generate a plot of signal strength versus vehicle position, xv , over the interval from 0 meters to +300 meters.4 Assume that signal strength is dened to be the peak value of the received sinusoid, rv (t). State how you get the peak value from the complex amplitude. (g) Explain your results from the previous part. In particular, what are the largest and smallest values of received signal strength? Why do we get those values? Are there vehicle positions where we get complete signal cancellation? If so, determine those vehicle positions.
3 For simplicity we are ignoring propagation losses: When a radio signal propagates over a distance R, its amplitude will be reduced by an amount that is inversely proportional to R2 . 4 M ATLAB works on vectors so you will have to produce a vector of positions starting at 0 and ending at +300 with a spacing that is small enough to capture all the variations in signal strength.
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.
Name:
Date of Lab:
Part 4.1 Demonstrate that your one cos function is correct by plotting a sinusoidal signal with the given parameters. Use the space below to calculate the period of the sinusoid. Veried: Date/Time:
Part 4.2.3 Show that your syn sin.m function is correct by running the test in Section 4.2.3 and plotting the result. Measure the period(s) and explain why the period of xx0 is longer that the periods of the signals used to form xx0. Write your explanations in the space below. Veried: Date/Time:
McClellan, Schafer, and Yoder, Signal Processing First, ISBN 0-13-065562-7. Prentice Hall, Upper Saddle River, NJ 07458. c 2003 Pearson Education, Inc.