KEMBAR78
Discrete Convolution | PDF | Fourier Transform | Discrete Fourier Transform
0% found this document useful (0 votes)
215 views51 pages

Discrete Convolution

Discrete convolution is a core operation in digital signal processing (DSP) that is commonly misused. It involves multiplying corresponding samples of two signals and summing the products. The output of a discrete-time system can be expressed as the convolution of the input and impulse response. Calculating convolution sums for each output sample involves shifting the impulse response and multiplying/summing the overlapping signal values. Matlab provides a conv function to compute convolutions.

Uploaded by

Smitha Vas
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
215 views51 pages

Discrete Convolution

Discrete convolution is a core operation in digital signal processing (DSP) that is commonly misused. It involves multiplying corresponding samples of two signals and summing the products. The output of a discrete-time system can be expressed as the convolution of the input and impulse response. Calculating convolution sums for each output sample involves shifting the impulse response and multiplying/summing the overlapping signal values. Matlab provides a conv function to compute convolutions.

Uploaded by

Smitha Vas
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 51

Discrete Convolution

Discrete Convolution: The operation by far the most commonly used


in DSP, but also most commonly misused, abused and confused by
uninitiated (=students).

At the heart of any DSP system:


Discrete-time
x[n] System, h[n]
y[n]
Input sequence Output sequence
y[n] = x[n] h[n]

= x[m] h[n m] h[n]: Impulse response of the system
m =

= h[m] x[n m]
m =

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Discrete Convolution
The n dependency of y[n] deserves some care: for each value of n
the convolution sum must be computed separately over all values of a
dummy variable m. So, for each n
1. Rename the independent variable as m. You now have x[m] and h[m]. Flip h[m]
over the origin. This is h[-m]
2. Shift h[-m] as far left as possible to a point n, where the two signals barely
touch. This is h[n-m]
3. Multiply the two signals and sum over all values of m. This is the convolution sum
for the specific n picked above.
4. Shift / move h[-m] to the right by one sample, and obtain a new h[n-m]. Multiply
and sum over all m.
5. Repeat 2~4 until h[n-m] no longer overlaps with x[m], i.e., shifted out of the x[m]
zone.

y[n] = x[n] h[n] = x[m] h[n m] = h[m] x[n m]
m = m =
Digital Signal Processing, 2007 Robi Polikar, Rowan University
Useful Expressions
The following expressions are often useful in calculating convolutions of
analytical discrete signals

1
a = 1 a , a < 1
n
n =0
a k
an = 1 a , a < 1
n=k
N m N +1
a a
= 1 a , a 1
a n
n=m

N 1
1 a N
n , a 1
a = 1 a
n =0 N , a =1

Digital Signal Processing, 2007 Robi Polikar, Rowan University
Convolution Example

n<N1
x[n] = a n u[n]
1 N1 n N 2
h[n] =
0 otherwise


N1<n<N2
0 n < N1

1 a n N1 +1
y[n] = N1 n < N 2
1 a
n N 1 a N 2 N1 +1
a 2 n N2
1 a

n>N2

Digital Signal Processing, 2007 Robi Polikar, Rowan University


In Matlab
Matlab has the built-in convolution function, conv(.)
Be careful, however in setting the time axis

n=-3:7;
x=0.55.^(n+3);
h=[1 1 1 1 1 1 1 1 1 1 1];
y=conv(x,h);
subplot(311)
stem(x)
title(Original signal)
subplot(312)
stem(h) % Use stem for discrete sequences
title(Impulse response / second signal)
subplot(313)
stem(y)
title( convolution result)

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Correlation
An efficient way to compare signals with each other and search for
similarities
The mathematical formulation of correlation is the cross correlation
sequence:


rxy [l ] = x[n] y[n l ]
n =
(note the difference with convolution)

and for the time reversed cross correlation sequence it can easily
be shown that it is related to the original sequence as:


ryx [l ] = y[n]x[n l ] =
n = m =
y[m + l ]x[m] = rxy [l ]
Correlation
autocorrelation is a cross correlation sequence of a series with
itself:

rxx [l ] = x[n]x[n l ]
n =

note that the zero lag term of the autocorrelation sequence is just
the total enery of the signal:
rxx [0] = x [ n] =
n =
2
x

and that an autocorrelation sequence is even for real x[n] since:

rxx [l ] = rxx [l ]
The Frequency Domain
Time domain operation are often not very informative and/or efficient
in signal processing
An alternative representation and characterization of signals and
systems can be made in transform domain
Much more can be said, much more information can be extracted from a signal in
the transform / frequency domain.
Many operations that are complicated in time domain become rather simple
algebraic expressions in transform domain
Most signal processing algorithms and operations become more intuitive in
frequency domain, once the basic concepts of the frequency domain are
understood.

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Frequency Domain
An Example
t=-1:0.001:1;
x=sin(2*pi*50*t);
subplot(211)
Sin(250t)
plot(t(1001:1200),x(1:200)) 1
grid
title('Sin(2\pi50t)') 0.5
xlabel('Time, s')
subplot(212) 0
X=abs(fft(x));
X2=fftshift(X); -0.5
f=-499.9:1000/2001:500;
plot(f,X2); -1
0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2
grid
Time, s
title(' Frequency domain representation of Sin(2\pi50t)')
Frequency domain representation of Sin(250t)
xlabel('Frequency, Hz.')
1000

500
RP
0
-500 -400 -300 -200 -100 0 100 200 300 400 500
Frequency, Hz.

Digital Signal Processing, 2010 Robi Polikar, Rowan University


Frequency Domain
Another Example
t=-1:0.001:1;
x=sin(2*pi*50*t)+sin(2*pi*75*t); Sin(250t)+Sin(275t)
subplot(211) 2
plot(t(1001:1200),x(1:200))
grid 1
title('Sin(2\pi50t)+Sin(2\pi75t)')
xlabel('Time, s') 0
subplot(212)
X=abs(fft(x)); -1
X2=fftshift(X);
f=-499.9:1000/2001:500; -2
plot(f,X2); 0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2
grid Time, s
title(' Frequency domain representation of Frequency domain representation of Sin(250t)+Sin(275t)
Sin(2\pi50t)+Sin(2\pi75t)')
xlabel('Frequency, Hz.') 1000

500

RP
0
-500 -400 -300 -200 -100 0 100 200 300 400 500
Frequency, Hz.

Digital Signal Processing, 2010 Robi Polikar, Rowan University


Frequency Domain
AndAnother Example
Freq_domain_example.m

Sin(2 20t)+4Cos(2 50t)+2Sin(2 100t)


10
t=-1:0.001:1;
x=sin(2*pi*20*t)+4*cos(2*pi*50*t)+2*sin(2*pi*100*t); 5

subplot(211)
0
plot(t(1001:1200),x(1:200))
grid -5

title('Sin(2\pi20t)+4Cos(2\pi50t)+2Sin(2\pi100t)')
-10
xlabel('Time, s') 0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2
Time, s
subplot(212)
Frequency domain representation of Sin(220t)+4Cos(250t)+2Sin(2100t)
X=abs(fft(x)); 4000

X2=fftshift(X);
3000
f=-499.9:1000/2001:500;
plot(f,X2); 2000

grid
1000
title(' Frequency domain representation of
Sin(2\pi20t)+4Cos(2\pi50t)+2Sin(2\pi100t)')
RP
0
-500 -400 -300 -200 -100 0 100 200 300 400 500
xlabel('Frequency, Hz.') Frequency, Hz.

Magnitude spectrum

Digital Signal Processing, 2010 Robi Polikar, Rowan University


The Fourier Transform

Spectrum: A compact representation of the frequency content of a signal


that is composed of sinusoids

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Fourier Who?

An arbitrary function, continuous or with


discontinuities, defined in a finite interval by an
arbitrarily capricious graph can always be
expressed as a sum of sinusoids
J.B.J. Fourier

Jean B. Joseph Fourier December 21, 1807


(1768-1830)

j 2kt / N 1 N 1
F [k ] = f (t )e dt f (t ) = F [k ]e j 2kt / N
2 i = 0

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Jean B. J. Fourier
He announced his discovery in a prize paper on the theory of heat (1807).
The judges: Laplace, Lagrange, Poisson and Legendre
Three of the judges found it incredible that sum of sines and cosines could add up
to anything but an infinitely differential function, but...
Lagrange: Lack of mathematical rigor and generality Denied publication.

Became famous with his other previous work on math, assigned as chair of Ecole Polytechnique
Napoleon took him along to conquer Egypt
Return back after several years
Barely escaped Giyotin!

After 15 years, following several attempts and disappointments and frustration, he published
his results in Theorie Analytique de la Chaleur in 1822 (Analytical Theory of Heat).
In 1829, Dirichlet proved Fouriers claim with very few and non-restricting conditions.

Next 150 years: His ideas expanded and generalized. 1965: Cooley and Tukey--> Fast
Fourier Transform Computational simplicity King of all transforms Countless
number of applications engineering, finance, applied mathematics, etc.

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Fourier Transforms
Fourier Series (FS)
Fouriers original work: A periodic function can be represented as a finite, weighted sum of
sinusoids that are integer multiples of the fundamental frequency 0 of the signal. These
frequencies are said to be harmonically related, or simply harmonics.
(Continuous) Fourier Transform (FT)
Extension of Fourier series to non-periodic functions: Any continuous aperiodic function
can be represented as an infinite sum (integral) of sinusoids. The sinusoids are no longer
integer multiples of a specific frequency anymore.
Discrete Time Fourier Transform (DTFT)
Extension of FT to discrete sequences. Any discrete function can also be represented as an
infinite sum (integral) of sinusoids.
Discrete Fourier Transform (DFT)
Because DTFT is defined as an infinite sum, the frequency representation is not discrete
(but continuous). An extension to DTFT is DFT, where the frequency variable is also
discretized.
Fast Fourier Transform (FFT)
Mathematically identical to DFT, however a significantly more efficient implementation.
FFT is what signal processing made possible today!

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Dirichlet Conditions
(1829)
Before we dive into Fourier transforms, it is important to understand
for which type of functions, Fourier transform can be calculated.
Dirichlet put the final period to the discussion on the feasibility of
Fourier transform by proving the necessary conditions for the
existence of Fourier representations of signals
The signal must have finite number of discontinuities
The signal must have finite number of extremum points within its period
The signal must be absolutely integrable within its period
t 0 +T
x(t ) dt <
t0
How restrictive are these conditions?

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Fourier Series
Any periodic signal x(t) whose fundamental period is T0 (hence,
fundamental frequency f0=1/T0, 0=2f0), can be represented as a
finite sum of complex exponentials (sines and cosines)
That is, a signal however arbitrary and complicated it may be, can be represented as
a sum of simple building blocks

x(t ) ck e j0kt
k

Note that each complex exponential that makes up the sum is an integer multiple
of 0, the fundamental frequency
Hence, the complex exponentials are harmonically related
The coefficients ck , aka Fourier (series) coefficients, are possibly complex
Fourier series (and all other types of Fourier transforms) are complex valued ! That is,
there is a magnitude and phase (angle) term to the Fourier transform!

Digital Signal Processing, 2010 Robi Polikar, Rowan University


Fourier Series
This is the synthesis equation: x(t) is synthesized from its building
blocks, the complex exponentials at integer multiples of 0

x(t ) ck e jk0t
k

k0: kth integer multiple kth harmonic of the fundamental frequency 0


ck: Fourier coefficients how much of kth harmonic exists in the signal
|ck|: Magnitude of the kth harmonic magnitude spectrum of x( t )
Spectrum of x(t)
< ck: Phase of the kth harmonic phase spectrum of x( t )

How to compute the Fourier coefficients, ck?

Digital Signal Processing, 2010 Robi Polikar, Rowan University


Fourier Series
The coefficients ck can be obtained through the analysis equation.

1 t0 T0 jk0t
The limits of the integral can be chosen to
ck x (t ) e dt cover any interval of T0, for example,
T0 t0 [-T0/2 T0/2] or [0 T0] or [-T0 0].

Note that, while x(t) is a sum, ck are obtained through an integral of


complex values.
Why / how?
More importantly, if x(t) is real, then the coefficients satisfy c-k=c*k,
that is |c-k|=|ck| why?

Digital Signal Processing, 2010 Robi Polikar, Rowan University


Trigonometric
Fourier Series
Using the Eulers rule, we can represent the complex Fourier series in
two trigonometric forms:

x(t ) = a0 + (ak cos(k0t ) + bk sin (k0t ))
k =1
2
ak = x(t ) cos(k 0t )dt
T0 T
0
2
x(t ) sin (k 0t )dt
T0 T
bk =
0

As you might have already guessed the trigonometric Fourier


coefficients, ak and bk, are not independent of the complex Fourier
coefficients a0 = 2c0 ak = ck + c k bk = j (ck c k )
a jbk a + jbk
ck = k , c k = k
2 2
Digital Signal Processing, 2007 Robi Polikar, Rowan University
Quick Facts and
An Example
Fourier series are computed for periodic signals (continuous or discrete). A periodic
signal has finite number of discrete spectral components.
Each spectral component is represented by ckand c-k Fourier series coefficients, k=1,2,,N.
Each k represents one of the spectral components at integer multiples of 0, the
fundamental frequency of the signal. These discrete spectral components at 0, 20,,
N0 are called harmonics.
For example, the signal x(t)=cos4t+sin6t has two (four, if you count the negative frequencies)
spectral components. The fundamental frequency is 0=2, and c-3=-1/2j, c3=1/2j, c-2=c2=1/2

ck
k=0 =0 rad/s
1/2 1/2 1/2j k=1 =2 rad/s
k=2 =4 rad/s
-3 -2 -1 0 1 2 3
k k=3 =6 rad/s
-1/2j

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Another
Example
x ( t ) = cos ( 4 t ) + 2 cos (16 t )
Original Signal
5

t=0:0.001:0.5; 0
x=cos(2*pi*2*t)+2*cos(2*pi*8*t);
w0=2*pi*2;
-5
K=5; 0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5
[X x_recon]=fourier_series(x,K,t,w0); Fourier Series Magnitude Coefficients
4

0
-5 -4 -3 -2 -1 0 1 2 3 4 5
Reconstructed Signal
10
p.s. fourier_series() is not
a standard Matlab function. 0
You will be writing this function
as part of next lab.
-10
0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5

Digital Signal Processing, 2007 Robi Polikar, Rowan University


Quick Facts About
Fourier Series
If a signal is even, then all bk=0, and if a signal is odd, then all ak=0
If x(t) is real, then the Fourier series are symmetric, that is, ck=c-k
This is inline with our interpretation of frequency as two phasors rotating at the
same rate but opposite directions.
For real signals, the relationship between complex and trigonometric
representation of Fourier series further simplifies to ak = 2[ck ] bk = 2 Im[ck ]
We also have a third representation for real signals:
kth harmonic

x(t ) = C0 + Ck cos(k0t k )
k =1
a b
C0 = 0 , Ck = ak2 + bk2 , k = tan 1 k
2 ak

Phase angles

DC component Harmonic amplitudes


Digital Signal Processing, 2007 Robi Polikar, Rowan University
Summary
We can often tell much more about a signal by looking at its
frequency content, that is, its spectrum.
For continuous time signals, that are also periodic with a fundamental
frequency of 0, Fourier series gives us the spectrum of the signal
The Fourier series of such a signal is a series of impulses at integer multiples of 0.
These impulses in the frequency domain represent the harmonics of the signal

Remember: the term ejo represents one spectral component at frequency 0


Cos(0t) has two such complex exponentials in it, at 0. Therefore, each cosine
at a particular frequency 0 consists of two spectral components, one at each of
0.
e j o t + e j o t
Cos ( 0t ) =
2
e j o t e j o t
Sin ( 0t ) =
2j

Digital Signal Processing, 2007 Robi Polikar, Rowan University


The Discrete Fourier Transform

X = x [ n ] e jn
n=

and

1
x [ n ]=
2
X e jn d

X ( + 2 k ) = x [n ] e
n=
j ( + 2 k ) n
= x [n ] e
n=
jn
e j2kn


= x [n ] e
n=
j n
= X ( ) k
n=
( ) = [n ] e
n=
j n
=1

n
x [ n] = e ; X ( ) = 2 ( + 2k )
j0
0
k=
X (e j0 n ) + X (e j0 n )
=
2
x [ n] = [ n]
n
( ( ) < 1) ; X ( ) =
0
1
j0
1 e

X ( ) = [n ] e
n j n
= n e j n
n= n= 0

( e )
j n 1
= =
n= 0 1 e j

n
x [ n] = e ; X ( ) = 2 ( + 2k )
j0
0
k=
dX ( )
nx [ n ] j
d
x [ n n0 ] e X ()
jn0

n
x [ n ] X ( 0 )
j0
e

1
General form: g [ n] .h
[ n] = G ( ) .H
( ) d
n= 2


1
g [ n] .g
[ n] = G ( ) .G
( ) d= g
n= 2
Properties of
Fourier Transform

Property Signal Fourier Transform

The table is from Signals and Systems, H.P. Hsu


(Schaums series), which uses for continuous
frequencies. Replace all with to be consistent with
our, and the textbook notation.
Digital Signal Processing, 2007 Robi Polikar, Rowan University
Common Fourier
Transform Pairs

x(t) X()

Digital Signal Processing, 2010 Robi Polikar, Rowan University

You might also like