I am trying to learn TensorFlow and studying the example at: https://github.com/aymericdamien/TensorFlow-Examples/blob/master/notebooks/3_NeuralNetworks/autoencoder.ipynb
I then have some questions in the code below:
for epoch in range(training_epochs):
# Loop over all batches
for i in range(total_batch):
batch_xs, batch_ys = mnist.train.next_batch(batch_size)
# Run optimization op (backprop) and cost op (to get loss value)
_, c = sess.run([optimizer, cost], feed_dict={X: batch_xs})
# Display logs per epoch step
if epoch % display_step == 0:
print("Epoch:", '%04d' % (epoch+1),
"cost=", "{:.9f}".format(c))
Since mnist is just a dataset, what exactly does mnist.train.next_batch
mean? How was the dataset.train.next_batch
defined?
Thanks!
The
mnist
object is returned from theread_data_sets()
function defined in thetf.contrib.learn
module. Themnist.train.next_batch(batch_size)
method is implemented here, and it returns a tuple of two arrays, where the first represents a batch ofbatch_size
MNIST images, and the second represents a batch ofbatch-size
labels corresponding to those images.The images are returned as a 2-D NumPy array of size
[batch_size, 784]
(since there are 784 pixels in an MNIST image), and the labels are returned as either a 1-D NumPy array of size[batch_size]
(ifread_data_sets()
was called withone_hot=False
) or a 2-D NumPy array of size[batch_size, 10]
(ifread_data_sets()
was called withone_hot=True
).