-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLec20.py
More file actions
70 lines (64 loc) · 1.9 KB
/
Copy pathLec20.py
File metadata and controls
70 lines (64 loc) · 1.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
from pylab import *
import random,math
def flipTrial(numFlips):
heads,tails=0,0
for i in xrange(0,numFlips):
coin=random.randint(0,1)
if coin==0: heads+=1
else: tails+=1
return heads,tails
def simFlips(numFlips,numTrials):
diffs=[]
for i in xrange(0,numTrials):
heads,tails=flipTrial(numFlips)
diffs.append(abs(heads-tails))
diffs=array(diffs)
diffMean=sum(diffs)/len(diffs)
diffPercent=(diffs/float(numFlips))*100
percentMean=sum(diffPercent)/len(diffPercent)
hist(diffs)
#axvline(diffMean,lable='Mean')
legend()
titleString=str(numFlips)+' Flips, '+str(numTrials)+' Trials'
title(titleString)
xlabel('Differnce between heads and tails')
ylabel('Number of Trials')
figure()
plot(diffPercent)
#axhline(percentMean,lable='Mean')
legend()
title(titleString)
xlabel('Trial Number')
ylabel('Percent Differnce between heads and tails')
##simFlips(100,100)
##figure()
##simFlips(5000,100)
##simFlips(3,4000)
##show()
def throwDarts(numDarts,shouldPlot):
inCircle=0
estimates=[]
for darts in xrange(1,numDarts+1,1):
x=random.random()
y=random.random()
if math.sqrt(x*x+y*y)<=1.0:
inCircle+=1
if shouldPlot:
piGuess=4*(inCircle/float(darts))
estimates.append(piGuess)
if darts%1000000==0:
piGuess=4*(inCircle/float(darts))
print 'Number of darts ',darts,', piGuess ',piGuess
if shouldPlot:
xAxis = xrange(1,len(estimates)+1)
semilogx(xAxis,estimates)
title('Estimate of pi')
xlabel('Number of darts')
ylabel('Estimate of pi')
show()
return 4*(inCircle/float(numDarts))
def findPi(numDarts,shouldPlot=False):
piGuess=throwDarts(numDarts,shouldPlot)
print 'Number of darts ',numDarts,', piGuess ',piGuess
#findPi(10000000)
#findPi(100000,True)