Key focus: Demodulation of phase modulated signal by extracting instantaneous phase can be done using Hilbert transform. Hands-on demo in Python & Matlab.
Phase modulated signal:
The concept of instantaneous amplitude/phase/frequency are fundamental to information communication and appears in many signal processing application. We know that a monochromatic signal of form x(t) = a cos(ω t + ɸ) cannot carry any information. To carry information, the signal need to be modulated. Different types of modulations can be performed – amplitude modulation, phase modulation / frequency modulation.
In amplitude modulation, the information is encoded as variations in the amplitude of a carrier signal. Demodulation of an amplitude modulated signal, involves extraction of envelope of the modulated signal. This was discussed and demonstrated here.
This article is part of the following books |
In phase modulation, the information is encoded as variations in the phase of the carrier signal. In its generic form, a phase modulated signal is expressed as an information-bearing sinusoidal signal modulating another sinusoidal carrier signal
where, m(t) = α sin (2 π fm t + θ ) represents the information-bearing modulating signal, with the following parameters
α – amplitude of the modulating sinusoidal signal
fm – frequency of the modulating sinusoidal signal
θ – phase offset of the modulating sinusoidal signal
The carrier signal has the following parameters
A – amplitude of the carrier
fc – frequency of the carrier and fc>>fm
β – phase offset of the carrier
Demodulating a phase modulated signal:
The phase modulated signal shown in equation (1), can be simply expressed as
Here, ɸ(t) is the instantaneous phase that varies according to the information signal m(t).
A phase modulated signal of form x(t) can be demodulated by forming an analytic signal by applying Hilbert transform and then extracting the instantaneous phase. This method is explained here.
We note that the instantaneous phase is ɸ(t) = 2 π fc t + β + α sin (2 π fm t + θ) is linear in time, that is proportional to 2 π fc t . This linear offset needs to be subtracted from the instantaneous phase to obtained the information bearing modulated signal. If the carrier frequency is known at the receiver, this can be done easily. If not, the carrier frequency term 2 π fc t needs to be estimated using a linear fit of the unwrapped instantaneous phase. The following Matlab and Python codes demonstrate all these methods.
Matlab code
%Demonstrate simple Phase Demodulation using Hilbert transform clearvars; clc; fc = 240; %carrier frequency fm = 10; %frequency of modulating signal alpha = 1; %amplitude of modulating signal theta = pi/4; %phase offset of modulating signal beta = pi/5; %constant carrier phase offset receiverKnowsCarrier= 'False'; %If receiver knows the carrier frequency & phase offset fs = 8*fc; %sampling frequency duration = 0.5; %duration of the signal t = 0:1/fs:1-1/fs; %time base %Phase Modulation m_t = alpha*sin(2*pi*fm*t + theta); %modulating signal x = cos(2*pi*fc*t + beta + m_t ); %modulated signal figure(); subplot(2,1,1) plot(t,m_t) %plot modulating signal title('Modulating signal'); xlabel('t'); ylabel('m(t)') subplot(2,1,2) plot(t,x) %plot modulated signal title('Modulated signal'); xlabel('t');ylabel('x(t)') %Add AWGN noise to the transmitted signal nMean = 0; %noise mean nSigma = 0.1; %noise sigma n = nMean + nSigma*randn(size(t)); %awgn noise r = x + n; %noisy received signal %Demodulation of the noisy Phase Modulated signal z= hilbert(r); %form the analytical signal from the received vector inst_phase = unwrap(angle(z)); %instaneous phase %If receiver don't know the carrier, estimate the subtraction term if strcmpi(receiverKnowsCarrier,'True') offsetTerm = 2*pi*fc*t+beta; %if carrier frequency & phase offset is known else p = polyfit(t,inst_phase,1); %linearly fit the instaneous phase estimated = polyval(p,t); %re-evaluate the offset term using the fitted values offsetTerm = estimated; end demodulated = inst_phase - offsetTerm; figure() plot(t,demodulated); %demodulated signal title('Demodulated signal'); xlabel('n'); ylabel('\hat{m(t)}');
Python code
import numpy as np from scipy.signal import hilbert import matplotlib.pyplot as plt PI = np.pi fc = 240 #carrier frequency fm = 10 #frequency of modulating signal alpha = 1 #amplitude of modulating signal theta = PI/4 #phase offset of modulating signal beta = PI/5 #constant carrier phase offset receiverKnowsCarrier= False; #If receiver knows the carrier frequency & phase offset fs = 8*fc #sampling frequency duration = 0.5 #duration of the signal t = np.arange(int(fs*duration)) / fs #time base #Phase Modulation m_t = alpha*np.sin(2*PI*fm*t + theta) #modulating signal x = np.cos(2*PI*fc*t + beta + m_t ) #modulated signal plt.figure() plt.subplot(2,1,1) plt.plot(t,m_t) #plot modulating signal plt.title('Modulating signal') plt.xlabel('t') plt.ylabel('m(t)') plt.subplot(2,1,2) plt.plot(t,x) #plot modulated signal plt.title('Modulated signal') plt.xlabel('t') plt.ylabel('x(t)') #Add AWGN noise to the transmitted signal nMean = 0 #noise mean nSigma = 0.1 #noise sigma n = np.random.normal(nMean, nSigma, len(t)) r = x + n #noisy received signal #Demodulation of the noisy Phase Modulated signal z= hilbert(r) #form the analytical signal from the received vector inst_phase = np.unwrap(np.angle(z))#instaneous phase #If receiver don't know the carrier, estimate the subtraction term if receiverKnowsCarrier: offsetTerm = 2*PI*fc*t+beta; #if carrier frequency & phase offset is known else: p = np.poly1d(np.polyfit(t,inst_phase,1)) #linearly fit the instaneous phase estimated = p(t) #re-evaluate the offset term using the fitted values offsetTerm = estimated demodulated = inst_phase - offsetTerm plt.figure() plt.plot(t,demodulated) #demodulated signal plt.title('Demodulated signal') plt.xlabel('n') plt.ylabel('\hat{m(t)}')
Results
Rate this article:
For further reading
Topics in this chapter
Books by the author
Wireless Communication Systems in Matlab Second Edition(PDF) Note: There is a rating embedded within this post, please visit this post to rate it. | Digital Modulations using Python (PDF ebook) Note: There is a rating embedded within this post, please visit this post to rate it. | Digital Modulations using Matlab (PDF ebook) Note: There is a rating embedded within this post, please visit this post to rate it. |
Hand-picked Best books on Communication Engineering Best books on Signal Processing |
Hi,
In section 1.8 of MatLab book you mentioned one of the two requirements (equation 1.76) is that the analytic signal needs to satisfy orthogonality requirement.
My question is, If I were to create I and Q samples for a signal to be transmitted, do they also have to meet the same requirement. I also have some files with IQ samples that were transmitted over the air, received and then recorded and they are not orthogonal. Am I misunderstanding the reason of this requirement?
If I want to display the power spectrum density of these samples, do I need to simply use fft() of the given complex samples or use hilbert() of the real values to ensure orthogonality. I know either way only the one-sided spectrum will be displayed. I have included the first 10 samples of my file for convenience. Thanks.
array([ 0.40649414-0.1227417j , -0.36132812+0.25732422j,
0.26293945-0.35986328j, -0.12719727+0.40551758j,
-0.02508545-0.39770508j, 0.1739502 +0.32714844j,
-0.30200195-0.21472168j, 0.38134766+0.07275391j,
-0.40698242+0.08276367j, 0.37402344-0.22644043j], dtype=complex64)
Thanks, little mistake in the top section. should be fc >> fm
Thanks for catching the mistake. It is now corrected.
Hey Mathuranathan, thank you very much for this new article! It really helped me to understand the phase demodulation using Hilbert Transform. Using practical examples and codes after the theory in a article is such a great idea! Once again, thank you very much!!
Thanks to you for giving the lead for this new article 🙂 !!!