From e896ae65cc7e2855be798af09ecfb13772d5e6ec Mon Sep 17 00:00:00 2001 From: afoix Date: Mon, 19 Aug 2024 23:50:14 +0000 Subject: [PATCH] Commit from GitHub Actions (Build Notebooks) --- exercise.ipynb | 236 ++++++++++++++++++------------------- solution.ipynb | 312 ++++++++++++++++++++++++------------------------- 2 files changed, 274 insertions(+), 274 deletions(-) diff --git a/exercise.ipynb b/exercise.ipynb index e5cda35..9d46637 100644 --- a/exercise.ipynb +++ b/exercise.ipynb @@ -2,7 +2,7 @@ "cells": [ { "cell_type": "markdown", - "id": "ad68ff94", + "id": "055f5871", "metadata": {}, "source": [ "# Exercise 7: Failure Modes And Limits of Deep Learning" @@ -10,7 +10,7 @@ }, { "cell_type": "markdown", - "id": "c0f0735a", + "id": "327d7b71", "metadata": {}, "source": [ "In the following exercise, we explore the failure modes and limits of neural networks.\n", @@ -23,7 +23,7 @@ }, { "cell_type": "markdown", - "id": "5619f37d", + "id": "41654ae2", "metadata": {}, "source": [ "\n", @@ -44,7 +44,7 @@ }, { "cell_type": "markdown", - "id": "aba193c5", + "id": "0a64a471", "metadata": {}, "source": [ "### Acknowledgements\n", @@ -53,7 +53,7 @@ }, { "cell_type": "markdown", - "id": "c1cf118b", + "id": "b5bcabb9", "metadata": {}, "source": [ "### Data Loading\n", @@ -67,7 +67,7 @@ { "cell_type": "code", "execution_count": null, - "id": "c29ae4dc", + "id": "9d41afcb", "metadata": {}, "outputs": [], "source": [ @@ -90,7 +90,7 @@ }, { "cell_type": "markdown", - "id": "1bb942ea", + "id": "1d04380a", "metadata": {}, "source": [ "### Part 1: Preparation of a Tainted Dataset\n", @@ -101,7 +101,7 @@ { "cell_type": "code", "execution_count": null, - "id": "32077360", + "id": "9b0b1a97", "metadata": {}, "outputs": [], "source": [ @@ -115,7 +115,7 @@ { "cell_type": "code", "execution_count": null, - "id": "1adbc5ee", + "id": "4d83f1a2", "metadata": {}, "outputs": [], "source": [ @@ -126,7 +126,7 @@ }, { "cell_type": "markdown", - "id": "dd092467", + "id": "12b9d7af", "metadata": {}, "source": [ "## Part 1.1: Local Corruption of Data\n", @@ -137,7 +137,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5d779046", + "id": "022103f5", "metadata": {}, "outputs": [], "source": [ @@ -149,7 +149,7 @@ { "cell_type": "code", "execution_count": null, - "id": "9eae44bc", + "id": "64ea44e2", "metadata": {}, "outputs": [], "source": [ @@ -172,7 +172,7 @@ }, { "cell_type": "markdown", - "id": "1242b7da", + "id": "08e33b46", "metadata": {}, "source": [ "

\n", @@ -183,7 +183,7 @@ }, { "cell_type": "markdown", - "id": "586be487", + "id": "fee2f87c", "metadata": {}, "source": [ "

\n", @@ -194,7 +194,7 @@ }, { "cell_type": "markdown", - "id": "2ad4f801", + "id": "3581f01f", "metadata": {}, "source": [ "## Part 1.2: Global Corruption of data\n", @@ -204,7 +204,7 @@ }, { "cell_type": "markdown", - "id": "0749a9f6", + "id": "6447348c", "metadata": {}, "source": [ "You may have noticed that the images are stored as arrays of integers. First we cast them to float to be able to add textures easily without integer wrapping issues." @@ -213,7 +213,7 @@ { "cell_type": "code", "execution_count": null, - "id": "19c5869e", + "id": "b3731533", "metadata": {}, "outputs": [], "source": [ @@ -224,7 +224,7 @@ }, { "cell_type": "markdown", - "id": "46e255ca", + "id": "7adcabd3", "metadata": {}, "source": [ "Then we create the grid texture and visualize it." @@ -233,7 +233,7 @@ { "cell_type": "code", "execution_count": null, - "id": "823060ce", + "id": "6b604fa3", "metadata": {}, "outputs": [], "source": [ @@ -249,7 +249,7 @@ }, { "cell_type": "markdown", - "id": "c09f310e", + "id": "c1368fb3", "metadata": {}, "source": [ "Next we add the texture to all 4s in the train and test set." @@ -258,7 +258,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5264fb24", + "id": "38a80836", "metadata": {}, "outputs": [], "source": [ @@ -269,7 +269,7 @@ }, { "cell_type": "markdown", - "id": "d0235c57", + "id": "cf303dd0", "metadata": {}, "source": [ "After adding the texture, we have to make sure the values are between 0 and 255 and then cast back to uint8.\n", @@ -279,7 +279,7 @@ { "cell_type": "code", "execution_count": null, - "id": "bf580bd0", + "id": "503dcb25", "metadata": {}, "outputs": [], "source": [ @@ -295,7 +295,7 @@ { "cell_type": "code", "execution_count": null, - "id": "dc053eb0", + "id": "7781c186", "metadata": {}, "outputs": [], "source": [ @@ -317,7 +317,7 @@ }, { "cell_type": "markdown", - "id": "66a4eb68", + "id": "4ec55e8d", "metadata": {}, "source": [ "

\n", @@ -328,7 +328,7 @@ }, { "cell_type": "markdown", - "id": "ea13603f", + "id": "33f601d3", "metadata": {}, "source": [ "\n", @@ -340,7 +340,7 @@ }, { "cell_type": "markdown", - "id": "5a17ff4d", + "id": "c4f22201", "metadata": {}, "source": [ "\n", @@ -353,7 +353,7 @@ }, { "cell_type": "markdown", - "id": "e6cb618a", + "id": "f7407f20", "metadata": {}, "source": [ "\n", @@ -371,7 +371,7 @@ }, { "cell_type": "markdown", - "id": "8cb597ed", + "id": "f126c5e4", "metadata": {}, "source": [ "### Part 2: Create and Train an Image Classification Neural Network on Clean and Tainted Data\n", @@ -382,7 +382,7 @@ { "cell_type": "code", "execution_count": null, - "id": "0a677906", + "id": "eda4fb9a", "metadata": {}, "outputs": [], "source": [ @@ -396,7 +396,7 @@ }, { "cell_type": "markdown", - "id": "d76c4b98", + "id": "fcba2a9c", "metadata": {}, "source": [ "Now we will train the neural network. A training function is provided below - this should be familiar, but make sure you look it over and understand what is happening in the training loop." @@ -405,7 +405,7 @@ { "cell_type": "code", "execution_count": null, - "id": "7d448ce4", + "id": "1d7471e6", "metadata": {}, "outputs": [], "source": [ @@ -430,7 +430,7 @@ }, { "cell_type": "markdown", - "id": "855c4b61", + "id": "b20e8ef1", "metadata": {}, "source": [ "We have to choose hyperparameters for our model. We have selected to train for two epochs, with a batch size of 64 for training and 1000 for testing. We are using the cross entropy loss, a standard multi-class classification loss." @@ -439,7 +439,7 @@ { "cell_type": "code", "execution_count": null, - "id": "8a2d97a2", + "id": "67dc8176", "metadata": {}, "outputs": [], "source": [ @@ -458,7 +458,7 @@ }, { "cell_type": "markdown", - "id": "441c4d04", + "id": "c167e7f1", "metadata": {}, "source": [ "Next we initialize a clean model, and a tainted model. We want to have reproducible results, so we set the initial weights with a specific random seed. The seed number does not matter, just that it is the same!" @@ -467,7 +467,7 @@ { "cell_type": "code", "execution_count": null, - "id": "28d546e4", + "id": "c5ed5585", "metadata": {}, "outputs": [], "source": [ @@ -495,7 +495,7 @@ }, { "cell_type": "markdown", - "id": "9eb196cd", + "id": "ef87074c", "metadata": {}, "source": [ "Next we initialize the clean and tainted dataloaders, again with a specific random seed for reproducibility." @@ -504,7 +504,7 @@ { "cell_type": "code", "execution_count": null, - "id": "133a85ba", + "id": "dbcf65c9", "metadata": {}, "outputs": [], "source": [ @@ -518,7 +518,7 @@ }, { "cell_type": "markdown", - "id": "90762c28", + "id": "9cb8b4b4", "metadata": {}, "source": [ "Now it is time to train the neural networks! We are storing the training loss history for each model so we can visualize it later." @@ -527,7 +527,7 @@ { "cell_type": "code", "execution_count": null, - "id": "a949ffda", + "id": "1ff6bb66", "metadata": {}, "outputs": [], "source": [ @@ -560,7 +560,7 @@ }, { "cell_type": "markdown", - "id": "96bc28fd", + "id": "f389ca38", "metadata": {}, "source": [ "Now we visualize the loss history for the clean and tainted models." @@ -569,7 +569,7 @@ { "cell_type": "code", "execution_count": null, - "id": "29093a14", + "id": "9473ae0f", "metadata": {}, "outputs": [], "source": [ @@ -584,7 +584,7 @@ }, { "cell_type": "markdown", - "id": "c7dddc4b", + "id": "5b6c2993", "metadata": {}, "source": [ "

\n", @@ -595,7 +595,7 @@ }, { "cell_type": "markdown", - "id": "b20df043", + "id": "db77e034", "metadata": {}, "source": [ "

\n", @@ -606,7 +606,7 @@ }, { "cell_type": "markdown", - "id": "94551ca6", + "id": "4aed0994", "metadata": {}, "source": [ "

\n", @@ -617,7 +617,7 @@ }, { "cell_type": "markdown", - "id": "edcc38e3", + "id": "e2ad4888", "metadata": {}, "source": [ "

\n", @@ -629,7 +629,7 @@ }, { "cell_type": "markdown", - "id": "ba7ae77b", + "id": "fd85af08", "metadata": {}, "source": [ "

\n", @@ -644,7 +644,7 @@ }, { "cell_type": "markdown", - "id": "e0afcf03", + "id": "35faa65c", "metadata": {}, "source": [ "### Part 3: Examining the Results of the Clean and Tainted Networks\n", @@ -657,7 +657,7 @@ { "cell_type": "code", "execution_count": null, - "id": "2c8432f0", + "id": "b9571f86", "metadata": {}, "outputs": [], "source": [ @@ -679,7 +679,7 @@ }, { "cell_type": "markdown", - "id": "dac0d3bd", + "id": "1ba7a46b", "metadata": {}, "source": [ "Now we call the predict method with the clean and tainted models on the clean and tainted datasets." @@ -688,7 +688,7 @@ { "cell_type": "code", "execution_count": null, - "id": "c6438d2e", + "id": "a64f5d22", "metadata": {}, "outputs": [], "source": [ @@ -700,7 +700,7 @@ }, { "cell_type": "markdown", - "id": "f6ec7c0d", + "id": "2937a3f5", "metadata": {}, "source": [ "We can investigate the results using the confusion matrix, which you should recall from the Introduction to Machine Learning exercise. The function in the cell below will create a nicely annotated confusion matrix." @@ -709,7 +709,7 @@ { "cell_type": "code", "execution_count": null, - "id": "ada1daff", + "id": "2d99588f", "metadata": { "lines_to_next_cell": 1 }, @@ -764,7 +764,7 @@ }, { "cell_type": "markdown", - "id": "1c841eaa", + "id": "ba93ea0c", "metadata": {}, "source": [ "Now we will generate confusion matrices for each model/data combination. Take your time and try and interpret these, and then try and answer the questions below." @@ -773,7 +773,7 @@ { "cell_type": "code", "execution_count": null, - "id": "073a89a2", + "id": "03fa45d8", "metadata": {}, "outputs": [], "source": [ @@ -785,7 +785,7 @@ }, { "cell_type": "markdown", - "id": "267208ff", + "id": "0d65dd6b", "metadata": {}, "source": [ "

\n", @@ -796,7 +796,7 @@ }, { "cell_type": "markdown", - "id": "82d1cba3", + "id": "54c38a61", "metadata": {}, "source": [ "

\n", @@ -807,7 +807,7 @@ }, { "cell_type": "markdown", - "id": "dd6ca1dd", + "id": "afcf048a", "metadata": {}, "source": [ "

\n", @@ -818,7 +818,7 @@ }, { "cell_type": "markdown", - "id": "c231d586", + "id": "c5751b3e", "metadata": {}, "source": [ "

\n", @@ -829,7 +829,7 @@ }, { "cell_type": "markdown", - "id": "a676ba72", + "id": "d2812f67", "metadata": {}, "source": [ "

\n", @@ -841,7 +841,7 @@ }, { "cell_type": "markdown", - "id": "e9a5583c", + "id": "8d411a40", "metadata": {}, "source": [ "

\n", @@ -856,7 +856,7 @@ }, { "cell_type": "markdown", - "id": "c30d4df6", + "id": "8249ac3d", "metadata": {}, "source": [ "### Part 4: Interpretation with Integrated Gradients\n", @@ -865,7 +865,7 @@ }, { "cell_type": "markdown", - "id": "2784e751", + "id": "7c235272", "metadata": {}, "source": [ "\n", @@ -875,7 +875,7 @@ { "cell_type": "code", "execution_count": null, - "id": "7403b38f", + "id": "b2d82d85", "metadata": {}, "outputs": [], "source": [ @@ -908,7 +908,7 @@ }, { "cell_type": "markdown", - "id": "3f1881d0", + "id": "a20292b4", "metadata": {}, "source": [ "Next we provide a function to visualize the output of integrated gradients, using the function above to actually run the algorithm." @@ -917,7 +917,7 @@ { "cell_type": "code", "execution_count": null, - "id": "1ef66e49", + "id": "f39b4d66", "metadata": {}, "outputs": [], "source": [ @@ -956,7 +956,7 @@ }, { "cell_type": "markdown", - "id": "3587e26e", + "id": "89ca294b", "metadata": {}, "source": [ "To start examining the results, we will call the `visualize_integrated_gradients` with the tainted and clean models on the tainted and clean sevens.\n", @@ -967,7 +967,7 @@ { "cell_type": "code", "execution_count": null, - "id": "3a141027", + "id": "68a1916d", "metadata": {}, "outputs": [], "source": [ @@ -977,7 +977,7 @@ }, { "cell_type": "markdown", - "id": "09f0b17b", + "id": "1a3c24c8", "metadata": {}, "source": [ "

\n", @@ -988,7 +988,7 @@ }, { "cell_type": "markdown", - "id": "e886ceb9", + "id": "039bdb2d", "metadata": {}, "source": [ "Now let's look at the attention of the tainted model!" @@ -997,7 +997,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5d8fe87c", + "id": "f42237ef", "metadata": {}, "outputs": [], "source": [ @@ -1007,7 +1007,7 @@ }, { "cell_type": "markdown", - "id": "63f51d95", + "id": "7666839c", "metadata": {}, "source": [ "

\n", @@ -1018,7 +1018,7 @@ }, { "cell_type": "markdown", - "id": "d84b50f2", + "id": "20006a90", "metadata": {}, "source": [ "Now let's look at the regions of the image that Integrated Gradients highlights as important for classifying fours in the clean and tainted models." @@ -1027,7 +1027,7 @@ { "cell_type": "code", "execution_count": null, - "id": "1f2524bc", + "id": "f2b422de", "metadata": {}, "outputs": [], "source": [ @@ -1039,7 +1039,7 @@ }, { "cell_type": "markdown", - "id": "162b2791", + "id": "f3470b70", "metadata": {}, "source": [ "

\n", @@ -1050,7 +1050,7 @@ }, { "cell_type": "markdown", - "id": "693673e7", + "id": "2b2ccff7", "metadata": {}, "source": [ "

\n", @@ -1061,7 +1061,7 @@ }, { "cell_type": "markdown", - "id": "07ffa5c9", + "id": "77638560", "metadata": {}, "source": [ "

\n", @@ -1074,7 +1074,7 @@ }, { "cell_type": "markdown", - "id": "e2b3e006", + "id": "0e7c467c", "metadata": {}, "source": [ "

\n", @@ -1088,7 +1088,7 @@ }, { "cell_type": "markdown", - "id": "d9c75351", + "id": "d5b37c02", "metadata": {}, "source": [ "## Part 5: Importance of using the right training data\n", @@ -1100,7 +1100,7 @@ }, { "cell_type": "markdown", - "id": "3c96a7d4", + "id": "4ab7521d", "metadata": {}, "source": [ "First, we will write a function to add noise to the MNIST dataset, so that we can train a model to denoise it." @@ -1109,7 +1109,7 @@ { "cell_type": "code", "execution_count": null, - "id": "7eb143be", + "id": "15340fcc", "metadata": {}, "outputs": [], "source": [ @@ -1122,7 +1122,7 @@ }, { "cell_type": "markdown", - "id": "420f2eb7", + "id": "bcb17b47", "metadata": {}, "source": [ "Next we will visualize a couple MNIST examples with and without noise." @@ -1131,7 +1131,7 @@ { "cell_type": "code", "execution_count": null, - "id": "0c9ba2bc", + "id": "3f4142ec", "metadata": {}, "outputs": [], "source": [ @@ -1160,7 +1160,7 @@ }, { "cell_type": "markdown", - "id": "3aa422bb", + "id": "32177f2e", "metadata": {}, "source": [ "### UNet model\n", @@ -1170,7 +1170,7 @@ }, { "cell_type": "markdown", - "id": "ce6e4ffe", + "id": "0bde3d98", "metadata": {}, "source": [ "The training loop code is also provided here. It is similar to the code used to train the image classification model previously, but look it over to make sure there are no surprises." @@ -1179,7 +1179,7 @@ { "cell_type": "code", "execution_count": null, - "id": "22e3196a", + "id": "e642d956", "metadata": {}, "outputs": [], "source": [ @@ -1227,7 +1227,7 @@ }, { "cell_type": "markdown", - "id": "afdc53ce", + "id": "f82de800", "metadata": {}, "source": [ "Here we choose hyperparameters and initialize the model and data loaders." @@ -1236,7 +1236,7 @@ { "cell_type": "code", "execution_count": null, - "id": "98818e5f", + "id": "3cf1768f", "metadata": {}, "outputs": [], "source": [ @@ -1274,7 +1274,7 @@ }, { "cell_type": "markdown", - "id": "851ee8bc", + "id": "c6491e06", "metadata": {}, "source": [ "Finally, we run the training loop!" @@ -1283,7 +1283,7 @@ { "cell_type": "code", "execution_count": null, - "id": "e75e5250", + "id": "a8ff968c", "metadata": {}, "outputs": [], "source": [ @@ -1294,7 +1294,7 @@ }, { "cell_type": "markdown", - "id": "3b123c83", + "id": "2c0e657c", "metadata": {}, "source": [ "As before, we will visualize the training loss. If all went correctly, it should decrease from around 1.0 to less than 0.2." @@ -1303,7 +1303,7 @@ { "cell_type": "code", "execution_count": null, - "id": "649578f4", + "id": "a5f92989", "metadata": { "lines_to_next_cell": 1 }, @@ -1319,7 +1319,7 @@ }, { "cell_type": "markdown", - "id": "31ee6225", + "id": "1ff69a50", "metadata": {}, "source": [ "### Check denoising performance\n", @@ -1330,7 +1330,7 @@ { "cell_type": "code", "execution_count": null, - "id": "aeada78c", + "id": "1d3ff452", "metadata": { "lines_to_next_cell": 1 }, @@ -1347,7 +1347,7 @@ { "cell_type": "code", "execution_count": null, - "id": "04b85210", + "id": "680d1a79", "metadata": { "lines_to_next_cell": 1 }, @@ -1373,7 +1373,7 @@ }, { "cell_type": "markdown", - "id": "999110e1", + "id": "dd293e3c", "metadata": {}, "source": [ "We pick 8 images to show:" @@ -1382,7 +1382,7 @@ { "cell_type": "code", "execution_count": null, - "id": "48932965", + "id": "d950e273", "metadata": {}, "outputs": [], "source": [ @@ -1392,7 +1392,7 @@ }, { "cell_type": "markdown", - "id": "a88faa07", + "id": "5093a370", "metadata": {}, "source": [ "

\n", @@ -1403,7 +1403,7 @@ }, { "cell_type": "markdown", - "id": "933c7ac9", + "id": "3e5bdd01", "metadata": {}, "source": [ "### Apply trained model on 'wrong' data\n", @@ -1413,7 +1413,7 @@ }, { "cell_type": "markdown", - "id": "5b4369e0", + "id": "08970f43", "metadata": {}, "source": [ "### Load the Fashion MNIST dataset\n", @@ -1424,7 +1424,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5e57d385", + "id": "e96ed5e7", "metadata": {}, "outputs": [], "source": [ @@ -1445,7 +1445,7 @@ }, { "cell_type": "markdown", - "id": "b36c6e41", + "id": "f00758c2", "metadata": {}, "source": [ "Next we apply the denoising model we trained on the MNIST data to FashionMNIST, and visualize the results." @@ -1454,7 +1454,7 @@ { "cell_type": "code", "execution_count": null, - "id": "6744e360", + "id": "89b14b4b", "metadata": {}, "outputs": [], "source": [ @@ -1464,7 +1464,7 @@ }, { "cell_type": "markdown", - "id": "971da0c3", + "id": "5e1870b6", "metadata": {}, "source": [ "

\n", @@ -1475,7 +1475,7 @@ }, { "cell_type": "markdown", - "id": "1df30b46", + "id": "19f2c40c", "metadata": {}, "source": [ "

\n", @@ -1486,7 +1486,7 @@ }, { "cell_type": "markdown", - "id": "835030fd", + "id": "fb0eeb74", "metadata": {}, "source": [ "### Train the denoiser on both MNIST and FashionMNIST\n", @@ -1497,7 +1497,7 @@ { "cell_type": "code", "execution_count": null, - "id": "c7cc9bb3", + "id": "eb150490", "metadata": {}, "outputs": [], "source": [ @@ -1534,7 +1534,7 @@ { "cell_type": "code", "execution_count": null, - "id": "46edff16", + "id": "ca64cf2e", "metadata": {}, "outputs": [], "source": [ @@ -1545,7 +1545,7 @@ { "cell_type": "code", "execution_count": null, - "id": "2dac72fa", + "id": "8574e737", "metadata": {}, "outputs": [], "source": [ @@ -1555,7 +1555,7 @@ }, { "cell_type": "markdown", - "id": "288c6764", + "id": "84a7865c", "metadata": {}, "source": [ "

\n", @@ -1566,7 +1566,7 @@ }, { "cell_type": "markdown", - "id": "a9694e46", + "id": "9bb4a705", "metadata": {}, "source": [ "### Train the denoiser on both MNIST and FashionMNIST, shuffling the training data\n", @@ -1577,7 +1577,7 @@ { "cell_type": "code", "execution_count": null, - "id": "ae52c3d0", + "id": "d229e0fa", "metadata": {}, "outputs": [], "source": [ @@ -1614,7 +1614,7 @@ { "cell_type": "code", "execution_count": null, - "id": "f71a710b", + "id": "2085c32f", "metadata": {}, "outputs": [], "source": [ @@ -1625,7 +1625,7 @@ { "cell_type": "code", "execution_count": null, - "id": "52a67bf2", + "id": "631c1b64", "metadata": {}, "outputs": [], "source": [ @@ -1635,7 +1635,7 @@ }, { "cell_type": "markdown", - "id": "b8fe50cf", + "id": "83bffaba", "metadata": {}, "source": [ "

\n", @@ -1646,7 +1646,7 @@ }, { "cell_type": "markdown", - "id": "ec448985", + "id": "1b7c9fcf", "metadata": {}, "source": [ "\n", @@ -1660,7 +1660,7 @@ }, { "cell_type": "markdown", - "id": "33838105", + "id": "c258e7ae", "metadata": {}, "source": [ "\n", @@ -1674,7 +1674,7 @@ }, { "cell_type": "markdown", - "id": "eee21f1e", + "id": "11700dbd", "metadata": {}, "source": [] } diff --git a/solution.ipynb b/solution.ipynb index fa15474..0557485 100644 --- a/solution.ipynb +++ b/solution.ipynb @@ -2,7 +2,7 @@ "cells": [ { "cell_type": "markdown", - "id": "ad68ff94", + "id": "055f5871", "metadata": {}, "source": [ "# Exercise 7: Failure Modes And Limits of Deep Learning" @@ -10,7 +10,7 @@ }, { "cell_type": "markdown", - "id": "c0f0735a", + "id": "327d7b71", "metadata": {}, "source": [ "In the following exercise, we explore the failure modes and limits of neural networks.\n", @@ -23,7 +23,7 @@ }, { "cell_type": "markdown", - "id": "5619f37d", + "id": "41654ae2", "metadata": {}, "source": [ "\n", @@ -44,7 +44,7 @@ }, { "cell_type": "markdown", - "id": "aba193c5", + "id": "0a64a471", "metadata": {}, "source": [ "### Acknowledgements\n", @@ -53,7 +53,7 @@ }, { "cell_type": "markdown", - "id": "c1cf118b", + "id": "b5bcabb9", "metadata": {}, "source": [ "### Data Loading\n", @@ -67,7 +67,7 @@ { "cell_type": "code", "execution_count": null, - "id": "c29ae4dc", + "id": "9d41afcb", "metadata": {}, "outputs": [], "source": [ @@ -90,7 +90,7 @@ }, { "cell_type": "markdown", - "id": "1bb942ea", + "id": "1d04380a", "metadata": {}, "source": [ "### Part 1: Preparation of a Tainted Dataset\n", @@ -101,7 +101,7 @@ { "cell_type": "code", "execution_count": null, - "id": "32077360", + "id": "9b0b1a97", "metadata": {}, "outputs": [], "source": [ @@ -115,7 +115,7 @@ { "cell_type": "code", "execution_count": null, - "id": "1adbc5ee", + "id": "4d83f1a2", "metadata": {}, "outputs": [], "source": [ @@ -126,7 +126,7 @@ }, { "cell_type": "markdown", - "id": "dd092467", + "id": "12b9d7af", "metadata": {}, "source": [ "## Part 1.1: Local Corruption of Data\n", @@ -137,7 +137,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5d779046", + "id": "022103f5", "metadata": {}, "outputs": [], "source": [ @@ -149,7 +149,7 @@ { "cell_type": "code", "execution_count": null, - "id": "9eae44bc", + "id": "64ea44e2", "metadata": {}, "outputs": [], "source": [ @@ -172,7 +172,7 @@ }, { "cell_type": "markdown", - "id": "1242b7da", + "id": "08e33b46", "metadata": {}, "source": [ "

\n", @@ -183,7 +183,7 @@ }, { "cell_type": "markdown", - "id": "73add44b", + "id": "6195f9ef", "metadata": { "tags": [ "solution" @@ -199,7 +199,7 @@ }, { "cell_type": "markdown", - "id": "35e8819c", + "id": "797de443", "metadata": { "tags": [ "solution" @@ -215,7 +215,7 @@ }, { "cell_type": "markdown", - "id": "586be487", + "id": "fee2f87c", "metadata": {}, "source": [ "

\n", @@ -226,7 +226,7 @@ }, { "cell_type": "markdown", - "id": "5b6c8072", + "id": "4a89fd8a", "metadata": { "tags": [ "solution" @@ -240,7 +240,7 @@ }, { "cell_type": "markdown", - "id": "d55321f4", + "id": "a58f5dfb", "metadata": { "tags": [ "solution" @@ -261,7 +261,7 @@ }, { "cell_type": "markdown", - "id": "2ad4f801", + "id": "3581f01f", "metadata": {}, "source": [ "## Part 1.2: Global Corruption of data\n", @@ -271,7 +271,7 @@ }, { "cell_type": "markdown", - "id": "0749a9f6", + "id": "6447348c", "metadata": {}, "source": [ "You may have noticed that the images are stored as arrays of integers. First we cast them to float to be able to add textures easily without integer wrapping issues." @@ -280,7 +280,7 @@ { "cell_type": "code", "execution_count": null, - "id": "19c5869e", + "id": "b3731533", "metadata": {}, "outputs": [], "source": [ @@ -291,7 +291,7 @@ }, { "cell_type": "markdown", - "id": "46e255ca", + "id": "7adcabd3", "metadata": {}, "source": [ "Then we create the grid texture and visualize it." @@ -300,7 +300,7 @@ { "cell_type": "code", "execution_count": null, - "id": "823060ce", + "id": "6b604fa3", "metadata": {}, "outputs": [], "source": [ @@ -316,7 +316,7 @@ }, { "cell_type": "markdown", - "id": "c09f310e", + "id": "c1368fb3", "metadata": {}, "source": [ "Next we add the texture to all 4s in the train and test set." @@ -325,7 +325,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5264fb24", + "id": "38a80836", "metadata": {}, "outputs": [], "source": [ @@ -336,7 +336,7 @@ }, { "cell_type": "markdown", - "id": "d0235c57", + "id": "cf303dd0", "metadata": {}, "source": [ "After adding the texture, we have to make sure the values are between 0 and 255 and then cast back to uint8.\n", @@ -346,7 +346,7 @@ { "cell_type": "code", "execution_count": null, - "id": "bf580bd0", + "id": "503dcb25", "metadata": {}, "outputs": [], "source": [ @@ -362,7 +362,7 @@ { "cell_type": "code", "execution_count": null, - "id": "dc053eb0", + "id": "7781c186", "metadata": {}, "outputs": [], "source": [ @@ -384,7 +384,7 @@ }, { "cell_type": "markdown", - "id": "66a4eb68", + "id": "4ec55e8d", "metadata": {}, "source": [ "

\n", @@ -395,7 +395,7 @@ }, { "cell_type": "markdown", - "id": "1783f875", + "id": "3fae04f1", "metadata": { "tags": [ "solution" @@ -413,7 +413,7 @@ }, { "cell_type": "markdown", - "id": "9adb2396", + "id": "f003eab9", "metadata": { "tags": [ "solution" @@ -442,7 +442,7 @@ }, { "cell_type": "markdown", - "id": "ea13603f", + "id": "33f601d3", "metadata": {}, "source": [ "\n", @@ -454,7 +454,7 @@ }, { "cell_type": "markdown", - "id": "2dc8d655", + "id": "12c7f43e", "metadata": { "tags": [ "solution" @@ -468,7 +468,7 @@ }, { "cell_type": "markdown", - "id": "239d45dc", + "id": "eaa89530", "metadata": { "tags": [ "solution" @@ -482,7 +482,7 @@ }, { "cell_type": "markdown", - "id": "5a17ff4d", + "id": "c4f22201", "metadata": {}, "source": [ "\n", @@ -495,7 +495,7 @@ }, { "cell_type": "markdown", - "id": "e6cb618a", + "id": "f7407f20", "metadata": {}, "source": [ "\n", @@ -513,7 +513,7 @@ }, { "cell_type": "markdown", - "id": "8cb597ed", + "id": "f126c5e4", "metadata": {}, "source": [ "### Part 2: Create and Train an Image Classification Neural Network on Clean and Tainted Data\n", @@ -524,7 +524,7 @@ { "cell_type": "code", "execution_count": null, - "id": "0a677906", + "id": "eda4fb9a", "metadata": {}, "outputs": [], "source": [ @@ -538,7 +538,7 @@ }, { "cell_type": "markdown", - "id": "d76c4b98", + "id": "fcba2a9c", "metadata": {}, "source": [ "Now we will train the neural network. A training function is provided below - this should be familiar, but make sure you look it over and understand what is happening in the training loop." @@ -547,7 +547,7 @@ { "cell_type": "code", "execution_count": null, - "id": "7d448ce4", + "id": "1d7471e6", "metadata": {}, "outputs": [], "source": [ @@ -572,7 +572,7 @@ }, { "cell_type": "markdown", - "id": "855c4b61", + "id": "b20e8ef1", "metadata": {}, "source": [ "We have to choose hyperparameters for our model. We have selected to train for two epochs, with a batch size of 64 for training and 1000 for testing. We are using the cross entropy loss, a standard multi-class classification loss." @@ -581,7 +581,7 @@ { "cell_type": "code", "execution_count": null, - "id": "8a2d97a2", + "id": "67dc8176", "metadata": {}, "outputs": [], "source": [ @@ -600,7 +600,7 @@ }, { "cell_type": "markdown", - "id": "441c4d04", + "id": "c167e7f1", "metadata": {}, "source": [ "Next we initialize a clean model, and a tainted model. We want to have reproducible results, so we set the initial weights with a specific random seed. The seed number does not matter, just that it is the same!" @@ -609,7 +609,7 @@ { "cell_type": "code", "execution_count": null, - "id": "28d546e4", + "id": "c5ed5585", "metadata": {}, "outputs": [], "source": [ @@ -637,7 +637,7 @@ }, { "cell_type": "markdown", - "id": "9eb196cd", + "id": "ef87074c", "metadata": {}, "source": [ "Next we initialize the clean and tainted dataloaders, again with a specific random seed for reproducibility." @@ -646,7 +646,7 @@ { "cell_type": "code", "execution_count": null, - "id": "133a85ba", + "id": "dbcf65c9", "metadata": {}, "outputs": [], "source": [ @@ -660,7 +660,7 @@ }, { "cell_type": "markdown", - "id": "90762c28", + "id": "9cb8b4b4", "metadata": {}, "source": [ "Now it is time to train the neural networks! We are storing the training loss history for each model so we can visualize it later." @@ -669,7 +669,7 @@ { "cell_type": "code", "execution_count": null, - "id": "a949ffda", + "id": "1ff6bb66", "metadata": {}, "outputs": [], "source": [ @@ -702,7 +702,7 @@ }, { "cell_type": "markdown", - "id": "96bc28fd", + "id": "f389ca38", "metadata": {}, "source": [ "Now we visualize the loss history for the clean and tainted models." @@ -711,7 +711,7 @@ { "cell_type": "code", "execution_count": null, - "id": "29093a14", + "id": "9473ae0f", "metadata": {}, "outputs": [], "source": [ @@ -726,7 +726,7 @@ }, { "cell_type": "markdown", - "id": "c7dddc4b", + "id": "5b6c2993", "metadata": {}, "source": [ "

\n", @@ -737,7 +737,7 @@ }, { "cell_type": "markdown", - "id": "dbf8c34e", + "id": "db3a2aef", "metadata": { "tags": [ "solution" @@ -751,7 +751,7 @@ }, { "cell_type": "markdown", - "id": "d1e6912d", + "id": "f73fba19", "metadata": { "tags": [ "solution" @@ -765,7 +765,7 @@ }, { "cell_type": "markdown", - "id": "b20df043", + "id": "db77e034", "metadata": {}, "source": [ "

\n", @@ -776,7 +776,7 @@ }, { "cell_type": "markdown", - "id": "fb4e94d9", + "id": "384c3592", "metadata": { "tags": [ "solution" @@ -790,7 +790,7 @@ }, { "cell_type": "markdown", - "id": "5dac1f8d", + "id": "87fbc8a6", "metadata": { "tags": [ "solution" @@ -804,7 +804,7 @@ }, { "cell_type": "markdown", - "id": "94551ca6", + "id": "4aed0994", "metadata": {}, "source": [ "

\n", @@ -815,7 +815,7 @@ }, { "cell_type": "markdown", - "id": "e0a63648", + "id": "4a8d9f85", "metadata": { "tags": [ "solution" @@ -829,7 +829,7 @@ }, { "cell_type": "markdown", - "id": "774a4d5b", + "id": "cefcccfc", "metadata": { "tags": [ "solution" @@ -843,7 +843,7 @@ }, { "cell_type": "markdown", - "id": "edcc38e3", + "id": "e2ad4888", "metadata": {}, "source": [ "

\n", @@ -855,7 +855,7 @@ }, { "cell_type": "markdown", - "id": "ba7ae77b", + "id": "fd85af08", "metadata": {}, "source": [ "

\n", @@ -870,7 +870,7 @@ }, { "cell_type": "markdown", - "id": "e0afcf03", + "id": "35faa65c", "metadata": {}, "source": [ "### Part 3: Examining the Results of the Clean and Tainted Networks\n", @@ -883,7 +883,7 @@ { "cell_type": "code", "execution_count": null, - "id": "2c8432f0", + "id": "b9571f86", "metadata": {}, "outputs": [], "source": [ @@ -905,7 +905,7 @@ }, { "cell_type": "markdown", - "id": "dac0d3bd", + "id": "1ba7a46b", "metadata": {}, "source": [ "Now we call the predict method with the clean and tainted models on the clean and tainted datasets." @@ -914,7 +914,7 @@ { "cell_type": "code", "execution_count": null, - "id": "c6438d2e", + "id": "a64f5d22", "metadata": {}, "outputs": [], "source": [ @@ -926,7 +926,7 @@ }, { "cell_type": "markdown", - "id": "f6ec7c0d", + "id": "2937a3f5", "metadata": {}, "source": [ "We can investigate the results using the confusion matrix, which you should recall from the Introduction to Machine Learning exercise. The function in the cell below will create a nicely annotated confusion matrix." @@ -935,7 +935,7 @@ { "cell_type": "code", "execution_count": null, - "id": "ada1daff", + "id": "2d99588f", "metadata": { "lines_to_next_cell": 1 }, @@ -990,7 +990,7 @@ }, { "cell_type": "markdown", - "id": "1c841eaa", + "id": "ba93ea0c", "metadata": {}, "source": [ "Now we will generate confusion matrices for each model/data combination. Take your time and try and interpret these, and then try and answer the questions below." @@ -999,7 +999,7 @@ { "cell_type": "code", "execution_count": null, - "id": "073a89a2", + "id": "03fa45d8", "metadata": {}, "outputs": [], "source": [ @@ -1011,7 +1011,7 @@ }, { "cell_type": "markdown", - "id": "267208ff", + "id": "0d65dd6b", "metadata": {}, "source": [ "

\n", @@ -1022,7 +1022,7 @@ }, { "cell_type": "markdown", - "id": "29690755", + "id": "a242141f", "metadata": { "tags": [ "solution" @@ -1036,7 +1036,7 @@ }, { "cell_type": "markdown", - "id": "ba56b808", + "id": "7056d957", "metadata": { "tags": [ "solution" @@ -1051,7 +1051,7 @@ }, { "cell_type": "markdown", - "id": "82d1cba3", + "id": "54c38a61", "metadata": {}, "source": [ "

\n", @@ -1062,7 +1062,7 @@ }, { "cell_type": "markdown", - "id": "cc035f15", + "id": "e9d8355a", "metadata": { "tags": [ "solution" @@ -1076,7 +1076,7 @@ }, { "cell_type": "markdown", - "id": "0aafabb4", + "id": "5f231071", "metadata": { "tags": [ "solution" @@ -1090,7 +1090,7 @@ }, { "cell_type": "markdown", - "id": "dd6ca1dd", + "id": "afcf048a", "metadata": {}, "source": [ "

\n", @@ -1101,7 +1101,7 @@ }, { "cell_type": "markdown", - "id": "5550a081", + "id": "27a27d7d", "metadata": { "tags": [ "solution" @@ -1115,7 +1115,7 @@ }, { "cell_type": "markdown", - "id": "ce131527", + "id": "562d72a5", "metadata": { "tags": [ "solution" @@ -1132,7 +1132,7 @@ }, { "cell_type": "markdown", - "id": "c231d586", + "id": "c5751b3e", "metadata": {}, "source": [ "

\n", @@ -1143,7 +1143,7 @@ }, { "cell_type": "markdown", - "id": "751a2905", + "id": "c670d437", "metadata": { "tags": [ "solution" @@ -1157,7 +1157,7 @@ }, { "cell_type": "markdown", - "id": "52c169b9", + "id": "7018f722", "metadata": { "tags": [ "solution" @@ -1177,7 +1177,7 @@ }, { "cell_type": "markdown", - "id": "a676ba72", + "id": "d2812f67", "metadata": {}, "source": [ "

\n", @@ -1189,7 +1189,7 @@ }, { "cell_type": "markdown", - "id": "e9a5583c", + "id": "8d411a40", "metadata": {}, "source": [ "

\n", @@ -1204,7 +1204,7 @@ }, { "cell_type": "markdown", - "id": "c30d4df6", + "id": "8249ac3d", "metadata": {}, "source": [ "### Part 4: Interpretation with Integrated Gradients\n", @@ -1213,7 +1213,7 @@ }, { "cell_type": "markdown", - "id": "2784e751", + "id": "7c235272", "metadata": {}, "source": [ "\n", @@ -1223,7 +1223,7 @@ { "cell_type": "code", "execution_count": null, - "id": "7403b38f", + "id": "b2d82d85", "metadata": {}, "outputs": [], "source": [ @@ -1256,7 +1256,7 @@ }, { "cell_type": "markdown", - "id": "3f1881d0", + "id": "a20292b4", "metadata": {}, "source": [ "Next we provide a function to visualize the output of integrated gradients, using the function above to actually run the algorithm." @@ -1265,7 +1265,7 @@ { "cell_type": "code", "execution_count": null, - "id": "1ef66e49", + "id": "f39b4d66", "metadata": {}, "outputs": [], "source": [ @@ -1304,7 +1304,7 @@ }, { "cell_type": "markdown", - "id": "3587e26e", + "id": "89ca294b", "metadata": {}, "source": [ "To start examining the results, we will call the `visualize_integrated_gradients` with the tainted and clean models on the tainted and clean sevens.\n", @@ -1315,7 +1315,7 @@ { "cell_type": "code", "execution_count": null, - "id": "3a141027", + "id": "68a1916d", "metadata": {}, "outputs": [], "source": [ @@ -1325,7 +1325,7 @@ }, { "cell_type": "markdown", - "id": "09f0b17b", + "id": "1a3c24c8", "metadata": {}, "source": [ "

\n", @@ -1336,7 +1336,7 @@ }, { "cell_type": "markdown", - "id": "43a466fa", + "id": "91c49b74", "metadata": { "tags": [ "solution" @@ -1350,7 +1350,7 @@ }, { "cell_type": "markdown", - "id": "53e3d16c", + "id": "9e0d6db2", "metadata": { "tags": [ "solution" @@ -1365,7 +1365,7 @@ }, { "cell_type": "markdown", - "id": "e886ceb9", + "id": "039bdb2d", "metadata": {}, "source": [ "Now let's look at the attention of the tainted model!" @@ -1374,7 +1374,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5d8fe87c", + "id": "f42237ef", "metadata": {}, "outputs": [], "source": [ @@ -1384,7 +1384,7 @@ }, { "cell_type": "markdown", - "id": "63f51d95", + "id": "7666839c", "metadata": {}, "source": [ "

\n", @@ -1395,7 +1395,7 @@ }, { "cell_type": "markdown", - "id": "96f968ca", + "id": "7e580a75", "metadata": { "tags": [ "solution" @@ -1409,7 +1409,7 @@ }, { "cell_type": "markdown", - "id": "98ffa814", + "id": "8b78225a", "metadata": { "tags": [ "solution" @@ -1427,7 +1427,7 @@ }, { "cell_type": "markdown", - "id": "d84b50f2", + "id": "20006a90", "metadata": {}, "source": [ "Now let's look at the regions of the image that Integrated Gradients highlights as important for classifying fours in the clean and tainted models." @@ -1436,7 +1436,7 @@ { "cell_type": "code", "execution_count": null, - "id": "1f2524bc", + "id": "f2b422de", "metadata": {}, "outputs": [], "source": [ @@ -1448,7 +1448,7 @@ }, { "cell_type": "markdown", - "id": "162b2791", + "id": "f3470b70", "metadata": {}, "source": [ "

\n", @@ -1459,7 +1459,7 @@ }, { "cell_type": "markdown", - "id": "19e8eaa9", + "id": "3af071e0", "metadata": { "tags": [ "solution" @@ -1473,7 +1473,7 @@ }, { "cell_type": "markdown", - "id": "f382878c", + "id": "f5614261", "metadata": { "tags": [ "solution" @@ -1490,7 +1490,7 @@ }, { "cell_type": "markdown", - "id": "693673e7", + "id": "2b2ccff7", "metadata": {}, "source": [ "

\n", @@ -1501,7 +1501,7 @@ }, { "cell_type": "markdown", - "id": "2e00c171", + "id": "55a09b6c", "metadata": { "tags": [ "solution" @@ -1515,7 +1515,7 @@ }, { "cell_type": "markdown", - "id": "15827a8b", + "id": "113d50b3", "metadata": { "tags": [ "solution" @@ -1531,7 +1531,7 @@ }, { "cell_type": "markdown", - "id": "07ffa5c9", + "id": "77638560", "metadata": {}, "source": [ "

\n", @@ -1544,7 +1544,7 @@ }, { "cell_type": "markdown", - "id": "e2b3e006", + "id": "0e7c467c", "metadata": {}, "source": [ "

\n", @@ -1558,7 +1558,7 @@ }, { "cell_type": "markdown", - "id": "d9c75351", + "id": "d5b37c02", "metadata": {}, "source": [ "## Part 5: Importance of using the right training data\n", @@ -1570,7 +1570,7 @@ }, { "cell_type": "markdown", - "id": "3c96a7d4", + "id": "4ab7521d", "metadata": {}, "source": [ "First, we will write a function to add noise to the MNIST dataset, so that we can train a model to denoise it." @@ -1579,7 +1579,7 @@ { "cell_type": "code", "execution_count": null, - "id": "7eb143be", + "id": "15340fcc", "metadata": {}, "outputs": [], "source": [ @@ -1592,7 +1592,7 @@ }, { "cell_type": "markdown", - "id": "420f2eb7", + "id": "bcb17b47", "metadata": {}, "source": [ "Next we will visualize a couple MNIST examples with and without noise." @@ -1601,7 +1601,7 @@ { "cell_type": "code", "execution_count": null, - "id": "0c9ba2bc", + "id": "3f4142ec", "metadata": {}, "outputs": [], "source": [ @@ -1630,7 +1630,7 @@ }, { "cell_type": "markdown", - "id": "3aa422bb", + "id": "32177f2e", "metadata": {}, "source": [ "### UNet model\n", @@ -1640,7 +1640,7 @@ }, { "cell_type": "markdown", - "id": "ce6e4ffe", + "id": "0bde3d98", "metadata": {}, "source": [ "The training loop code is also provided here. It is similar to the code used to train the image classification model previously, but look it over to make sure there are no surprises." @@ -1649,7 +1649,7 @@ { "cell_type": "code", "execution_count": null, - "id": "22e3196a", + "id": "e642d956", "metadata": {}, "outputs": [], "source": [ @@ -1697,7 +1697,7 @@ }, { "cell_type": "markdown", - "id": "afdc53ce", + "id": "f82de800", "metadata": {}, "source": [ "Here we choose hyperparameters and initialize the model and data loaders." @@ -1706,7 +1706,7 @@ { "cell_type": "code", "execution_count": null, - "id": "98818e5f", + "id": "3cf1768f", "metadata": {}, "outputs": [], "source": [ @@ -1744,7 +1744,7 @@ }, { "cell_type": "markdown", - "id": "851ee8bc", + "id": "c6491e06", "metadata": {}, "source": [ "Finally, we run the training loop!" @@ -1753,7 +1753,7 @@ { "cell_type": "code", "execution_count": null, - "id": "e75e5250", + "id": "a8ff968c", "metadata": {}, "outputs": [], "source": [ @@ -1764,7 +1764,7 @@ }, { "cell_type": "markdown", - "id": "3b123c83", + "id": "2c0e657c", "metadata": {}, "source": [ "As before, we will visualize the training loss. If all went correctly, it should decrease from around 1.0 to less than 0.2." @@ -1773,7 +1773,7 @@ { "cell_type": "code", "execution_count": null, - "id": "649578f4", + "id": "a5f92989", "metadata": { "lines_to_next_cell": 1 }, @@ -1789,7 +1789,7 @@ }, { "cell_type": "markdown", - "id": "31ee6225", + "id": "1ff69a50", "metadata": {}, "source": [ "### Check denoising performance\n", @@ -1800,7 +1800,7 @@ { "cell_type": "code", "execution_count": null, - "id": "aeada78c", + "id": "1d3ff452", "metadata": { "lines_to_next_cell": 1 }, @@ -1817,7 +1817,7 @@ { "cell_type": "code", "execution_count": null, - "id": "04b85210", + "id": "680d1a79", "metadata": { "lines_to_next_cell": 1 }, @@ -1843,7 +1843,7 @@ }, { "cell_type": "markdown", - "id": "999110e1", + "id": "dd293e3c", "metadata": {}, "source": [ "We pick 8 images to show:" @@ -1852,7 +1852,7 @@ { "cell_type": "code", "execution_count": null, - "id": "48932965", + "id": "d950e273", "metadata": {}, "outputs": [], "source": [ @@ -1862,7 +1862,7 @@ }, { "cell_type": "markdown", - "id": "a88faa07", + "id": "5093a370", "metadata": {}, "source": [ "

\n", @@ -1873,7 +1873,7 @@ }, { "cell_type": "markdown", - "id": "c559a605", + "id": "9ee5481c", "metadata": { "tags": [ "solution" @@ -1887,7 +1887,7 @@ }, { "cell_type": "markdown", - "id": "3419188a", + "id": "7ea07946", "metadata": { "tags": [ "solution" @@ -1901,7 +1901,7 @@ }, { "cell_type": "markdown", - "id": "933c7ac9", + "id": "3e5bdd01", "metadata": {}, "source": [ "### Apply trained model on 'wrong' data\n", @@ -1911,7 +1911,7 @@ }, { "cell_type": "markdown", - "id": "5b4369e0", + "id": "08970f43", "metadata": {}, "source": [ "### Load the Fashion MNIST dataset\n", @@ -1922,7 +1922,7 @@ { "cell_type": "code", "execution_count": null, - "id": "5e57d385", + "id": "e96ed5e7", "metadata": {}, "outputs": [], "source": [ @@ -1943,7 +1943,7 @@ }, { "cell_type": "markdown", - "id": "b36c6e41", + "id": "f00758c2", "metadata": {}, "source": [ "Next we apply the denoising model we trained on the MNIST data to FashionMNIST, and visualize the results." @@ -1952,7 +1952,7 @@ { "cell_type": "code", "execution_count": null, - "id": "6744e360", + "id": "89b14b4b", "metadata": {}, "outputs": [], "source": [ @@ -1962,7 +1962,7 @@ }, { "cell_type": "markdown", - "id": "971da0c3", + "id": "5e1870b6", "metadata": {}, "source": [ "

\n", @@ -1973,7 +1973,7 @@ }, { "cell_type": "markdown", - "id": "bbc529ed", + "id": "610c8a41", "metadata": { "tags": [ "solution" @@ -1987,7 +1987,7 @@ }, { "cell_type": "markdown", - "id": "13941a06", + "id": "f6ed5e00", "metadata": { "tags": [ "solution" @@ -2001,7 +2001,7 @@ }, { "cell_type": "markdown", - "id": "1df30b46", + "id": "19f2c40c", "metadata": {}, "source": [ "

\n", @@ -2012,7 +2012,7 @@ }, { "cell_type": "markdown", - "id": "43fc08eb", + "id": "4274f603", "metadata": { "tags": [ "solution" @@ -2026,7 +2026,7 @@ }, { "cell_type": "markdown", - "id": "43e047c9", + "id": "c5a2dfcc", "metadata": { "tags": [ "solution" @@ -2041,7 +2041,7 @@ }, { "cell_type": "markdown", - "id": "835030fd", + "id": "fb0eeb74", "metadata": {}, "source": [ "### Train the denoiser on both MNIST and FashionMNIST\n", @@ -2052,7 +2052,7 @@ { "cell_type": "code", "execution_count": null, - "id": "c7cc9bb3", + "id": "eb150490", "metadata": {}, "outputs": [], "source": [ @@ -2089,7 +2089,7 @@ { "cell_type": "code", "execution_count": null, - "id": "46edff16", + "id": "ca64cf2e", "metadata": {}, "outputs": [], "source": [ @@ -2100,7 +2100,7 @@ { "cell_type": "code", "execution_count": null, - "id": "2dac72fa", + "id": "8574e737", "metadata": {}, "outputs": [], "source": [ @@ -2110,7 +2110,7 @@ }, { "cell_type": "markdown", - "id": "288c6764", + "id": "84a7865c", "metadata": {}, "source": [ "

\n", @@ -2121,7 +2121,7 @@ }, { "cell_type": "markdown", - "id": "433162e3", + "id": "59ececbf", "metadata": { "lines_to_next_cell": 0, "tags": [ @@ -2139,7 +2139,7 @@ }, { "cell_type": "markdown", - "id": "a9694e46", + "id": "9bb4a705", "metadata": {}, "source": [ "### Train the denoiser on both MNIST and FashionMNIST, shuffling the training data\n", @@ -2150,7 +2150,7 @@ { "cell_type": "code", "execution_count": null, - "id": "ae52c3d0", + "id": "d229e0fa", "metadata": {}, "outputs": [], "source": [ @@ -2187,7 +2187,7 @@ { "cell_type": "code", "execution_count": null, - "id": "f71a710b", + "id": "2085c32f", "metadata": {}, "outputs": [], "source": [ @@ -2198,7 +2198,7 @@ { "cell_type": "code", "execution_count": null, - "id": "52a67bf2", + "id": "631c1b64", "metadata": {}, "outputs": [], "source": [ @@ -2208,7 +2208,7 @@ }, { "cell_type": "markdown", - "id": "b8fe50cf", + "id": "83bffaba", "metadata": {}, "source": [ "

\n", @@ -2219,7 +2219,7 @@ }, { "cell_type": "markdown", - "id": "23c0b50d", + "id": "35e0a667", "metadata": { "tags": [ "solution" @@ -2233,7 +2233,7 @@ }, { "cell_type": "markdown", - "id": "ec448985", + "id": "1b7c9fcf", "metadata": {}, "source": [ "\n", @@ -2247,7 +2247,7 @@ }, { "cell_type": "markdown", - "id": "33838105", + "id": "c258e7ae", "metadata": {}, "source": [ "\n", @@ -2261,7 +2261,7 @@ }, { "cell_type": "markdown", - "id": "eee21f1e", + "id": "11700dbd", "metadata": {}, "source": [] }