annotate sandbox/simple_autoassociator/graph.py @ 407:b9f545594207

Automated merge with ssh://projects@lgcm.iro.umontreal.ca/hg/pylearn
author Frederic Bastien <bastienf@iro.umontreal.ca>
date Thu, 10 Jul 2008 09:03:11 -0400
parents 8cc11ac97087
children faffaae0d2f9
rev   line source
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
1 """
386
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
2 Theano graph for a simple autoassociator.
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
3 @todo: Make nearly everything private.
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
4 """
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
5
383
344d1f874af7 Small fix
Joseph Turian <turian@gmail.com>
parents: 382
diff changeset
6 from pylearn.nnet_ops import sigmoid, binary_crossentropy
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
7 from theano import tensor as t
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
8 from theano.tensor import dot
386
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
9 x = t.dvector()
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
10 w1 = t.dmatrix()
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
11 b1 = t.dvector()
386
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
12 w2 = t.dmatrix()
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
13 b2 = t.dvector()
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
14 h = sigmoid(dot(x, w1) + b1)
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
15 y = sigmoid(dot(h, w2) + b2)
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
16
388
98ca97cc9910 Debugging simple AA
Joseph Turian <turian@gmail.com>
parents: 386
diff changeset
17 loss_unsummed = binary_crossentropy(y, x)
98ca97cc9910 Debugging simple AA
Joseph Turian <turian@gmail.com>
parents: 386
diff changeset
18 loss = t.sum(loss_unsummed)
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
19
404
8cc11ac97087 Debugging simple AA a bit
Joseph Turian <turian@gmail.com>
parents: 393
diff changeset
20 (gw1, gb1, gw2, gb2, gy, gh) = t.grad(loss, [w1, b1, w2, b2, y, h])
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
21
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
22 import theano.compile
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
23
386
a474341861fa Added a simple AA
Joseph Turian <turian@gmail.com>
parents: 384
diff changeset
24 inputs = [x, w1, b1, w2, b2]
404
8cc11ac97087 Debugging simple AA a bit
Joseph Turian <turian@gmail.com>
parents: 393
diff changeset
25 outputs = [y, h, loss, loss_unsummed, gw1, gb1, gw2, gb2, gy, gh]
370
a1bbcde6b456 Moved sparse_random_autoassociator from my repository
Joseph Turian <turian@gmail.com>
parents:
diff changeset
26 trainfn = theano.compile.function(inputs, outputs)