Project 1 Matched Filters: Applications of Cross-Correlation
Project 1 Matched Filters: Applications of Cross-Correlation
Project 1 Matched Filters: Applications of Cross-Correlation
Project 1
One possible application of cross-correlation is the detection of a signal embedded within noise. The
signal can be estimated by cross-correlating a template signal with the input signal. The template signal,
h[n], is considered to be known a-priori. Detection is accomplished by time-reversing the template and
convolving it with the input signal. Maxima observed in the output signal indicate lag indices where the
template and the shape of interest in the noisy signal are aligned. h[n] is referred to as a matched lter, i.e.,
a lter which is custom-designed to detect the presence of a specic structure within the input signal, recall
from class that x[n] ? h[−n] = rxh [n].
ECGR 4124/5124 Task 1
This task has students detect the phase and period of a sinusoid embedded within a noisy signal. To
do so, we generate a sinusoidal with known frequency but unknown phase and corrupt this sinusoid with
additive random noise (steps (a,b)). We then compute a zero phase template of the sinusoid consisting of
K samples using the known frequency of the sinusoid (step (c)). We then attempt to detect the presence of
the unknown sinusoid by cross-correlating the template and the noisy signal (step (d)) by detecting peaks,
i.e., local maxima in the output signal from the cross-correlation.
π
1. Generate a sinusoidal sequence x[n] = cos( 15 n + φ) 1 ≤ n ≤ 200 and φ = 0.
2. Corrupt this signal with additive uniformly distributed noise e[n] of amplitude ±15 with distribution
U ∼ [−0.5, 0.5]. For a length N sequence, you can generate the noise with the following MATLAB
code: noisevals = 30*(rand(N,1)-0.5);
π
3. Compute matched lters of varying length hK [n] = cos( 15 n) where 0≤n<K and K = 10, 20, 40, 80.
4. Compute the cross-correlation of the noisy signal, x[n] + e, and h[n].
ECGR 4124/5124 Task 1 (30 pts)
To Turn in:
You are responsible for turning in the following objects IN THE ORDER LISTED BELOW. Deductions
will be made for reports which are messy and dicult to comprehend. Using your MATLAB
program for steps 1-4 provide the following:
1. (5pts) Turn in your MATLAB code for computing steps 1-4. NO MATLAB CODE IMPLIES NO
CREDIT FOR ANY OF YOUR SOLUTIONS. These points are awarded for code that is clearly
written and follows the guidelines of the project.
2. (5pts) Using subplot(), plot the cross-correlation signals for each value of K as a 4x1 (4-row,1-column)
matrix of plots.
3. (5pts) Use the location of peaks in the output to estimate the period of the noisy sinusoidal input x[n].
State the estimated value of the sinusoid period.
4. (5pts) Provide a 1-paragraph explanation of how the variable K impacts the estimation of the period.
5. (5pts) If the noise amplitude were increased, how would you change h[n] to get a better estimate?
6. (5pts) Is it also possible to estimate the phase of the function if φ 6= 0? If so, give an idea of how you
would do this?
Hint : From the program above, let φ=π or φ= π
2 and observe how the value of the indices of your
peaks change.
1
ECGR 4124/5124 Task 2
This task has students detect the frequency of a sinusoid embedded within a noisy signal. To do so, we
generate a set of candidate sinusoidal functions, each representing our guess for the unknown frequency. We
then cross-correlate these functions with the input signal and then use the magnitude of the peaks in the
output as a score for the presence of each frequency in the input signal.
Let our signal be a sinusoid x(t) containing an unknown frequency that lies in the range from 1 Hz to 2
Hz . This signal is sampled at a rate of 30 samples per second by an analog-to-digital converter to create a
digital signal x[n]. In this circumstance we will proceed as follows:
1. Hypothesize a sinusoidal sequence having frequencies ranging from f = [1Hz, 2Hz] in increments of
0.2 Hz . Create a digital lter h[n] to cross-correlate with the input x[n].
2. Adjust values of your lter coecients so that the sum of the lter coecients is equal to 0. This can
be accomplished by sampling the sinusoid symmetrically about the origin since the sine function is odd
symmetric, i.e., sin(x) = − sin(−x). Note that since sin(0) = 0 the sample h[0] has no contribution to
either your lter or the output value.
3. For each sequence, cross-correlate your signal with the input signal.
4. Observe the output signal and nd the cross-correlation signal having largest peak response. This
frequency is then the best guess for the unknown frequency in the input signal.
1. (10pts) On one plot show your 6 lters hi [n] representing your hypothesized frequencies. Let your
lters be 100 samples long (or 101 samples if you count the sample h[0] = 0).
2. (10pts) Using the data le provided, provide a single plot showing the 'valid' part, i.e., non-transient
part, of your cross-correlations for each of your lters from (1) with the data le containing the unknown
frequency. Hint: Use conv(A,B,'valid').
3. (10pts) Indicate which lter has a frequency closest to the unknown frequency present in the data le.
Clearly state the frequency indicated as your best guess from the outputs of (2).
4. (10pts) Rene your best guess answer for the unknown frequency by changing your MATLAB code.
Indicate your improved guess (dierent than that from (3)). Explain how you arrived at your improved
solution.
1. Read in the video data le and convert it to a list of signals, if the image has N columns and M rows
we convert this into a list of NM signals x1 [n], x2 [n], . . . xN M [n].
2. Cross-correlate your lter with each of the input signals creating output signals y1 [n], y2 [n], . . . yN M [n].
At this point we could try and look at each of these signals for the unknown frequency but for even small
images this is too much data to analyze. Instead we will try re-incorporate the magnied frequency into the
original video and view the video to see the output.
2
1. Multiply your output signals y1 [n], y2 [n], . . . yN M [n] by a constant α and add it to the original input
signal creating a video output signal v1 [n], v2 [n], . . . vN M [n] where vi [n] = xi [n] + αyi [n].
2. Use the provided MATLAB code to view the output video signal.
1. (5pts) Plot the cross-correlation between the red pixel signal and your chosen lter.
2. (5pts) Pick o sample indices corresponding to maximum and minimum locations in the cross-correlation
plot. Use the data cursor to pick o these locations and show the annotated plot indicating the (x, y)
locations of the curve max and min that you selected.
3. (10pts) Create a 2x2 matrix of image plots. The rst column will show the unmodied original image
and the magnied image using the maximum and minimum index values you selected from (2) above.
The second column will show the magnied image using the maximum and minimum index values
you selected from (2) above. Label each image in your 2x2 matrix as 'original image', 'max image',
and 'min image' as appropriate. Hint: If h[n] is a row vector then you can call conv2(A,B,'same')
(2-dimensional convolution) as part of your code to cross-correlate h[n] with all pixels of the input
image in one function call.
4. (5pts) What physical eect is magnied by your lter within the image? Explain why this eect has
become visible whereas it was not previously observable in the original image. You must explain why
other phenomenon in the image are not magnied and how the magnication is specic to only the
magnied phenomenon.
5. (5pts) What is the heart rate of the subject in the video (in beats per minute; bpm)? How can
you compute this from the magnied video images. Explain your calculation relating the digital
computation back to the analog value of the heart rate.
1 − 1
(t−µi )2
2σ 2
gi (µi , σi , Ai ) = Ai ∗ √ e i
σi 2π
Ng
X
Tg = gi (µi , σi , Ai )
i=1
3
(i) Write a function to compute the coecients of a template with 41 values by sampling Tg at the same
frequency as x[n], i.e., n = [0, . . . , 40]. Using a MATLAB function call to construct each Gaussian pulse,
a function template has been provided in the le: construct_pulse.m. Assemble the template function,
t[n], by summing the Ng constructed Gaussian pulses. Plot the resulting template function using stem()
in MATLAB. Convert this template into a digital lter by time reversing the template. Plot the lter
coecients of your matched lter, h[n], in a second plot.
(ii-iii) Detect the pulse signals within the data signal and generate a list containing the sample lag indices
of the detected pulses. Use these indices to estimate the period of the noise-perturbed signal, b . (Hint :
N
N > 5 samples). The detection and estimation scheme which one may use is as follows :
2. Find all sample indices where the signal value, i.e., nd all n such that y[n] ≥ 0.8max(y[n]) where
y[n] = x[n]∗h[−n]. These are indices of correlation values ≥ 80% of the maximum observed correlation
value. We consider the resulting set of indices, K = {k1 , k2 , ...}, as possible lag indices where the
template and the embedded pulse signal have aligned.
3. Compute the period estimates for each of the resulting index pairs by subtracting neighboring indices
from K. Here we assume that indices with large correlation values indicate the presence of the template
in the signal. Dierences between these indices indicates the period of the unknown signal (in samples).
5. Find the fundamental period from the remaining values, i.e., the smallest value.
6. Take all values within 30% of the fundamental period. Use their mean value as the estimate of the
period, N
b.
7. Use N
b and the sample rate to compute the heart rate of your patient in beats per minute.
Feel free to design your own detection scheme. Any reasonable estimation scheme is acceptable.
(iv) Vary the length of your computed matched lter by taking the rst Nk values from the templatet[n]
where Nk = [4, 10, 41]. Run your program from (ii-iii). Take your period estimates from step 6 and compute
the standard deviation of the period estimates as a function of the length of the template. Make a comment
on your observations.
2. (30pts) Period estimates and plots as requested in (ii),(iii),(iv) and related comments and observations.
Make sure to provide the estimated heart rate in beats per minute.
3. (20pts) Plot of the standard deviation of the period as a function of the template length from (iv) and
the associated mean estimates of the period for dierent length templates.