[Solved] COEN140 Lab#8-Convolutional Neural Network

$25

File Name: COEN140_Lab#8-Convolutional_Neural_Network.zip
File Size: 395.64 KB

SKU: [Solved] COEN140 Lab#8-Convolutional Neural Network Category: Tag:
5/5 - (1 vote)

Problem: Build a convolutional neural network for the recognition task with the fashion MNIST data set. Use the sparse_categorical_crossentropy loss function, use adam as the optimizer, and train your model for 5 epochs.

Adopt the following convolutional neural network structure:

  1. Input layer
  2. 2d-convolutional layer: filter size 33, depth=32, padding=same, strides = (1,1), ReLU activation function
  3. 22 max pooling layer, strides = (2,2), padding = same
  4. 2d-convolutional layer: filter size 33, depth=64, padding=same, strides = (1,1), ReLU activation function
  5. 22 max pooling layer, strides = (2,2), padding = same
  6. 2d-convolutional layer: filter size 33, depth=64, padding=same, strides = (1,1), ReLU activation function
  7. Flattening layer
  8. Fully-connected layer: 64 nodes, ReLU activation function
  9. (output) Fully-connected layer: 10 nodes, softmax activation function

The following code snippet is for your reference:

from tensorflow import keras from tensorflow.keras import layers, models fashion_mnist = keras.datasets.fashion_mnist

(train_images, train_labels), (test_images, test_labels) = fashion_mnist.load_data() train_images = train_images.reshape((60000, 28, 28, 1)) test_images = test_images.reshape((10000, 28, 28, 1)) # Normalize pixel values to be between 0 and 1 train_images, test_images = train_images / 255.0, test_images / 255.0 model = models.Sequential() model.add(layers.Conv2D(32, (3, 3), activation=relu, padding=same, strides = (1,1), input_shape=(28, 28, 1)))

# to be completed by yourself

Include in the report :

  1. Give the recognition accuracy rate, and show the confusion matrix, both for the test set.
  1. For each layer of the network:
  • Manually calculate the number of parameters of that layer. That is, the number of weight elements (include the bias terms). Show you work. Verify whether your results are the same as those given by model.summary().
  • Write out the output dimension of that layer.
  • Manually calculate the number of multiplications required to generate that layer. The weights have bias terms. You only need to consider the multiplications required to calculate the weighted sums. You dont need to consider the multiplications involved in the softmax function. Show you work.
  1. Compare the recognition accuracy rate of the test set, total number of parameters, and total number of multiplications of this CNN to those in Lab 7 (neural network). Analyze your findings and explain why you obtain different (or similar) results.

Demo/Explain to TA :

  1. How do you build the layers of the convolutional neural network?
  2. How do you do prediction for the test samples?
  3. How do you calculate the number of parameters and the number of multiplications?

Reviews

There are no reviews yet.

Only logged in customers who have purchased this product may leave a review.

Shopping Cart
[Solved] COEN140 Lab#8-Convolutional Neural Network
$25