Question
For this question, you will use some important properties of random numbers to assess the results of a poll that ranks the publics approval of
For this question, you will use some important properties of random numbers to assess the results of a poll that ranks the publics approval of some person or issue. Suppose you asked everyone in the country what they thought of the presidents performance,on a scale of 0% to 100%, where 0% is terrible and 100% is wonderful. If you averaged all the answers, you would get the true average opinion of everyone in the country. We call that the population mean. Unfortunately, asking everyone is expensive, so pollsters just ask a few representative people,perhaps 100.
Even when you take a truly representative sample, the average of what your samples say wont equal the average of what everyone would say. The measured average will have a variance. Let:
x= a particular samples approval value
x= population mean approval value = average approval of everyone = thetruth
Using bold angled brackets to denote averaging,we define:
variance =< (xx)^2 > = average of the square of (each samples approvalpopulation mean approval).
With a little algebra, one can show that: < (xx)^2 > = ( - ^2 ) + ( - x)^2
The first term on the right-hand side is:
The second term on the right-hand side is:(-x)^2= square of (average sample approvalpopulations mean approval)
Well call this the variance of the average. This helps us estimate the error in our sampling experiment. What we usually want to know is:standard deviation of the average =sqrt[(-x)^2] = Math.abs ( -x)
This tells approximately how far off our computed result is. It could be off in either direction by as much as two or three times the standard deviation.
In real life, we almost never know thetruepopulation mean,x, so we cant just useMath.abs( - x). Instead, we have to estimate our error indirectly. On the average, it turns out that:
- x)^2 ( - ^2) / (samples1)
That is, the variance of the averageraw variance / (samples1).
Thus, we can estimate the standard deviation of an experimental determination of an average by calculating:
standard deviation of meansqrt [(-^2)/(samples1)]
We must always take more than one sample, and the more samples we take, the smaller our error
becomes, but it decreases only as the square root of the number of samples.
Heres a suggested UML class diagram
The main method calls verifyModelto prove that the getSample algorithm is OK. Then it calls setPopulationMean to set the population mean approval at an unknown random value between 0.0 and 1.0. Then main asks the user for a desired number of samples,and it instantiates anApproval object,poll. Then it asks pollto calldoPoll and prints polls mean value, as apercentage. It getspolls raw variance and divides it by (samples1) to obtain an estimate of thevariance of the measured average, relative to the underlying true population mean. It prints the standard deviation of variation in the measured average, as a percentage. Finally, it reveals thetrueunderlying population mean, as a percentage, for comparison.
The doPoll method loops for the specified number of samples, accumulating value and value squared. After the looping, it divides each accumulation by the specified number of samples to obtain the respective averages. Then it sets mean, and:
variance avgOfValueSquaredavgValue * avgValue.
The setPopulationMean method just makes populationMean equal to whatever value is returned by Math.random.
The getSample method implements the following algorithm, which provides a simple representation of the populations distribution of approval values:
sample Math.random
where Math.random
if where < populationMean
sample populationMean + (1populationMean) * sample
else
sample populationMeanpopulationMean * sample
The verifyModel method establishes an independent population mean, and loops through one million samples, to confirm that the average of all of them approximately equals the established population mean, and to confirm that all samples are within the allowed range.
a)Write a Java program that uses the above methods to produce something like the following results:
Sample session:
populationMean = 0.588476003095624 for 1000000 samples
maxValue = 0.9999997135618746
minValue = 9.054368410588154E-7
avgValue = 0.588630443979852
Enter number of samples in poll:50
poll's average = 52%
standard deviation of poll's average = 4%
population average = 49%
b)Write another driver for the Approval class that conducts a large number of polls and verifies experimentally the relationship:
(-x)^2 (-^2) / (samples1) for arbitrary user-specification of number of samples.
Do this by looping through a user-specified number of iterations. In each iteration, take a separate poll, and accumulate raw variance (right-side numerator) and the square of that polls mean minus population mean (left side). After the loop, divide each accumulation by the number of iterations, and divide the quotients to produce an average estimate of (samples-1)
Sample Output:
PopulationMean = 0.6785929035920892
Enter number of polls:100000
Enter number of samples per poll:100
samplesMinusOne = 98.93854576326652
Step by Step Solution
There are 3 Steps involved in it
Step: 1
Get Instant Access to Expert-Tailored Solutions
See step-by-step solutions with expert insights and AI powered tools for academic success
Step: 2
Step: 3
Ace Your Homework with AI
Get the answers you need in no time with our AI-driven, step-by-step assistance
Get Started