forked from kiat/BigDataAnalytics
-
Notifications
You must be signed in to change notification settings - Fork 27
Expand file tree
/
Copy pathisland3.py
More file actions
49 lines (34 loc) · 1.05 KB
/
island3.py
File metadata and controls
49 lines (34 loc) · 1.05 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
# http://people.duke.edu/~ccc14/sta-663-2016/16A_MCMC.html
import numpy as np
import seaborn as sns
def make_islands(n, low=10, high=101):
islands = np.random.randint(low, high, n+2)
islands[0] = 0
islands[-1] = 0
return islands
islands = make_islands(10)
thetas = hop(islands, start=1, niter=10000)
# Main Metroplis implementation
def metroplis(start, target, proposal, niter, nburn=0):
current = start
post = [current]
for i in range(niter):
proposed = proposal(current)
p = min(target(proposed)/target(current), 1)
if np.random.random() < p:
current = proposed
post.append(current)
return post[nburn:]
# Generic Metropolis scheme
data = islands[1:-1]
data = data/data.sum()
sns.barplot(x=np.arange(len(data)), y=data)
pass
# Apply to island hooper - MH
target = lambda x: islands[x]
proposal = lambda x: x + np.random.choice([-1, 1])
post = metroplis(1, target, proposal, 2000)
data = np.bincount(post)[1:]
data = data/data.sum()
sns.barplot(x=np.arange(len(data)), y=data)
pass