Tuesday, April 25, 2017

matlab - How to convert time-domain signal to complex envelope?



Matlab and Simulink Communications Toolbox digital demodulators are defined to only work on the complex envelope representation of a baseband signal.


To obtain the time-domain representation of this signal, I believe one takes the real part of the complex envelope.


Given just this real part, how does one convert the time-domain representation of modulated data back into a complex envelope such that a Matlab demodulator will demodulate it?


Application: I'm trying to simulate a simple audio FSK system in Simulink.



Answer



These are the main ideas:



  1. Consider a receiver that picks up a signal r(t). This signal has bandwidth W and is centered on carrier frequency fc.

  2. Using the Hilbert transform, eliminate the negative frequencies of r(t). The resulting signal, r+(t), is called an analytic signal.

  3. Now, downconvert the analytic signal using a complex exponential, so that the spectrum is centered around 0. This signal, called ˜r(t), is the complex envelope of r(t). Its spectrum goes from W/2 to W/2, and its bandwidth is B=W/2.


  4. The complex envelope is almost always complex, but if the spectrum of r(t) is symmetrical around fc, the CE is real. Examples of this are AM DSB and BPSK.


In the transmitter you would do the opposite:



  1. Start with a complex envelope ˜s(t) that represents the information you want to transmit. Its spectrum should go from W/2 to W/2. An example would be a QAM signal with complex symbols.

  2. Upconvert the CE to frequency fc, multiplying by a complex exponential. The result is an analytic signal with only positive frequencies. The signal will be centered around fc and cover the frequency range from fcW/2 to fc+W/2.

  3. Take the real part of the analytic signal to convert it to a real signal that can be physically generated and transmitted.


All of these steps can be accomplished in Matlab. Be sure to read the documentation for the hilbert command. I can't comment on the corresponding Simulink blocks, since I don't use them.


Also note that it is very likely that you don't have to do all this. If you can perform all your simulations using the complex envelope, you'll save a lot of computing time. The reason is that the transmitted and received signals need to be sampled at least at a rate 2(fc+W/2), whereas the complex envelope can be sampled at W real samples per second -- a huge difference for large fc.



No comments:

Post a Comment

periodic trends - Comparing radii in lithium, beryllium, magnesium, aluminium and sodium ions

Apparently the of last four, MgX2+ is closest in radius to LiX+. Is this true, and if so, why would a whole larger shell ($\ce{...