In reality, multiple radio stations operate in the same metro area, or market. When you tune in a signal at 750 kHz, another signal may be at 760 kHz. To find out whether the adjacent signal impacts the simple receiver design, assume that the interference is a single tone, Aicos(2πfit). The received signal is now of the form
data:image/s3,"s3://crabby-images/fb1ff/fb1ff57196a88e247ea8d287785a3540d51089ea" alt="image0.jpg"
with fi assumed to lie just outside the +/– 5-kHz channel bandwidth centered on fc.
Using a generalized version of the phasor addition formula, you can show that the received envelope with single-tone interference is as follows:
data:image/s3,"s3://crabby-images/e410c/e410cf38ac8c3e1e2f2824c4996b82d38fdad6f0" alt="image1.jpg"
Note that
data:image/s3,"s3://crabby-images/a3ced/a3ceda0b0805926bd8640e8ad23b120f2fea70b0" alt="image2.jpg"
The envelope detector recovers envelope R(t). To find R(t) for a new signal model, use the phasor additional formula, which can be shown to hold for time-varying amplitudes and phases of the constituent terms. The enhanced formula states that
data:image/s3,"s3://crabby-images/ea515/ea515b16e4de4803f3c2d5867cff76e49ddc3013" alt="image3.jpg"
where
data:image/s3,"s3://crabby-images/8af74/8af74f46933ec61e5146316e6a1f7050ebb2c699" alt="image4.jpg"
The key to this formula working is the common f0 found in each cosine term.
For AM plus single-tone interference, you can make the formula work by adding and subtracting fc in the interference term:
data:image/s3,"s3://crabby-images/ff646/ff64688ba7bf9f0a0d07c603ab1662d88f366039" alt="image5.jpg"
In the formula A1(t) = Ac[1 + am(t)],
data:image/s3,"s3://crabby-images/56d57/56d570169fa80e99a490152817d029a5bfd575a7" alt="image6.jpg"
Now, calculate
data:image/s3,"s3://crabby-images/df8c6/df8c6d6e607f5baae2d869c7ea28e97ba85a3f9f" alt="image7.jpg"
Add these complex numbers in rectangular form and then find the magnitude:
data:image/s3,"s3://crabby-images/70b26/70b26bdcd0e5c2b1a8ed4996f7823b31244f6728" alt="image8.jpg"
The last line follows from
data:image/s3,"s3://crabby-images/33ce1/33ce1203a7baa3240e03102f8d9080982d61f9d3" alt="image9.jpg"
Because
data:image/s3,"s3://crabby-images/0f1a6/0f1a6766adb8b14e61b301ac04b9c916923b20ac" alt="image10.jpg"
you can combine the terms and drop the absolute value. As a check, if Ai = 0, that is, no interference, the result for R(t) reduces to
data:image/s3,"s3://crabby-images/a3670/a3670c776222306808d5ff1b111bdcbada8afd5a" alt="image11.jpg"
The envelope detector is relatively easy to implement in hardware, but it’s a little difficult to analyze. You can explore the model for R(t) to get a feel for what’s going on. For starters, the input/output relationship is nonlinear, as evidenced by the squares and square root operations. Even with Ai= 0, R(t) contains an absolute value. At this point, assume m(t) = cos(2πfmt) as simple test case.
The Python function env_plot(t,Ac,Am,fm,Ai,fi) allows R(t) to be plotted as well as its spectrum. The spectrum PR(f) is a result of using PyLab’s psd() function.
In [<b>346</b>]: def env_plot(t,Ac,Am,fm,Ai,fi): ...: R = sqrt((Ac+Am*cos(2*pi*fm*t) +Ai*cos(2*pi*dfi*t))**2 +(Ai*sin(2*pi*dfi*t))**2) ..: return R In [<b>347</b>]: t = arange(0,20,1/500.) # T=20ms, fs=500 kHz
Exercise the function by using a time vector running over 20 ms at an effective sampling rate of 500 ksps and then plot time-domain and frequency-domain results side by side (see the 3 x 2 subplot array in the figure).
Set
data:image/s3,"s3://crabby-images/ce4be/ce4be08fc073ff151c7a5784dbef3349917ff392" alt="image12.jpg"
Also set Am = 0.5, which is equivalent to setting a = 0.5 (50 percent modulation depth). The value of Ai steps over 0, 0.1, and 1.0. The 2-kHz message is within the 5-kHz message bandwidth requirement and
data:image/s3,"s3://crabby-images/b467b/b467b5d91b2e680bc40e53331109f6b29ae6456f" alt="image13.jpg"
kHz for the interference places it in the adjacent channel (5 kHz is the crossover frequency).
Here are the primary IPython command line entries:
In [<b>447</b>]: R = env_plot(t,1,.5,2,0,7) In [<b>449</b>]: plot(t,R) In [<b>454</b>]: psd(R,2**13,500); In [<b>457</b>]: R = env_plot(t,1,.5,2,0.1,7) In [<b>459</b>]: plot(t,R) In [<b>464</b>]: psd(R,2**13,500); In [<b>467</b>]: R = env_plot(t,1,.5,2,1,7) In [<b>469</b>]: plot(t,R) In [<b>475</b>]: psd(R,2**13,500);
![[Credit: Illustration by Mark Wickert, PhD]](https://cdn.prod.website-files.com/6634a8f8dd9b2a63c9e6be83/669d58029b9fd2e28febb0c1_379631.image14.jpeg)
The only way to eliminate or reduce the interference is with a BPF in front of the envelope detector. The superheterodyne option is a good choice here, because the BPF doesn’t need to be tunable. At first, you may be disturbed that an out-of-band signal can produce in-band interference, but you should always expect the unexpected from nonlinearities. The upside is that the receiver design is still low cost.