-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexperiment-MNIST.py
67 lines (57 loc) · 2.3 KB
/
experiment-MNIST.py
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
# -----------------------------------------------------------------------------
# Copyright (c) 2019 Nicolas P. Rougier
# Distributed under the terms of the BSD License.
# -----------------------------------------------------------------------------
import sys
import som, mnist, plot
import numpy as np
import matplotlib
import matplotlib.pyplot as plt
if __name__ == '__main__':
seed = 1
topology = "random"
n_unit = 1024
n_neighbor = 3
n_epochs = 60000
sigma = 0.25, 0.01
lrate = 0.50, 0.01
if seed is None:
seed = np.random.randint(0,1000)
np.random.seed(seed)
print("Building network (might take some time)... ", end="")
sys.stdout.flush()
som = som.SOM(n_unit, topology, n_neighbor)
print("done!")
print("Random seed: {0}".format(seed))
print("Number of units: {0}".format(som.size))
if type == "random":
print("Number of neighbors: {0}".format(n_neighbor))
X, Y = mnist.read("training")
xshape, yshape = X.shape[1:], Y.shape[1:]
X, Y = X.reshape(len(X),-1), Y.reshape(len(Y),-1)
som.fit(X, Y, n_epochs, sigma=sigma, lrate=lrate)
# Collect minimal/maximal response from the map across all stimuli
# vmin, vmax = None, None
# for x in X:
# D = -np.sqrt(((som.codebook["X"] - x.ravel())**2).sum(axis=-1))
# vmin = D.min() if vmin is None else min(D.min(), vmin)
# vmax = D.max() if vmax is None else max(D.max(), vmax)
figsize = 2.5*np.array([6,7])
fig = plt.figure(figsize=figsize, dpi=50)
ax = plt.subplot2grid((7, 6), (0, 0), colspan=3, rowspan=3, aspect=1)
plot.network(ax, som)
plot.letter(ax, "A")
ax = plt.subplot2grid((7, 6), (0, 3), colspan=3, rowspan=3, aspect=1)
cmap = matplotlib.cm.get_cmap("tab10")
plot.weights_img(ax, som, xshape, cmap=cmap)
plot.letter(ax, "B")
X = X[np.random.randint(0,len(X),6)]
for i,x in enumerate(X):
ax = plt.subplot2grid((7, 6), (3+2*(i//3), 2*(i%3)),
colspan=2, rowspan=2, aspect=1)
plot.activation(ax, som, np.array(x).reshape(28,28))
plot.letter(ax, chr(ord("C")+i))
plt.tight_layout()
# np.save("./results/experiment-MNIST-"+topology, som.codebook['X'])
plt.savefig("experiment-MNIST.pdf", dpi=300)
plt.show()