Reference no: EM132784901
CS 6140 Data Mining - The University of Utah
Hash Functions and PAC Algorithms
Overview
In this assignment you will experiment with random variation over discrete events.
It will be very helpful to use the analytical results and the experimental results to help verify the other is correct. If they do not align, you are probably doing something wrong (this is a very powerful and important thing to do whenever working with real data).
if your assignment is difficult to read or hard to follow. Find a sample form in: Canvas -> Files -> Assignments -> Assignment Latex Template.zip. As usual, it is recommended that you use LaTeX for this assignment. If you do not, you may lose points
Birthday Paradox
Consider a domain of size n = 3000.
A: Generate random numbers in the domain [n] until two have the same value. How many random trials did this take? We will use k to represent this value.
B: Repeat the experiment m = 200 times, and record for each time how many random trials this took. Plot this data as a cumulative density plot where the x-axis records the number of trials required k, show a curve that starts at a y value of 0, and increases as k increases, and eventually reaches a y value of 1. and the y-axis records the fraction of experiments that succeeded (a collision) after k trials. The plot should
C: Empirically estimate the expected number of k random trials in order to have a collision. That is, add up all values k, and divide by m.
D: Describe how you implemented this experiment and how long it took for m = 200 trials.
Show a plot of the run time as you gradually increase the parameters n and m. (For at least 3 fixed values of m between 200 and 10,000, plot the time as a function of n.) You should be able to reach values of n = 1,000,000 and m = 10,000.
Coupon Collectors
Consider a domain [n] of size n = 200.
A: Generate random numbers in the domain [n] until every value i [n] has had one random number equal to i. How many random trials did this take? We will use k to represent this value.
B: Repeat step A for m = 300 times, and for each repetition record the value k of how many random trials we required to collect all values i ∈ [n]. Make a cumulative density plot as in 1.B.
C: Use the above results to calculate the empirical expected value of k.
D: Describe how you implemented this experiment and how long it took for n = 200 and m = 300 trials. Show a plot of m between 300 and 2,000, plot the time as a function of n.) You should be able to reach n = 10,000 and m = 2,000. Show a plot of the run time as you gradually increase the parameters n and m. (For at least 3 fixed values
Comparing Experiments to Analysis
A. random trials needed so there is a collision with probability at least 0.5 when the domain size is n = 3000. A: (15 points) Calculate analytically (using formulas from the notes in L2 or M4D book) the number of There are a few formulas stated with varying degree of accuracy, you may use any of these - the more
accurate formula, the more sure you may be that your experimental part is verified, or is not (and thus you need to fix something).
[Show your work, including describing which formula you used.]
How does this compare to your results from 1.C?
number of random trials before all elements are witnessed in a domain of size n = 200? Again, there are a B: (15 points) Calculate analytically (using formulas from the notes in L2 or M4D book) the expected few formulas you may use - the more accurate, the more confidence you might have in your experimental part.
[Show your work, including describing which formula you used.]
How does this compare to your results from 2.C?
BONUS : PAC Bounds
i ∈ [n] with probability 1/n. Let fi denote the number of trials that have value i. Note that for each i ∈ [n] we have E[fi] = k/n. Let µ = maxi∈[n] fi/k. Consider a domain size n and let k be the number of random trials run, where each trial obtains each value
Consider some parameter ε (0, 1). As a function of parameter ε, how large does k need to be for Pr[ µ 1/n ε] 0.02? That is, how large does k need to be for all counts to be within (ε 100)% of the average with probability 0.02? (Fine print: you don't need to calculate this exactly, but describe a bound as a function of ε for the value k which satisfies PAC property. Chapter 2.3 in the M4D book should help.)
How does this change if we want Pr[ µ 1/n ε] 0.002 (that is, only 0.002 probability of exceeding ε error)?
Attachment:- Data Mining.rar