{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "KrTEd7hNXeqT",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "cfcf269d-8390-4c42-94d0-e135efc596e2"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/home/himalaya/.local/lib/python3.10/site-packages/matplotlib/projections/__init__.py:63: UserWarning: Unable to import Axes3D. This may be due to multiple versions of Matplotlib being installed (e.g. as a system package and as a pip package). As a result, the 3D projection is not available.\n",
            "  warnings.warn(\"Unable to import Axes3D. This may be due to multiple versions of \"\n"
          ]
        }
      ],
      "source": [
        "import os\n",
        "import cv2\n",
        "import torch\n",
        "import numpy as np\n",
        "import torch.nn as nn\n",
        "import torch.optim as optim\n",
        "import matplotlib.pyplot as plt\n",
        "import torch.nn.functional as F\n",
        "from torchvision import transforms\n",
        "from torch.utils.data import Dataset\n",
        "from torchvision.datasets import MNIST\n",
        "from torch.utils.data import DataLoader\n",
        "from torchvision import datasets, transforms"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Define transforms & Data Loaders.\n",
        "\n",
        "I have used 10x10 Resize for simplicilty.\n",
        "\n",
        "More neurons lead to very large CNF Formulas that take time to work with.\n"
      ],
      "metadata": {
        "id": "4FeIfG1POBjm"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "cQuyfC11tcgz"
      },
      "outputs": [],
      "source": [
        "transform=transforms.Compose([\n",
        "                       transforms.ToTensor(),\n",
        "                       transforms.Normalize((0.1307,), (0.3081,)),\n",
        "                       transforms.Resize((10,10)),\n",
        "                       ])\n",
        "\n",
        "dataset_train = MNIST(root='./data', train=True, download=True, transform=transform)\n",
        "dataset_test = MNIST(root='./data', train=False, download=True, transform=transform)\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "HudJ95LwuhhR"
      },
      "outputs": [],
      "source": [
        "\n",
        "train_loader = DataLoader(dataset_train, batch_size=16, shuffle=True)\n",
        "test_loader = DataLoader(dataset_test, batch_size=16, shuffle=False)\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "class_labels = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9']\n",
        "\n",
        "fig, axes = plt.subplots(2, 5, figsize=(12, 6))  # Create a 2x5 subplot grid\n",
        "\n",
        "for class_idx, class_label in enumerate(class_labels):\n",
        "    index = next(idx for idx, (_, label) in enumerate(dataset_train) if label == class_idx)\n",
        "\n",
        "    image, _ = dataset_train[index]\n",
        "\n",
        "    row = class_idx // 5  # Calculate the row index (0 or 1)\n",
        "    col = class_idx % 5   # Calculate the column index (0 to 4)\n",
        "\n",
        "    axes[row, col].imshow(image.squeeze().numpy(), cmap='gray')\n",
        "    axes[row, col].axis('off')\n",
        "    axes[row, col].set_title(class_label)\n",
        "\n",
        "plt.tight_layout()\n",
        "plt.show()\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 560
        },
        "id": "4ckxZT9IbMCH",
        "outputId": "87bd61b2-4120-47ee-aba9-afa3a0e99fb3"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1200x600 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABKUAAAIfCAYAAAChPG9iAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAlQUlEQVR4nO3da5DW9Xn/8esGRE5C5eQJGkwRHBFaqwYhnlKtEjJAVCQHHTDFEuOBkkPNGENxSLSxtY1aJzWMBg9gRLGtSpQoptYY8RQxkRoDxWARDAiKgGQBl/v/4F9JUEg36X6v3y68XjM+yM36mUvkF/Ttvbu1er1eDwAAAABI1KbqAwAAAADY+4hSAAAAAKQTpQAAAABIJ0oBAAAAkE6UAgAAACCdKAUAAABAOlEKAAAAgHSiFAAAAADpRCkAAAAA0olSAAAAAKQTpfZQW7ZsiS9/+ctx8MEHR8eOHWPo0KHx8MMPV30WsBubNm2KadOmxYgRI6J79+5Rq9XilltuqfosYBeeeeaZuPjii2PQoEHRuXPn+MM//MMYN25cLFmypOrTgF34z//8zzj77LPjgx/8YHTq1Cl69uwZJ554Ytx///1VnwY0wZVXXhm1Wi2OPPLIqk+hAFFqD3XeeefFP/7jP8Y555wT1113XbRt2zZGjhwZjz/+eNWnAbuwdu3amD59evzsZz+LP/7jP676HOC3uPrqq+Oee+6JU045Ja677rqYNGlSPPbYY/Gnf/qnsXjx4qrPA97jlVdeiY0bN8aECRPiuuuui6lTp0ZExOjRo2PGjBkVXwf8Nq+++mpcddVV0blz56pPoZBavV6vV30Ezevpp5+OoUOHxt///d/Hl770pYiIaGhoiCOPPDJ69+4dTzzxRMUXAu+1ZcuWePPNN+PAAw+MZ599No499tiYOXNmnHfeeVWfBrzHE088Ecccc0y0b99+x2tLly6NwYMHx9ixY2PWrFkVXgc0RWNjYxx99NHR0NAQL730UtXnALvxyU9+Ml5//fVobGyMtWvX+o8/eyDvlNoDzZ07N9q2bRuTJk3a8VqHDh1i4sSJsXDhwlixYkWF1wG7su+++8aBBx5Y9RlAEwwfPnynIBURcdhhh8WgQYPiZz/7WUVXAb+Ltm3bRt++fWP9+vVVnwLsxmOPPRZz586Na6+9tupTKEiU2gMtWrQoBgwYEF27dt3p9Q996EMREfH8889XcBUA7Lnq9XqsXr06evbsWfUpwG68/fbbsXbt2li2bFl885vfjAcffDBOOeWUqs8CdqGxsTEuueSSOP/882Pw4MFVn0NB7ao+gOb32muvxUEHHfS+1999bdWqVdknAcAebfbs2bFy5cqYPn161acAu/HFL34xvv3tb0dERJs2beLMM8+MG264oeKrgF258cYb45VXXokFCxZUfQqFiVJ7oF/96lex7777vu/1Dh067PhxAKB5vPTSS3HRRRfFsGHDYsKECVWfA+zGlClTYuzYsbFq1aq46667orGxMbZu3Vr1WcB7rFu3Lv7mb/4mpk6dGr169ar6HArz6Xt7oI4dO8aWLVve93pDQ8OOHwcA/u9++ctfxsc+9rHo1q3bjq/pCLRMhx9+eJx66qkxfvz4mDdvXmzatClGjRoVvu8TtCxf/epXo3v37nHJJZdUfQoJRKk90EEHHRSvvfba+15/97WDDz44+yQA2OO89dZb8dGPfjTWr18f8+fP9/srtDJjx46NZ555JpYsWVL1KcD/WLp0acyYMSMmT54cq1atiuXLl8fy5cujoaEhtm3bFsuXL4833nij6jNpRqLUHuhP/uRPYsmSJbFhw4adXn/qqad2/DgA8PtraGiIUaNGxZIlS2LevHlxxBFHVH0S8Dt690tavPXWWxVfArxr5cqVsX379pg8eXIceuihO/546qmnYsmSJXHooYf6+o17GF9Tag80duzYuOaaa2LGjBnxpS99KSIitmzZEjNnzoyhQ4dG3759K74QAFqvxsbG+MQnPhELFy6Me++9N4YNG1b1ScBvsWbNmujdu/dOr23bti1uu+226Nixo6gMLciRRx4Z//qv//q+17/61a/Gxo0b47rrros/+qM/quAyShGl9kBDhw6Ns88+Oy677LJYs2ZN9O/fP2699dZYvnx53HzzzVWfB+zGDTfcEOvXr9/xHTLvv//+ePXVVyMi4pJLLolu3bpVeR7wP774xS/GfffdF6NGjYo33ngjZs2atdOPn3vuuRVdBuzKZz/72diwYUOceOKJccghh8Qvf/nLmD17drz00kvxD//wD9GlS5eqTwT+R8+ePePjH//4+16/9tprIyJ2+WO0brW6r+y3R2poaIipU6fGrFmz4s0334whQ4bE1772tTj99NOrPg3YjX79+sUrr7yyyx/7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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "FYPoPnVc0U-p",
        "outputId": "8e1928cf-7317-4aaa-d963-58800c43d682"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Train Dataset:\n",
            "Class 0: 5923 images\n",
            "Class 1: 6742 images\n",
            "Class 2: 5958 images\n",
            "Class 3: 6131 images\n",
            "Class 4: 5842 images\n",
            "Class 5: 5421 images\n",
            "Class 6: 5918 images\n",
            "Class 7: 6265 images\n",
            "Class 8: 5851 images\n",
            "Class 9: 5949 images\n",
            "\n",
            "Test Dataset:\n",
            "Class 0: 980 images\n",
            "Class 1: 1135 images\n",
            "Class 2: 1032 images\n",
            "Class 3: 1010 images\n",
            "Class 4: 982 images\n",
            "Class 5: 892 images\n",
            "Class 6: 958 images\n",
            "Class 7: 1028 images\n",
            "Class 8: 974 images\n",
            "Class 9: 1009 images\n"
          ]
        }
      ],
      "source": [
        "class_labels = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9']\n",
        "\n",
        "train_class_counts = [0] * len(class_labels)\n",
        "\n",
        "for _, label in dataset_train:\n",
        "    train_class_counts[label] += 1\n",
        "\n",
        "test_class_counts = [0] * len(class_labels)\n",
        "\n",
        "for _, label in dataset_test:\n",
        "    test_class_counts[label] += 1\n",
        "\n",
        "print(\"Train Dataset:\")\n",
        "for class_idx, class_label in enumerate(class_labels):\n",
        "    print(f\"Class {class_label}: {train_class_counts[class_idx]} images\")\n",
        "\n",
        "print(\"\\nTest Dataset:\")\n",
        "for class_idx, class_label in enumerate(class_labels):\n",
        "    print(f\"Class {class_label}: {test_class_counts[class_idx]} images\")"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Now define some functions & classes to Binarise the weights of the network for forward pass."
      ],
      "metadata": {
        "id": "MbqYUaZ1Oau2"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "QhYlYpAfS75a"
      },
      "outputs": [],
      "source": [
        "def Binarize(tensor,quant_mode='det'):\n",
        "    if quant_mode=='det':\n",
        "        return tensor.sign()\n",
        "    else:\n",
        "        return tensor.add_(1).div_(2).add_(torch.rand(tensor.size()).add(-0.5)).clamp_(0,1).round().mul_(2).add_(-1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Wh31I2AyTnmx"
      },
      "outputs": [],
      "source": [
        "class BinarizeLinear(nn.Linear):\n",
        "\n",
        "    def __init__(self, *kargs, **kwargs):\n",
        "        super(BinarizeLinear, self).__init__(*kargs, **kwargs)\n",
        "\n",
        "    def forward(self, input):\n",
        "\n",
        "        if input.size(1) != 100:\n",
        "            input.data=Binarize(input.data)\n",
        "        if not hasattr(self.weight,'org'):\n",
        "            self.weight.org=self.weight.data.clone()\n",
        "        self.weight.data=Binarize(self.weight.org)\n",
        "        out = nn.functional.linear(input, self.weight)\n",
        "        if not self.bias is None:\n",
        "            self.bias.org=self.bias.data.clone()\n",
        "            out += self.bias.view(1, -1).expand_as(out)\n",
        "\n",
        "        return out"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Train Function, in which the weights are binairsed for every forward pass by clampign them to 1 & -1. while the back prop is done on real set of teh weights, that are gotten rid of after training."
      ],
      "metadata": {
        "id": "0X7UIFxKOwTH"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "qwgIIgvyT1dY"
      },
      "outputs": [],
      "source": [
        "def train(epoch):\n",
        "    model.train()\n",
        "    for i, (data, target) in enumerate(train_loader):\n",
        "\n",
        "        data, target = data.to(device), target.to(device)\n",
        "\n",
        "        optimizer.zero_grad()\n",
        "        output = model(data)\n",
        "\n",
        "        loss = criterion(output, target)\n",
        "\n",
        "        if epoch%25==0:\n",
        "            optimizer.param_groups[0]['lr']=optimizer.param_groups[0]['lr']*0.1\n",
        "        optimizer.zero_grad()\n",
        "\n",
        "        loss.backward()\n",
        "\n",
        "        for p in list(model.parameters()):\n",
        "            if hasattr(p,'org'):\n",
        "                p.data.copy_(p.org)\n",
        "        optimizer.step()\n",
        "\n",
        "        for p in list(model.parameters()):\n",
        "            if hasattr(p,'org'):\n",
        "                p.org.copy_(p.data.clamp_(-1,1))\n",
        "\n",
        "        if i % 10 == 0:\n",
        "            print('Train Epoch: {} [{}/{} ({:.0f}%)]\\tLoss: {:.6f}'.format(\n",
        "                epoch, i * len(data), len(train_loader.dataset),\n",
        "                100. * i / len(train_loader), loss.item()))"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Test Fucntion"
      ],
      "metadata": {
        "id": "qVCfBVVeO5kX"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "jo7Ml3HET3d4"
      },
      "outputs": [],
      "source": [
        "def test():\n",
        "    model.eval()\n",
        "    test_loss = 0\n",
        "    correct = 0\n",
        "    with torch.no_grad():\n",
        "        for data, target in test_loader:\n",
        "            data, target = data.to(device), target.to(device)\n",
        "            output = model(data)\n",
        "            test_loss += criterion(output, target).item()\n",
        "            pred = output.data.max(1, keepdim=True)[1]\n",
        "            correct += pred.eq(target.data.view_as(pred)).cpu().sum()\n",
        "\n",
        "    test_loss /= len(test_loader.dataset)\n",
        "    accuracy = 100. * correct / len(test_loader.dataset)\n",
        "    print('\\nTest set: Average loss: {:.4f}, Accuracy: {}/{} ({:.0f}%)\\n'.format(\n",
        "        test_loss, correct, len(test_loader.dataset),\n",
        "        100. * correct / len(test_loader.dataset)))\n",
        "    return accuracy"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Now a BNN is defined with a single block & 20 neurons in the hidden layer. 100 in the input & 10 in the output."
      ],
      "metadata": {
        "id": "LN7-OOZBO2E7"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "UhvJB2pvPfj1"
      },
      "outputs": [],
      "source": [
        "class BNN_1blk_20(nn.Module):\n",
        "    def __init__(self, input_size, output_size):\n",
        "        super(BNN_1blk_20, self).__init__()\n",
        "        self.infl_ratio=1\n",
        "        self.input_size=input_size\n",
        "        self.output_size=output_size\n",
        "        self.num_internal_blocks=1\n",
        "\n",
        "        self.name='bnn_1blk_20'\n",
        "        self.fc1 = BinarizeLinear(input_size,20*self.infl_ratio)\n",
        "        self.htanh1 = nn.Hardtanh()\n",
        "        self.bn1 = nn.BatchNorm1d(20*self.infl_ratio)\n",
        "\n",
        "        self.fc5 = BinarizeLinear(20*self.infl_ratio,output_size)\n",
        "        self.logsoftmax=nn.LogSoftmax()\n",
        "        self.binarize_func=Binarize\n",
        "\n",
        "    def forward(self, x):\n",
        "        x = x.view(-1, self.input_size)\n",
        "        x = self.binarize_func(x)\n",
        "\n",
        "        x = self.fc1(x)\n",
        "        x = self.bn1(x)\n",
        "        x = self.htanh1(x)\n",
        "\n",
        "        x = self.fc5(x)\n",
        "        return self.logsoftmax(x)\n",
        "\n",
        "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
        "model = BNN_1blk_20(100,10)\n",
        "model=model.to(device)\n"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Training & Evaluation"
      ],
      "metadata": {
        "id": "jXCZs-TFPmc7"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "bzpQOm1BPxqC",
        "outputId": "d291cba0-cfdb-4f52-9c1c-72d88dd91abb"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "<ipython-input-19-0501bc8e8e83>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Train Epoch: 1 [0/60000 (0%)]\tLoss: 1.323427\n",
            "Train Epoch: 1 [1280/60000 (2%)]\tLoss: 1.302587\n",
            "Train Epoch: 1 [2560/60000 (4%)]\tLoss: 1.304566\n",
            "Train Epoch: 1 [3840/60000 (6%)]\tLoss: 1.902627\n",
            "Train Epoch: 1 [5120/60000 (9%)]\tLoss: 1.101730\n",
            "Train Epoch: 1 [6400/60000 (11%)]\tLoss: 1.211581\n",
            "Train Epoch: 1 [7680/60000 (13%)]\tLoss: 1.273204\n",
            "Train Epoch: 1 [8960/60000 (15%)]\tLoss: 1.261649\n",
            "Train Epoch: 1 [10240/60000 (17%)]\tLoss: 1.410656\n",
            "Train Epoch: 1 [11520/60000 (19%)]\tLoss: 1.323818\n",
            "Train Epoch: 1 [12800/60000 (21%)]\tLoss: 1.040961\n",
            "Train Epoch: 1 [14080/60000 (23%)]\tLoss: 1.105515\n",
            "Train Epoch: 1 [15360/60000 (26%)]\tLoss: 1.363896\n",
            "Train Epoch: 1 [16640/60000 (28%)]\tLoss: 0.993659\n",
            "Train Epoch: 1 [17920/60000 (30%)]\tLoss: 1.482359\n",
            "Train Epoch: 1 [19200/60000 (32%)]\tLoss: 1.149113\n",
            "Train Epoch: 1 [20480/60000 (34%)]\tLoss: 1.575279\n",
            "Train Epoch: 1 [21760/60000 (36%)]\tLoss: 1.418366\n",
            "Train Epoch: 1 [23040/60000 (38%)]\tLoss: 1.509853\n",
            "Train Epoch: 1 [24320/60000 (41%)]\tLoss: 1.135945\n",
            "Train Epoch: 1 [25600/60000 (43%)]\tLoss: 1.459794\n",
            "Train Epoch: 1 [26880/60000 (45%)]\tLoss: 1.521884\n",
            "Train Epoch: 1 [28160/60000 (47%)]\tLoss: 1.434490\n",
            "Train Epoch: 1 [29440/60000 (49%)]\tLoss: 1.110177\n",
            "Train Epoch: 1 [30720/60000 (51%)]\tLoss: 1.011918\n",
            "Train Epoch: 1 [32000/60000 (53%)]\tLoss: 1.603862\n",
            "Train Epoch: 1 [33280/60000 (55%)]\tLoss: 1.059292\n",
            "Train Epoch: 1 [34560/60000 (58%)]\tLoss: 1.551926\n",
            "Train Epoch: 1 [35840/60000 (60%)]\tLoss: 0.902996\n",
            "Train Epoch: 1 [37120/60000 (62%)]\tLoss: 1.312787\n",
            "Train Epoch: 1 [38400/60000 (64%)]\tLoss: 1.134003\n",
            "Train Epoch: 1 [39680/60000 (66%)]\tLoss: 1.729675\n",
            "Train Epoch: 1 [40960/60000 (68%)]\tLoss: 1.363759\n",
            "Train Epoch: 1 [42240/60000 (70%)]\tLoss: 1.506649\n",
            "Train Epoch: 1 [43520/60000 (72%)]\tLoss: 1.350107\n",
            "Train Epoch: 1 [44800/60000 (75%)]\tLoss: 1.688040\n",
            "Train Epoch: 1 [46080/60000 (77%)]\tLoss: 1.619957\n",
            "Train Epoch: 1 [47360/60000 (79%)]\tLoss: 1.057286\n",
            "Train Epoch: 1 [48640/60000 (81%)]\tLoss: 1.426579\n",
            "Train Epoch: 1 [49920/60000 (83%)]\tLoss: 0.973659\n",
            "Train Epoch: 1 [51200/60000 (85%)]\tLoss: 1.459563\n",
            "Train Epoch: 1 [52480/60000 (87%)]\tLoss: 1.362672\n",
            "Train Epoch: 1 [53760/60000 (90%)]\tLoss: 1.395330\n",
            "Train Epoch: 1 [55040/60000 (92%)]\tLoss: 1.135693\n",
            "Train Epoch: 1 [56320/60000 (94%)]\tLoss: 1.364353\n",
            "Train Epoch: 1 [57600/60000 (96%)]\tLoss: 1.519928\n",
            "Train Epoch: 1 [58880/60000 (98%)]\tLoss: 1.744437\n",
            "\n",
            "Test set: Average loss: 0.0106, Accuracy: 6845/10000 (68%)\n",
            "\n",
            "Train Epoch: 2 [0/60000 (0%)]\tLoss: 1.451381\n",
            "Train Epoch: 2 [1280/60000 (2%)]\tLoss: 1.375645\n",
            "Train Epoch: 2 [2560/60000 (4%)]\tLoss: 1.109384\n",
            "Train Epoch: 2 [3840/60000 (6%)]\tLoss: 1.451680\n",
            "Train Epoch: 2 [5120/60000 (9%)]\tLoss: 1.482270\n",
            "Train Epoch: 2 [6400/60000 (11%)]\tLoss: 1.590268\n",
            "Train Epoch: 2 [7680/60000 (13%)]\tLoss: 1.015999\n",
            "Train Epoch: 2 [8960/60000 (15%)]\tLoss: 1.175045\n",
            "Train Epoch: 2 [10240/60000 (17%)]\tLoss: 1.547931\n",
            "Train Epoch: 2 [11520/60000 (19%)]\tLoss: 1.325756\n",
            "Train Epoch: 2 [12800/60000 (21%)]\tLoss: 0.618082\n",
            "Train Epoch: 2 [14080/60000 (23%)]\tLoss: 1.279178\n",
            "Train Epoch: 2 [15360/60000 (26%)]\tLoss: 1.278281\n",
            "Train Epoch: 2 [16640/60000 (28%)]\tLoss: 1.057398\n",
            "Train Epoch: 2 [17920/60000 (30%)]\tLoss: 1.296605\n",
            "Train Epoch: 2 [19200/60000 (32%)]\tLoss: 1.023864\n",
            "Train Epoch: 2 [20480/60000 (34%)]\tLoss: 1.387689\n",
            "Train Epoch: 2 [21760/60000 (36%)]\tLoss: 1.193677\n",
            "Train Epoch: 2 [23040/60000 (38%)]\tLoss: 1.449161\n",
            "Train Epoch: 2 [24320/60000 (41%)]\tLoss: 1.095110\n",
            "Train Epoch: 2 [25600/60000 (43%)]\tLoss: 1.617610\n",
            "Train Epoch: 2 [26880/60000 (45%)]\tLoss: 1.297839\n",
            "Train Epoch: 2 [28160/60000 (47%)]\tLoss: 1.397561\n",
            "Train Epoch: 2 [29440/60000 (49%)]\tLoss: 1.176967\n",
            "Train Epoch: 2 [30720/60000 (51%)]\tLoss: 1.302768\n",
            "Train Epoch: 2 [32000/60000 (53%)]\tLoss: 1.398582\n",
            "Train Epoch: 2 [33280/60000 (55%)]\tLoss: 0.804130\n",
            "Train Epoch: 2 [34560/60000 (58%)]\tLoss: 1.343691\n",
            "Train Epoch: 2 [35840/60000 (60%)]\tLoss: 1.319327\n",
            "Train Epoch: 2 [37120/60000 (62%)]\tLoss: 1.582857\n",
            "Train Epoch: 2 [38400/60000 (64%)]\tLoss: 1.299873\n",
            "Train Epoch: 2 [39680/60000 (66%)]\tLoss: 1.453633\n",
            "Train Epoch: 2 [40960/60000 (68%)]\tLoss: 0.757567\n",
            "Train Epoch: 2 [42240/60000 (70%)]\tLoss: 1.806103\n",
            "Train Epoch: 2 [43520/60000 (72%)]\tLoss: 1.707471\n",
            "Train Epoch: 2 [44800/60000 (75%)]\tLoss: 1.248698\n",
            "Train Epoch: 2 [46080/60000 (77%)]\tLoss: 1.384504\n",
            "Train Epoch: 2 [47360/60000 (79%)]\tLoss: 1.404922\n",
            "Train Epoch: 2 [48640/60000 (81%)]\tLoss: 1.451267\n",
            "Train Epoch: 2 [49920/60000 (83%)]\tLoss: 1.594063\n",
            "Train Epoch: 2 [51200/60000 (85%)]\tLoss: 1.532595\n",
            "Train Epoch: 2 [52480/60000 (87%)]\tLoss: 1.347838\n",
            "Train Epoch: 2 [53760/60000 (90%)]\tLoss: 1.311765\n",
            "Train Epoch: 2 [55040/60000 (92%)]\tLoss: 1.631214\n",
            "Train Epoch: 2 [56320/60000 (94%)]\tLoss: 1.016129\n",
            "Train Epoch: 2 [57600/60000 (96%)]\tLoss: 1.477859\n",
            "Train Epoch: 2 [58880/60000 (98%)]\tLoss: 1.429435\n",
            "\n",
            "Test set: Average loss: 0.0100, Accuracy: 7060/10000 (71%)\n",
            "\n",
            "Train Epoch: 3 [0/60000 (0%)]\tLoss: 1.389002\n",
            "Train Epoch: 3 [1280/60000 (2%)]\tLoss: 1.521394\n",
            "Train Epoch: 3 [2560/60000 (4%)]\tLoss: 1.347884\n",
            "Train Epoch: 3 [3840/60000 (6%)]\tLoss: 1.127291\n",
            "Train Epoch: 3 [5120/60000 (9%)]\tLoss: 1.419214\n",
            "Train Epoch: 3 [6400/60000 (11%)]\tLoss: 2.094652\n",
            "Train Epoch: 3 [7680/60000 (13%)]\tLoss: 1.203817\n",
            "Train Epoch: 3 [8960/60000 (15%)]\tLoss: 1.885160\n",
            "Train Epoch: 3 [10240/60000 (17%)]\tLoss: 1.445566\n",
            "Train Epoch: 3 [11520/60000 (19%)]\tLoss: 1.024900\n",
            "Train Epoch: 3 [12800/60000 (21%)]\tLoss: 1.327283\n",
            "Train Epoch: 3 [14080/60000 (23%)]\tLoss: 1.252909\n",
            "Train Epoch: 3 [15360/60000 (26%)]\tLoss: 1.672738\n",
            "Train Epoch: 3 [16640/60000 (28%)]\tLoss: 1.790719\n",
            "Train Epoch: 3 [17920/60000 (30%)]\tLoss: 1.734252\n",
            "Train Epoch: 3 [19200/60000 (32%)]\tLoss: 1.356410\n",
            "Train Epoch: 3 [20480/60000 (34%)]\tLoss: 1.324276\n",
            "Train Epoch: 3 [21760/60000 (36%)]\tLoss: 0.986625\n",
            "Train Epoch: 3 [23040/60000 (38%)]\tLoss: 1.350295\n",
            "Train Epoch: 3 [24320/60000 (41%)]\tLoss: 1.375409\n",
            "Train Epoch: 3 [25600/60000 (43%)]\tLoss: 1.434784\n",
            "Train Epoch: 3 [26880/60000 (45%)]\tLoss: 1.249284\n",
            "Train Epoch: 3 [28160/60000 (47%)]\tLoss: 1.545120\n",
            "Train Epoch: 3 [29440/60000 (49%)]\tLoss: 1.430648\n",
            "Train Epoch: 3 [30720/60000 (51%)]\tLoss: 0.780409\n",
            "Train Epoch: 3 [32000/60000 (53%)]\tLoss: 1.449621\n",
            "Train Epoch: 3 [33280/60000 (55%)]\tLoss: 1.117994\n",
            "Train Epoch: 3 [34560/60000 (58%)]\tLoss: 1.265382\n",
            "Train Epoch: 3 [35840/60000 (60%)]\tLoss: 1.552611\n",
            "Train Epoch: 3 [37120/60000 (62%)]\tLoss: 1.699659\n",
            "Train Epoch: 3 [38400/60000 (64%)]\tLoss: 1.060221\n",
            "Train Epoch: 3 [39680/60000 (66%)]\tLoss: 1.510455\n",
            "Train Epoch: 3 [40960/60000 (68%)]\tLoss: 0.967637\n",
            "Train Epoch: 3 [42240/60000 (70%)]\tLoss: 1.331936\n",
            "Train Epoch: 3 [43520/60000 (72%)]\tLoss: 1.354233\n",
            "Train Epoch: 3 [44800/60000 (75%)]\tLoss: 1.450545\n",
            "Train Epoch: 3 [46080/60000 (77%)]\tLoss: 1.681588\n",
            "Train Epoch: 3 [47360/60000 (79%)]\tLoss: 1.362637\n",
            "Train Epoch: 3 [48640/60000 (81%)]\tLoss: 1.276517\n",
            "Train Epoch: 3 [49920/60000 (83%)]\tLoss: 1.455486\n",
            "Train Epoch: 3 [51200/60000 (85%)]\tLoss: 1.460639\n",
            "Train Epoch: 3 [52480/60000 (87%)]\tLoss: 2.195163\n",
            "Train Epoch: 3 [53760/60000 (90%)]\tLoss: 0.975071\n",
            "Train Epoch: 3 [55040/60000 (92%)]\tLoss: 1.465779\n",
            "Train Epoch: 3 [56320/60000 (94%)]\tLoss: 0.841523\n",
            "Train Epoch: 3 [57600/60000 (96%)]\tLoss: 1.539056\n",
            "Train Epoch: 3 [58880/60000 (98%)]\tLoss: 1.163362\n",
            "\n",
            "Test set: Average loss: 0.0099, Accuracy: 6908/10000 (69%)\n",
            "\n",
            "Train Epoch: 4 [0/60000 (0%)]\tLoss: 1.107988\n",
            "Train Epoch: 4 [1280/60000 (2%)]\tLoss: 1.680151\n",
            "Train Epoch: 4 [2560/60000 (4%)]\tLoss: 1.210005\n",
            "Train Epoch: 4 [3840/60000 (6%)]\tLoss: 1.477925\n",
            "Train Epoch: 4 [5120/60000 (9%)]\tLoss: 1.281792\n",
            "Train Epoch: 4 [6400/60000 (11%)]\tLoss: 0.864867\n",
            "Train Epoch: 4 [7680/60000 (13%)]\tLoss: 1.148120\n",
            "Train Epoch: 4 [8960/60000 (15%)]\tLoss: 1.041204\n",
            "Train Epoch: 4 [10240/60000 (17%)]\tLoss: 1.339540\n",
            "Train Epoch: 4 [11520/60000 (19%)]\tLoss: 1.103784\n",
            "Train Epoch: 4 [12800/60000 (21%)]\tLoss: 1.683883\n",
            "Train Epoch: 4 [14080/60000 (23%)]\tLoss: 1.356443\n",
            "Train Epoch: 4 [15360/60000 (26%)]\tLoss: 1.770995\n",
            "Train Epoch: 4 [16640/60000 (28%)]\tLoss: 1.338571\n",
            "Train Epoch: 4 [17920/60000 (30%)]\tLoss: 0.690891\n",
            "Train Epoch: 4 [19200/60000 (32%)]\tLoss: 1.133634\n",
            "Train Epoch: 4 [20480/60000 (34%)]\tLoss: 1.424707\n",
            "Train Epoch: 4 [21760/60000 (36%)]\tLoss: 1.120845\n",
            "Train Epoch: 4 [23040/60000 (38%)]\tLoss: 1.009273\n",
            "Train Epoch: 4 [24320/60000 (41%)]\tLoss: 1.509400\n",
            "Train Epoch: 4 [25600/60000 (43%)]\tLoss: 1.303439\n",
            "Train Epoch: 4 [26880/60000 (45%)]\tLoss: 1.421912\n",
            "Train Epoch: 4 [28160/60000 (47%)]\tLoss: 1.221958\n",
            "Train Epoch: 4 [29440/60000 (49%)]\tLoss: 1.064066\n",
            "Train Epoch: 4 [30720/60000 (51%)]\tLoss: 1.414387\n",
            "Train Epoch: 4 [32000/60000 (53%)]\tLoss: 1.349921\n",
            "Train Epoch: 4 [33280/60000 (55%)]\tLoss: 1.297552\n",
            "Train Epoch: 4 [34560/60000 (58%)]\tLoss: 1.439394\n",
            "Train Epoch: 4 [35840/60000 (60%)]\tLoss: 1.505491\n",
            "Train Epoch: 4 [37120/60000 (62%)]\tLoss: 1.252326\n",
            "Train Epoch: 4 [38400/60000 (64%)]\tLoss: 1.369066\n",
            "Train Epoch: 4 [39680/60000 (66%)]\tLoss: 1.232508\n",
            "Train Epoch: 4 [40960/60000 (68%)]\tLoss: 1.306063\n",
            "Train Epoch: 4 [42240/60000 (70%)]\tLoss: 1.433914\n",
            "Train Epoch: 4 [43520/60000 (72%)]\tLoss: 1.206451\n",
            "Train Epoch: 4 [44800/60000 (75%)]\tLoss: 1.488518\n",
            "Train Epoch: 4 [46080/60000 (77%)]\tLoss: 1.438977\n",
            "Train Epoch: 4 [47360/60000 (79%)]\tLoss: 1.433765\n",
            "Train Epoch: 4 [48640/60000 (81%)]\tLoss: 1.188270\n",
            "Train Epoch: 4 [49920/60000 (83%)]\tLoss: 1.620605\n",
            "Train Epoch: 4 [51200/60000 (85%)]\tLoss: 1.377249\n",
            "Train Epoch: 4 [52480/60000 (87%)]\tLoss: 1.727198\n",
            "Train Epoch: 4 [53760/60000 (90%)]\tLoss: 1.339351\n",
            "Train Epoch: 4 [55040/60000 (92%)]\tLoss: 1.201319\n",
            "Train Epoch: 4 [56320/60000 (94%)]\tLoss: 1.511653\n",
            "Train Epoch: 4 [57600/60000 (96%)]\tLoss: 1.174506\n",
            "Train Epoch: 4 [58880/60000 (98%)]\tLoss: 1.011667\n",
            "\n",
            "Test set: Average loss: 0.0120, Accuracy: 6531/10000 (65%)\n",
            "\n",
            "Train Epoch: 5 [0/60000 (0%)]\tLoss: 1.195822\n",
            "Train Epoch: 5 [1280/60000 (2%)]\tLoss: 1.745076\n",
            "Train Epoch: 5 [2560/60000 (4%)]\tLoss: 1.208835\n",
            "Train Epoch: 5 [3840/60000 (6%)]\tLoss: 1.005221\n",
            "Train Epoch: 5 [5120/60000 (9%)]\tLoss: 1.506827\n",
            "Train Epoch: 5 [6400/60000 (11%)]\tLoss: 1.472376\n",
            "Train Epoch: 5 [7680/60000 (13%)]\tLoss: 1.387529\n",
            "Train Epoch: 5 [8960/60000 (15%)]\tLoss: 1.155198\n",
            "Train Epoch: 5 [10240/60000 (17%)]\tLoss: 1.628896\n",
            "Train Epoch: 5 [11520/60000 (19%)]\tLoss: 1.389352\n",
            "Train Epoch: 5 [12800/60000 (21%)]\tLoss: 1.480023\n",
            "Train Epoch: 5 [14080/60000 (23%)]\tLoss: 1.068657\n",
            "Train Epoch: 5 [15360/60000 (26%)]\tLoss: 0.987107\n",
            "Train Epoch: 5 [16640/60000 (28%)]\tLoss: 1.589886\n",
            "Train Epoch: 5 [17920/60000 (30%)]\tLoss: 1.213188\n",
            "Train Epoch: 5 [19200/60000 (32%)]\tLoss: 1.347287\n",
            "Train Epoch: 5 [20480/60000 (34%)]\tLoss: 1.255826\n",
            "Train Epoch: 5 [21760/60000 (36%)]\tLoss: 1.255677\n",
            "Train Epoch: 5 [23040/60000 (38%)]\tLoss: 1.371092\n",
            "Train Epoch: 5 [24320/60000 (41%)]\tLoss: 1.296420\n",
            "Train Epoch: 5 [25600/60000 (43%)]\tLoss: 1.130147\n",
            "Train Epoch: 5 [26880/60000 (45%)]\tLoss: 1.348549\n",
            "Train Epoch: 5 [28160/60000 (47%)]\tLoss: 1.295610\n",
            "Train Epoch: 5 [29440/60000 (49%)]\tLoss: 1.318697\n",
            "Train Epoch: 5 [30720/60000 (51%)]\tLoss: 1.071566\n",
            "Train Epoch: 5 [32000/60000 (53%)]\tLoss: 0.889791\n",
            "Train Epoch: 5 [33280/60000 (55%)]\tLoss: 1.572646\n",
            "Train Epoch: 5 [34560/60000 (58%)]\tLoss: 1.222816\n",
            "Train Epoch: 5 [35840/60000 (60%)]\tLoss: 1.419078\n",
            "Train Epoch: 5 [37120/60000 (62%)]\tLoss: 1.386908\n",
            "Train Epoch: 5 [38400/60000 (64%)]\tLoss: 1.246523\n",
            "Train Epoch: 5 [39680/60000 (66%)]\tLoss: 1.232463\n",
            "Train Epoch: 5 [40960/60000 (68%)]\tLoss: 1.485817\n",
            "Train Epoch: 5 [42240/60000 (70%)]\tLoss: 1.262532\n",
            "Train Epoch: 5 [43520/60000 (72%)]\tLoss: 1.261546\n",
            "Train Epoch: 5 [44800/60000 (75%)]\tLoss: 1.542752\n",
            "Train Epoch: 5 [46080/60000 (77%)]\tLoss: 1.745566\n",
            "Train Epoch: 5 [47360/60000 (79%)]\tLoss: 1.290304\n",
            "Train Epoch: 5 [48640/60000 (81%)]\tLoss: 1.550503\n",
            "Train Epoch: 5 [49920/60000 (83%)]\tLoss: 1.185050\n",
            "Train Epoch: 5 [51200/60000 (85%)]\tLoss: 1.904934\n",
            "Train Epoch: 5 [52480/60000 (87%)]\tLoss: 1.263469\n",
            "Train Epoch: 5 [53760/60000 (90%)]\tLoss: 1.493713\n",
            "Train Epoch: 5 [55040/60000 (92%)]\tLoss: 1.341650\n",
            "Train Epoch: 5 [56320/60000 (94%)]\tLoss: 1.464642\n",
            "Train Epoch: 5 [57600/60000 (96%)]\tLoss: 1.217245\n",
            "Train Epoch: 5 [58880/60000 (98%)]\tLoss: 1.264316\n",
            "\n",
            "Test set: Average loss: 0.0121, Accuracy: 6569/10000 (66%)\n",
            "\n",
            "Train Epoch: 6 [0/60000 (0%)]\tLoss: 1.951738\n",
            "Train Epoch: 6 [1280/60000 (2%)]\tLoss: 1.485616\n",
            "Train Epoch: 6 [2560/60000 (4%)]\tLoss: 1.115136\n",
            "Train Epoch: 6 [3840/60000 (6%)]\tLoss: 1.269309\n",
            "Train Epoch: 6 [5120/60000 (9%)]\tLoss: 1.093198\n",
            "Train Epoch: 6 [6400/60000 (11%)]\tLoss: 1.477637\n",
            "Train Epoch: 6 [7680/60000 (13%)]\tLoss: 1.247256\n",
            "Train Epoch: 6 [8960/60000 (15%)]\tLoss: 1.578910\n",
            "Train Epoch: 6 [10240/60000 (17%)]\tLoss: 1.373938\n",
            "Train Epoch: 6 [11520/60000 (19%)]\tLoss: 1.462816\n",
            "Train Epoch: 6 [12800/60000 (21%)]\tLoss: 1.307816\n",
            "Train Epoch: 6 [14080/60000 (23%)]\tLoss: 1.152530\n",
            "Train Epoch: 6 [15360/60000 (26%)]\tLoss: 1.590767\n",
            "Train Epoch: 6 [16640/60000 (28%)]\tLoss: 1.018799\n",
            "Train Epoch: 6 [17920/60000 (30%)]\tLoss: 1.224047\n",
            "Train Epoch: 6 [19200/60000 (32%)]\tLoss: 1.118548\n",
            "Train Epoch: 6 [20480/60000 (34%)]\tLoss: 1.426815\n",
            "Train Epoch: 6 [21760/60000 (36%)]\tLoss: 1.159803\n",
            "Train Epoch: 6 [23040/60000 (38%)]\tLoss: 1.333177\n",
            "Train Epoch: 6 [24320/60000 (41%)]\tLoss: 1.312057\n",
            "Train Epoch: 6 [25600/60000 (43%)]\tLoss: 1.161975\n",
            "Train Epoch: 6 [26880/60000 (45%)]\tLoss: 1.756063\n",
            "Train Epoch: 6 [28160/60000 (47%)]\tLoss: 1.511718\n",
            "Train Epoch: 6 [29440/60000 (49%)]\tLoss: 1.058304\n",
            "Train Epoch: 6 [30720/60000 (51%)]\tLoss: 1.168355\n",
            "Train Epoch: 6 [32000/60000 (53%)]\tLoss: 1.423478\n",
            "Train Epoch: 6 [33280/60000 (55%)]\tLoss: 1.339292\n",
            "Train Epoch: 6 [34560/60000 (58%)]\tLoss: 1.268257\n",
            "Train Epoch: 6 [35840/60000 (60%)]\tLoss: 1.063282\n",
            "Train Epoch: 6 [37120/60000 (62%)]\tLoss: 1.586250\n",
            "Train Epoch: 6 [38400/60000 (64%)]\tLoss: 1.502603\n",
            "Train Epoch: 6 [39680/60000 (66%)]\tLoss: 1.034673\n",
            "Train Epoch: 6 [40960/60000 (68%)]\tLoss: 1.333380\n",
            "Train Epoch: 6 [42240/60000 (70%)]\tLoss: 1.559941\n",
            "Train Epoch: 6 [43520/60000 (72%)]\tLoss: 1.190854\n",
            "Train Epoch: 6 [44800/60000 (75%)]\tLoss: 1.621720\n",
            "Train Epoch: 6 [46080/60000 (77%)]\tLoss: 1.783634\n",
            "Train Epoch: 6 [47360/60000 (79%)]\tLoss: 1.483619\n",
            "Train Epoch: 6 [48640/60000 (81%)]\tLoss: 1.187370\n",
            "Train Epoch: 6 [49920/60000 (83%)]\tLoss: 1.238347\n",
            "Train Epoch: 6 [51200/60000 (85%)]\tLoss: 1.202996\n",
            "Train Epoch: 6 [52480/60000 (87%)]\tLoss: 1.741593\n",
            "Train Epoch: 6 [53760/60000 (90%)]\tLoss: 1.290843\n",
            "Train Epoch: 6 [55040/60000 (92%)]\tLoss: 1.027839\n",
            "Train Epoch: 6 [56320/60000 (94%)]\tLoss: 1.086961\n",
            "Train Epoch: 6 [57600/60000 (96%)]\tLoss: 1.067491\n",
            "Train Epoch: 6 [58880/60000 (98%)]\tLoss: 1.362714\n",
            "\n",
            "Test set: Average loss: 0.0100, Accuracy: 7090/10000 (71%)\n",
            "\n",
            "Train Epoch: 7 [0/60000 (0%)]\tLoss: 1.468595\n",
            "Train Epoch: 7 [1280/60000 (2%)]\tLoss: 1.491531\n",
            "Train Epoch: 7 [2560/60000 (4%)]\tLoss: 1.261406\n",
            "Train Epoch: 7 [3840/60000 (6%)]\tLoss: 1.261123\n",
            "Train Epoch: 7 [5120/60000 (9%)]\tLoss: 1.072197\n",
            "Train Epoch: 7 [6400/60000 (11%)]\tLoss: 1.274797\n",
            "Train Epoch: 7 [7680/60000 (13%)]\tLoss: 0.991163\n",
            "Train Epoch: 7 [8960/60000 (15%)]\tLoss: 0.799249\n",
            "Train Epoch: 7 [10240/60000 (17%)]\tLoss: 1.477209\n",
            "Train Epoch: 7 [11520/60000 (19%)]\tLoss: 1.334782\n",
            "Train Epoch: 7 [12800/60000 (21%)]\tLoss: 1.456584\n",
            "Train Epoch: 7 [14080/60000 (23%)]\tLoss: 1.374974\n",
            "Train Epoch: 7 [15360/60000 (26%)]\tLoss: 0.936979\n",
            "Train Epoch: 7 [16640/60000 (28%)]\tLoss: 1.439293\n",
            "Train Epoch: 7 [17920/60000 (30%)]\tLoss: 1.224345\n",
            "Train Epoch: 7 [19200/60000 (32%)]\tLoss: 1.403960\n",
            "Train Epoch: 7 [20480/60000 (34%)]\tLoss: 2.131383\n",
            "Train Epoch: 7 [21760/60000 (36%)]\tLoss: 1.598603\n",
            "Train Epoch: 7 [23040/60000 (38%)]\tLoss: 0.944051\n",
            "Train Epoch: 7 [24320/60000 (41%)]\tLoss: 1.817578\n",
            "Train Epoch: 7 [25600/60000 (43%)]\tLoss: 1.678040\n",
            "Train Epoch: 7 [26880/60000 (45%)]\tLoss: 1.331541\n",
            "Train Epoch: 7 [28160/60000 (47%)]\tLoss: 1.234244\n",
            "Train Epoch: 7 [29440/60000 (49%)]\tLoss: 1.644067\n",
            "Train Epoch: 7 [30720/60000 (51%)]\tLoss: 2.083558\n",
            "Train Epoch: 7 [32000/60000 (53%)]\tLoss: 1.546425\n",
            "Train Epoch: 7 [33280/60000 (55%)]\tLoss: 1.241479\n",
            "Train Epoch: 7 [34560/60000 (58%)]\tLoss: 1.096076\n",
            "Train Epoch: 7 [35840/60000 (60%)]\tLoss: 1.382987\n",
            "Train Epoch: 7 [37120/60000 (62%)]\tLoss: 1.393018\n",
            "Train Epoch: 7 [38400/60000 (64%)]\tLoss: 1.142664\n",
            "Train Epoch: 7 [39680/60000 (66%)]\tLoss: 0.898223\n",
            "Train Epoch: 7 [40960/60000 (68%)]\tLoss: 1.624141\n",
            "Train Epoch: 7 [42240/60000 (70%)]\tLoss: 1.588085\n",
            "Train Epoch: 7 [43520/60000 (72%)]\tLoss: 1.416786\n",
            "Train Epoch: 7 [44800/60000 (75%)]\tLoss: 1.663569\n",
            "Train Epoch: 7 [46080/60000 (77%)]\tLoss: 1.323364\n",
            "Train Epoch: 7 [47360/60000 (79%)]\tLoss: 1.154913\n",
            "Train Epoch: 7 [48640/60000 (81%)]\tLoss: 1.189740\n",
            "Train Epoch: 7 [49920/60000 (83%)]\tLoss: 1.973460\n",
            "Train Epoch: 7 [51200/60000 (85%)]\tLoss: 1.192529\n",
            "Train Epoch: 7 [52480/60000 (87%)]\tLoss: 1.064409\n",
            "Train Epoch: 7 [53760/60000 (90%)]\tLoss: 1.278478\n",
            "Train Epoch: 7 [55040/60000 (92%)]\tLoss: 1.286827\n",
            "Train Epoch: 7 [56320/60000 (94%)]\tLoss: 1.512832\n",
            "Train Epoch: 7 [57600/60000 (96%)]\tLoss: 1.381645\n",
            "Train Epoch: 7 [58880/60000 (98%)]\tLoss: 1.235525\n",
            "\n",
            "Test set: Average loss: 0.0107, Accuracy: 6993/10000 (70%)\n",
            "\n",
            "Train Epoch: 8 [0/60000 (0%)]\tLoss: 1.185282\n",
            "Train Epoch: 8 [1280/60000 (2%)]\tLoss: 1.590641\n",
            "Train Epoch: 8 [2560/60000 (4%)]\tLoss: 0.938613\n",
            "Train Epoch: 8 [3840/60000 (6%)]\tLoss: 1.076460\n",
            "Train Epoch: 8 [5120/60000 (9%)]\tLoss: 1.472175\n",
            "Train Epoch: 8 [6400/60000 (11%)]\tLoss: 1.257120\n",
            "Train Epoch: 8 [7680/60000 (13%)]\tLoss: 1.268546\n",
            "Train Epoch: 8 [8960/60000 (15%)]\tLoss: 1.320007\n",
            "Train Epoch: 8 [10240/60000 (17%)]\tLoss: 0.960885\n",
            "Train Epoch: 8 [11520/60000 (19%)]\tLoss: 1.290364\n",
            "Train Epoch: 8 [12800/60000 (21%)]\tLoss: 1.152956\n",
            "Train Epoch: 8 [14080/60000 (23%)]\tLoss: 0.777541\n",
            "Train Epoch: 8 [15360/60000 (26%)]\tLoss: 1.130985\n",
            "Train Epoch: 8 [16640/60000 (28%)]\tLoss: 1.659289\n",
            "Train Epoch: 8 [17920/60000 (30%)]\tLoss: 1.063492\n",
            "Train Epoch: 8 [19200/60000 (32%)]\tLoss: 1.219170\n",
            "Train Epoch: 8 [20480/60000 (34%)]\tLoss: 1.297705\n",
            "Train Epoch: 8 [21760/60000 (36%)]\tLoss: 1.702775\n",
            "Train Epoch: 8 [23040/60000 (38%)]\tLoss: 1.086481\n",
            "Train Epoch: 8 [24320/60000 (41%)]\tLoss: 1.691632\n",
            "Train Epoch: 8 [25600/60000 (43%)]\tLoss: 1.311862\n",
            "Train Epoch: 8 [26880/60000 (45%)]\tLoss: 0.951916\n",
            "Train Epoch: 8 [28160/60000 (47%)]\tLoss: 1.613132\n",
            "Train Epoch: 8 [29440/60000 (49%)]\tLoss: 1.400392\n",
            "Train Epoch: 8 [30720/60000 (51%)]\tLoss: 1.810183\n",
            "Train Epoch: 8 [32000/60000 (53%)]\tLoss: 1.227270\n",
            "Train Epoch: 8 [33280/60000 (55%)]\tLoss: 1.257650\n",
            "Train Epoch: 8 [34560/60000 (58%)]\tLoss: 1.254947\n",
            "Train Epoch: 8 [35840/60000 (60%)]\tLoss: 1.051835\n",
            "Train Epoch: 8 [37120/60000 (62%)]\tLoss: 0.990938\n",
            "Train Epoch: 8 [38400/60000 (64%)]\tLoss: 1.353770\n",
            "Train Epoch: 8 [39680/60000 (66%)]\tLoss: 1.037356\n",
            "Train Epoch: 8 [40960/60000 (68%)]\tLoss: 1.441147\n",
            "Train Epoch: 8 [42240/60000 (70%)]\tLoss: 1.241880\n",
            "Train Epoch: 8 [43520/60000 (72%)]\tLoss: 1.258257\n",
            "Train Epoch: 8 [44800/60000 (75%)]\tLoss: 1.664464\n",
            "Train Epoch: 8 [46080/60000 (77%)]\tLoss: 0.997966\n",
            "Train Epoch: 8 [47360/60000 (79%)]\tLoss: 1.665396\n",
            "Train Epoch: 8 [48640/60000 (81%)]\tLoss: 1.334370\n",
            "Train Epoch: 8 [49920/60000 (83%)]\tLoss: 1.628985\n",
            "Train Epoch: 8 [51200/60000 (85%)]\tLoss: 1.063624\n",
            "Train Epoch: 8 [52480/60000 (87%)]\tLoss: 1.483424\n",
            "Train Epoch: 8 [53760/60000 (90%)]\tLoss: 0.905630\n",
            "Train Epoch: 8 [55040/60000 (92%)]\tLoss: 1.478751\n",
            "Train Epoch: 8 [56320/60000 (94%)]\tLoss: 1.809835\n",
            "Train Epoch: 8 [57600/60000 (96%)]\tLoss: 1.270919\n",
            "Train Epoch: 8 [58880/60000 (98%)]\tLoss: 1.361971\n",
            "\n",
            "Test set: Average loss: 0.0094, Accuracy: 7404/10000 (74%)\n",
            "\n",
            "Train Epoch: 9 [0/60000 (0%)]\tLoss: 1.113855\n",
            "Train Epoch: 9 [1280/60000 (2%)]\tLoss: 1.235737\n",
            "Train Epoch: 9 [2560/60000 (4%)]\tLoss: 1.279987\n",
            "Train Epoch: 9 [3840/60000 (6%)]\tLoss: 1.065409\n",
            "Train Epoch: 9 [5120/60000 (9%)]\tLoss: 1.336910\n",
            "Train Epoch: 9 [6400/60000 (11%)]\tLoss: 1.102224\n",
            "Train Epoch: 9 [7680/60000 (13%)]\tLoss: 1.273790\n",
            "Train Epoch: 9 [8960/60000 (15%)]\tLoss: 1.402990\n",
            "Train Epoch: 9 [10240/60000 (17%)]\tLoss: 1.590468\n",
            "Train Epoch: 9 [11520/60000 (19%)]\tLoss: 0.791166\n",
            "Train Epoch: 9 [12800/60000 (21%)]\tLoss: 1.209027\n",
            "Train Epoch: 9 [14080/60000 (23%)]\tLoss: 1.741607\n",
            "Train Epoch: 9 [15360/60000 (26%)]\tLoss: 1.285213\n",
            "Train Epoch: 9 [16640/60000 (28%)]\tLoss: 1.120611\n",
            "Train Epoch: 9 [17920/60000 (30%)]\tLoss: 1.491740\n",
            "Train Epoch: 9 [19200/60000 (32%)]\tLoss: 1.512396\n",
            "Train Epoch: 9 [20480/60000 (34%)]\tLoss: 1.228300\n",
            "Train Epoch: 9 [21760/60000 (36%)]\tLoss: 1.153051\n",
            "Train Epoch: 9 [23040/60000 (38%)]\tLoss: 1.005075\n",
            "Train Epoch: 9 [24320/60000 (41%)]\tLoss: 1.702809\n",
            "Train Epoch: 9 [25600/60000 (43%)]\tLoss: 1.262131\n",
            "Train Epoch: 9 [26880/60000 (45%)]\tLoss: 1.200922\n",
            "Train Epoch: 9 [28160/60000 (47%)]\tLoss: 0.897869\n",
            "Train Epoch: 9 [29440/60000 (49%)]\tLoss: 1.251375\n",
            "Train Epoch: 9 [30720/60000 (51%)]\tLoss: 0.971991\n",
            "Train Epoch: 9 [32000/60000 (53%)]\tLoss: 1.336685\n",
            "Train Epoch: 9 [33280/60000 (55%)]\tLoss: 1.538005\n",
            "Train Epoch: 9 [34560/60000 (58%)]\tLoss: 1.488236\n",
            "Train Epoch: 9 [35840/60000 (60%)]\tLoss: 1.690226\n",
            "Train Epoch: 9 [37120/60000 (62%)]\tLoss: 1.300596\n",
            "Train Epoch: 9 [38400/60000 (64%)]\tLoss: 1.370632\n",
            "Train Epoch: 9 [39680/60000 (66%)]\tLoss: 1.212277\n",
            "Train Epoch: 9 [40960/60000 (68%)]\tLoss: 1.459350\n",
            "Train Epoch: 9 [42240/60000 (70%)]\tLoss: 1.301782\n",
            "Train Epoch: 9 [43520/60000 (72%)]\tLoss: 1.184032\n",
            "Train Epoch: 9 [44800/60000 (75%)]\tLoss: 1.220577\n",
            "Train Epoch: 9 [46080/60000 (77%)]\tLoss: 0.776487\n",
            "Train Epoch: 9 [47360/60000 (79%)]\tLoss: 1.130695\n",
            "Train Epoch: 9 [48640/60000 (81%)]\tLoss: 1.428787\n",
            "Train Epoch: 9 [49920/60000 (83%)]\tLoss: 1.488642\n",
            "Train Epoch: 9 [51200/60000 (85%)]\tLoss: 1.087557\n",
            "Train Epoch: 9 [52480/60000 (87%)]\tLoss: 1.565817\n",
            "Train Epoch: 9 [53760/60000 (90%)]\tLoss: 1.399408\n",
            "Train Epoch: 9 [55040/60000 (92%)]\tLoss: 1.180311\n",
            "Train Epoch: 9 [56320/60000 (94%)]\tLoss: 1.156334\n",
            "Train Epoch: 9 [57600/60000 (96%)]\tLoss: 1.048059\n",
            "Train Epoch: 9 [58880/60000 (98%)]\tLoss: 0.915956\n",
            "\n",
            "Test set: Average loss: 0.0096, Accuracy: 7118/10000 (71%)\n",
            "\n",
            "Train Epoch: 10 [0/60000 (0%)]\tLoss: 1.463092\n",
            "Train Epoch: 10 [1280/60000 (2%)]\tLoss: 1.605721\n",
            "Train Epoch: 10 [2560/60000 (4%)]\tLoss: 1.151576\n",
            "Train Epoch: 10 [3840/60000 (6%)]\tLoss: 1.079263\n",
            "Train Epoch: 10 [5120/60000 (9%)]\tLoss: 1.101671\n",
            "Train Epoch: 10 [6400/60000 (11%)]\tLoss: 1.511920\n",
            "Train Epoch: 10 [7680/60000 (13%)]\tLoss: 1.527798\n",
            "Train Epoch: 10 [8960/60000 (15%)]\tLoss: 1.064247\n",
            "Train Epoch: 10 [10240/60000 (17%)]\tLoss: 1.106312\n",
            "Train Epoch: 10 [11520/60000 (19%)]\tLoss: 1.610519\n",
            "Train Epoch: 10 [12800/60000 (21%)]\tLoss: 1.445660\n",
            "Train Epoch: 10 [14080/60000 (23%)]\tLoss: 1.666983\n",
            "Train Epoch: 10 [15360/60000 (26%)]\tLoss: 1.280714\n",
            "Train Epoch: 10 [16640/60000 (28%)]\tLoss: 1.407933\n",
            "Train Epoch: 10 [17920/60000 (30%)]\tLoss: 1.001499\n",
            "Train Epoch: 10 [19200/60000 (32%)]\tLoss: 1.444748\n",
            "Train Epoch: 10 [20480/60000 (34%)]\tLoss: 1.676354\n",
            "Train Epoch: 10 [21760/60000 (36%)]\tLoss: 1.255905\n",
            "Train Epoch: 10 [23040/60000 (38%)]\tLoss: 1.208303\n",
            "Train Epoch: 10 [24320/60000 (41%)]\tLoss: 1.207552\n",
            "Train Epoch: 10 [25600/60000 (43%)]\tLoss: 1.233439\n",
            "Train Epoch: 10 [26880/60000 (45%)]\tLoss: 1.051011\n",
            "Train Epoch: 10 [28160/60000 (47%)]\tLoss: 1.965932\n",
            "Train Epoch: 10 [29440/60000 (49%)]\tLoss: 1.491511\n",
            "Train Epoch: 10 [30720/60000 (51%)]\tLoss: 1.619134\n",
            "Train Epoch: 10 [32000/60000 (53%)]\tLoss: 1.649810\n",
            "Train Epoch: 10 [33280/60000 (55%)]\tLoss: 1.281682\n",
            "Train Epoch: 10 [34560/60000 (58%)]\tLoss: 1.507607\n",
            "Train Epoch: 10 [35840/60000 (60%)]\tLoss: 1.157230\n",
            "Train Epoch: 10 [37120/60000 (62%)]\tLoss: 1.773596\n",
            "Train Epoch: 10 [38400/60000 (64%)]\tLoss: 1.198063\n",
            "Train Epoch: 10 [39680/60000 (66%)]\tLoss: 1.290834\n",
            "Train Epoch: 10 [40960/60000 (68%)]\tLoss: 0.915801\n",
            "Train Epoch: 10 [42240/60000 (70%)]\tLoss: 1.123036\n",
            "Train Epoch: 10 [43520/60000 (72%)]\tLoss: 1.247630\n",
            "Train Epoch: 10 [44800/60000 (75%)]\tLoss: 0.909294\n",
            "Train Epoch: 10 [46080/60000 (77%)]\tLoss: 1.378886\n",
            "Train Epoch: 10 [47360/60000 (79%)]\tLoss: 1.159312\n",
            "Train Epoch: 10 [48640/60000 (81%)]\tLoss: 1.389619\n",
            "Train Epoch: 10 [49920/60000 (83%)]\tLoss: 1.312339\n",
            "Train Epoch: 10 [51200/60000 (85%)]\tLoss: 1.037200\n",
            "Train Epoch: 10 [52480/60000 (87%)]\tLoss: 1.115950\n",
            "Train Epoch: 10 [53760/60000 (90%)]\tLoss: 1.412792\n",
            "Train Epoch: 10 [55040/60000 (92%)]\tLoss: 1.699280\n",
            "Train Epoch: 10 [56320/60000 (94%)]\tLoss: 1.238345\n",
            "Train Epoch: 10 [57600/60000 (96%)]\tLoss: 1.545300\n",
            "Train Epoch: 10 [58880/60000 (98%)]\tLoss: 1.184268\n",
            "\n",
            "Test set: Average loss: 0.0099, Accuracy: 7055/10000 (71%)\n",
            "\n"
          ]
        }
      ],
      "source": [
        "criterion = nn.CrossEntropyLoss()\n",
        "optimizer = optim.Adam(model.parameters(), lr=0.00001)\n",
        "\n",
        "\n",
        "max_acc = 0.0\n",
        "\n",
        "for epoch in range(1, 11):\n",
        "    train(epoch)\n",
        "    acc = test()\n",
        "\n",
        "    if acc > max_acc:\n",
        "        max_acc = acc\n",
        "        torch.save(model.state_dict(), 'mnist-100-bnn_1blk_20.pt', _use_new_zipfile_serialization=False)"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Loading the saved model for the Testing."
      ],
      "metadata": {
        "id": "nVV8QdQQPqBc"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "A72QrgYcvwU5",
        "outputId": "cce6b0de-2b37-40d0-c994-5adb8301b87d"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "Test set: Average loss: 0.0094, Accuracy: 7404/10000 (74%)\n",
            "\n",
            "Accuracy: tensor(74.0400)\n"
          ]
        }
      ],
      "source": [
        "# Load the model\n",
        "saved_model = BNN_1blk_20(100,10)\n",
        "saved_model.load_state_dict(torch.load('Downloads/mnist-100-bnn_1blk_20.pt'))\n",
        "saved_model.to(device)\n",
        "\n",
        "criterion = nn.CrossEntropyLoss()\n",
        "\n",
        "def saved_test():\n",
        "    saved_model.eval()\n",
        "    test_loss = 0\n",
        "    correct = 0\n",
        "    with torch.no_grad():\n",
        "        for data, target in test_loader:\n",
        "            data, target = data.to(device), target.to(device)\n",
        "            output = saved_model(data)\n",
        "            test_loss += criterion(output, target).item()\n",
        "            pred = output.data.max(1, keepdim=True)[1]\n",
        "            correct += pred.eq(target.data.view_as(pred)).cpu().sum()\n",
        "\n",
        "    test_loss /= len(test_loader.dataset)\n",
        "    accuracy = 100. * correct / len(test_loader.dataset)\n",
        "    print('\\nTest set: Average loss: {:.4f}, Accuracy: {}/{} ({:.0f}%)\\n'.format(\n",
        "        test_loss, correct, len(test_loader.dataset),\n",
        "        100. * correct / len(test_loader.dataset)))\n",
        "    return accuracy\n",
        "\n",
        "accuracy = saved_test()\n",
        "\n",
        "print(\"Accuracy:\", accuracy)"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "The layers in the model are the weights therein are as follows"
      ],
      "metadata": {
        "id": "m4ZrX1bjP0Oc"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "print(saved_model)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "xAV1vbx8dFV_",
        "outputId": "e874c28a-a255-43ca-d65a-33978e265a15"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "BNN_1blk_20(\n",
            "  (fc1): BinarizeLinear(in_features=100, out_features=20, bias=True)\n",
            "  (htanh1): Hardtanh(min_val=-1.0, max_val=1.0)\n",
            "  (bn1): BatchNorm1d(20, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
            "  (fc5): BinarizeLinear(in_features=20, out_features=10, bias=True)\n",
            "  (logsoftmax): LogSoftmax(dim=None)\n",
            ")\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "for name, param in saved_model.named_parameters():\n",
        "    if param.requires_grad:\n",
        "        print(name, param.data)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "LSj4iGMjdSz6",
        "outputId": "8e98727c-495c-4abe-e7ad-204097ece32c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "fc1.weight tensor([[ 1.,  1.,  1.,  ...,  1.,  1., -1.],\n",
            "        [ 1.,  1., -1.,  ..., -1.,  1., -1.],\n",
            "        [ 1., -1., -1.,  ..., -1.,  1.,  1.],\n",
            "        ...,\n",
            "        [-1.,  1., -1.,  ...,  1., -1., -1.],\n",
            "        [ 1.,  1.,  1.,  ...,  1.,  1.,  1.],\n",
            "        [-1.,  1.,  1.,  ...,  1., -1., -1.]], device='cuda:0')\n",
            "fc1.bias tensor([-0.0299,  0.0900,  0.0887,  0.0884, -0.0492, -0.0128, -0.0329, -0.0784,\n",
            "         0.0786,  0.0753, -0.0080,  0.0761, -0.0558,  0.0801,  0.0858,  0.0917,\n",
            "        -0.0918, -0.0190, -0.0139,  0.0168], device='cuda:0')\n",
            "bn1.weight tensor([0.9282, 0.7590, 0.8276, 0.7607, 0.8061, 0.8836, 0.8078, 0.7824, 0.8439,\n",
            "        0.8248, 0.7746, 0.7700, 0.8240, 0.8366, 0.7722, 0.7947, 0.8682, 0.7893,\n",
            "        0.8686, 0.7776], device='cuda:0')\n",
            "bn1.bias tensor([-0.0050, -0.0501, -0.0254,  0.0647,  0.0260, -0.0596, -0.0893,  0.0573,\n",
            "         0.1466,  0.0191, -0.1199, -0.0625, -0.0635, -0.1298, -0.0509, -0.0059,\n",
            "         0.1297, -0.0422,  0.0920,  0.0201], device='cuda:0')\n",
            "fc5.weight tensor([[-1., -1.,  1.,  1., -1.,  1., -1.,  1., -1.,  1.,  1., -1., -1.,  1.,\n",
            "          1., -1.,  1., -1.,  1., -1.],\n",
            "        [-1.,  1., -1., -1.,  1., -1., -1., -1.,  1., -1.,  1.,  1.,  1., -1.,\n",
            "         -1., -1., -1.,  1.,  1.,  1.],\n",
            "        [-1., -1.,  1.,  1.,  1., -1., -1., -1.,  1., -1., -1., -1., -1.,  1.,\n",
            "         -1., -1., -1., -1., -1., -1.],\n",
            "        [-1.,  1.,  1.,  1., -1., -1., -1.,  1.,  1.,  1., -1., -1.,  1., -1.,\n",
            "          1., -1.,  1.,  1.,  1.,  1.],\n",
            "        [ 1., -1., -1.,  1.,  1.,  1., -1., -1., -1.,  1.,  1., -1.,  1., -1.,\n",
            "         -1.,  1.,  1., -1.,  1.,  1.],\n",
            "        [ 1., -1., -1., -1., -1., -1., -1.,  1.,  1.,  1., -1., -1., -1., -1.,\n",
            "         -1., -1.,  1., -1.,  1., -1.],\n",
            "        [-1., -1., -1., -1., -1., -1.,  1., -1., -1., -1.,  1., -1.,  1.,  1.,\n",
            "         -1.,  1.,  1., -1.,  1.,  1.],\n",
            "        [ 1.,  1.,  1., -1., -1.,  1., -1.,  1., -1., -1.,  1.,  1.,  1., -1.,\n",
            "         -1., -1.,  1.,  1.,  1.,  1.],\n",
            "        [-1.,  1.,  1.,  1.,  1., -1.,  1., -1.,  1., -1., -1., -1., -1., -1.,\n",
            "         -1.,  1.,  1., -1.,  1.,  1.],\n",
            "        [ 1., -1., -1.,  1., -1.,  1., -1.,  1., -1., -1.,  1.,  1., -1., -1.,\n",
            "         -1., -1.,  1.,  1.,  1.,  1.]], device='cuda:0')\n",
            "fc5.bias tensor([ 0.0616, -0.1074, -0.2278, -0.0086,  0.0043,  0.1150, -0.1975,  0.1160,\n",
            "         0.0098,  0.1666], device='cuda:0')\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "The two weight matrices fc1 & fc5 can be visualised as follows."
      ],
      "metadata": {
        "id": "Oe_pYTzHQFfs"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Extract the weight matrix from the self.fc1 layer\n",
        "weight_matrix = saved_model.fc1.weight.data.cpu().numpy()\n",
        "\n",
        "# Set the figure size to make the plot larger\n",
        "plt.figure(figsize=(20, 4))  # Adjust the values as needed\n",
        "\n",
        "# Plot the weight matrix\n",
        "plt.imshow(weight_matrix, cmap='coolwarm', aspect='auto')  # 'aspect' ensures proper scaling\n",
        "plt.title('Weight Matrix (20x100)')  # Corrected labels\n",
        "plt.xlabel('Input Units')  # Corrected label\n",
        "plt.ylabel('Output Units')  # Corrected label\n",
        "\n",
        "# Remove ticks from both axes\n",
        "plt.xticks([])\n",
        "plt.yticks([])\n",
        "\n",
        "plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 406
        },
        "id": "cr39bpnhnGdP",
        "outputId": "5b2a8c12-2b02-4807-d4d8-ea3500b9188b"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 2000x400 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABjUAAAFxCAYAAAA77Sr9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA1tklEQVR4nO3deZQV5Z0//s9laaCRbkEWdUQ2SUANLhgTkAQHF0JIIpq4LxhPJIrGmGhMmARZhJA44hIVEhwHjQYxMeroGDQGwQWJy7gmLqMGlCiOI0K3LCJ01/eP/OifTdPY3bfp6zP39TqHc+xa7vOpp56qW91vqyqXZVkWAAAAAAAAn3CtCl0AAAAAAABAQwg1AAAAAACAJAg1AAAAAACAJAg1AAAAAACAJAg1AAAAAACAJAg1AAAAAACAJAg1AAAAAACAJAg1AAAAAACAJAg1AAAAAACAJAg1AABgBzv99NOjd+/eTV53p512at6CPsFuuOGGyOVysXz58mb93C9/+ctx5plnNutnpuqEE06I4447rtBlAABAkwg1AAAoSr/97W8jl8vFHXfcUWfefvvtF7lcLhYtWlRn3p577hlDhw5tiRIbZf369TF58uRYvHhxg5ZfvHhx5HK5yOVycfPNN29zmUMOOSRyuVzsu+++Tapp1qxZccMNNzRp3ea0ZMmS+OMf/xg//OEPa6a99NJLcdFFF8X+++8fnTp1it122y1Gjx4dTz755DY/480334zjjjsudt555ygrK4ujjjoq/va3vzW5punTp8fXvva16NGjR+RyuZg8eXK9yzam7euvvz4GDhwY7du3j/79+8fVV19dZ5kf/vCH8fvf/z6effbZJtcPAACFItQAAKAoDRs2LCIiHnnkkVrTKysr4y9/+Uu0adMmlixZUmveihUrYsWKFTXrNtR1110XL7/8cn4Ff4z169fHlClTGhxqbNG+ffuYN29enenLly+PRx99NNq3b9/kmpoSapx66qmxYcOG6NWrV5Pb3dq//uu/xmGHHRZ77bVXzbR/+7d/i+uuuy4OOuigmDlzZnz/+9+Pl19+OT7/+c/Hn/70p1rrr127Nv75n/85HnzwwfiXf/mXmDJlSjz99NMxfPjwWLVqVZNq+slPfhJPPPFEHHDAAdtdrjFt/+pXv4pvfetbsc8++8TVV18dQ4YMifPOOy9+/vOf11rugAMOqNluAABITZtCFwAAAIWw++67R58+feqEGkuXLo0sy+LYY4+tM2/Lz40NNdq2bZtfsTvQl7/85bjrrrvi3Xffja5du9ZMnzdvXvTo0SP69+8fq1ev3uF1rFu3Ljp27BitW7eO1q1bN9vnvvPOO3HPPffEL3/5y1rTTzzxxJg8eXKtR3udccYZMXDgwJg8eXIcfvjhNdNnzZoVr7zySjz++OPx2c9+NiIiRo0aFfvuu2/MnDkzfvrTnza6rmXLlkXv3r3j3XffjW7dutW7XEPb3rBhQ/z4xz+O0aNHx2233RYREWeeeWZUV1fHJZdcEuPGjYvOnTvXfO5xxx0XkyZNilmzZhXV480AAEifOzUAAChaw4YNi6effjo2bNhQM23JkiWxzz77xKhRo+LPf/5zVFdX15qXy+XikEMOqZl28803x+DBg6NDhw7RpUuXOOGEE2LFihW12tnWOzVWrVoVp556apSVlcXOO+8cY8eOjWeffTZyudw272548803Y8yYMbHTTjtFt27d4sILL4yqqqqI+MddFVv+MD5lypSax0pt75FGWxx11FHRrl27+N3vfldr+rx58+K4447bZsAwd+7cGDFiRHTv3j3atWsXe++9d8yePbvWMr17946//vWv8eCDD9bUc+ihh0bE///ejAcffDDGjx8f3bt3jz322KPWvC3v1HjggQeiVatWcfHFF9epL5fL1Wl3a/fcc09s3ry5VkgRETF48OA6f8zfZZdd4gtf+EK8+OKLtabfdttt8dnPfrYmVIiIGDBgQBx22GHx29/+tmba2LFjo3379nXWHzlyZHTu3DneeuutWv3TEA1te9GiRbFq1aoYP358rfXPOeecWLduXdxzzz21ph9xxBGxbt26uP/++xtUBwAAfFIINQAAKFrDhg2LTZs2xWOPPVYzbcmSJTF06NAYOnRoVFRUxF/+8pda8wYMGBC77LJLRPzjvQinnXZa9O/fPy6//PI4//zzY+HChfHFL34x1qxZU2+71dXV8dWvfjVuueWWGDt2bEyfPj1WrlwZY8eO3ebyVVVVMXLkyNhll13isssui+HDh8fMmTNjzpw5ERHRrVu3mj/uH3300XHTTTfFTTfdFMccc8zH9kFpaWkcddRRccstt9RMe/bZZ+Ovf/1rnHTSSdtcZ/bs2dGrV6/4l3/5l5g5c2b07Nkzxo8fH9dee23NMldeeWXsscceMWDAgJp6fvzjH9f6nPHjx8cLL7wQF198cfzoRz/aZlsjRoyI8ePHx4wZM+Kpp56KiIiVK1fGd77znTj88MPjrLPO2u72Pfroo7HLLrs0+HFWb7/9dq07Vqqrq+O5556Lgw46qM6yBx98cLz22mvx/vvvR0TEVVddFd26dYuxY8fWBE6/+tWv4o9//GNcffXVsfvuuzeohqa0/fTTT0dE1Fl28ODB0apVq5r5W+y9997RoUOHOo9YAwCATzqhBgAARWvr92ps3rw5HnvssTjkkEOiX79+0aNHj5p577//fjz//PM167z++usxadKkmDZtWsyfPz/OPvvsuPjii2PRokXx97//PWbNmlVvu3feeWcsXbo0Zs6cGVdffXWcc845ce+999aEJVv74IMP4vjjj4/rr78+zjrrrLjtttvigAMOiOuvvz4iIjp27Bjf+MY3IiJi0KBBccopp8Qpp5wSgwYNalA/nHTSSfHII4/U3GHym9/8Jvr27Ruf//znt7n8gw8+GHPnzo3zzz8/zj333Ljvvvti5MiRcfnll9csM2bMmCgvL48ePXrU1HPEEUfU+pwuXbrEwoUL49xzz631Eu+tXXrppdG7d+847bTTYuPGjXHmmWfG5s2b4/rrr49cLrfdbXvppZcafFfEww8/HEuXLo3jjz++Ztp7770XGzdujN12263O8lumbbkDY+edd47rr78+nnjiifjZz34Wy5YtiwsvvDDGjBkTp5xySoNq+KjGtL1y5cpo3bp1dO/evdZyJSUlscsuu9S6SyQiok2bNtGzZ8944YUXGl0XAAAUklADAICiNXDgwNhll11qgotnn3021q1bF0OHDo2IiKFDh9b8n+xLly6NqqqqmlDj9ttvj+rq6jjuuOPi3Xffrfm36667Rv/+/WPRokX1tnvvvfdG27Zt48wzz6yZ1qpVqzjnnHPqXWfrOxK+8IUvxN/+9rembfhWjjzyyOjSpUvMnz8/siyL+fPnx4knnljv8h06dKj574qKinj33Xdj+PDh8be//S0qKioa3O6ZZ57ZoPdnlJaWxg033BAvvvhifPGLX4x77rknrrjiithzzz0/dt1Vq1bVepdEfd5555046aSTok+fPnHRRRfVTN/yaLJ27drVWWfLS9Q/+viyI488Mr797W/H1KlT45hjjon27dvHr371q49tf1sa0/aGDRuipKRkm5/Tvn37WjVu0blz53j33XebVBsAABSKF4UDAFC0crlcDB06NB566KGorq6OJUuWRPfu3WOvvfaKiH+EGtdcc01ERE24sSXUeOWVVyLLsujfv/82P3t7Lwd//fXXY7fddovS0tJa07e0u7X27dvXeZl0586dm+0F3m3bto1jjz025s2bFwcffHCsWLGi3kdPRfyjLyZNmhRLly6N9evX15pXUVER5eXlDWq3T58+Da7xkEMOibPPPjuuvfbaGDlyZJxxxhkNXjfLsu3OX7duXXzlK1+J999/Px555JFa79rYEuBs3LixznoffPBBrWW2uOyyy+I//uM/4plnnol58+bVuXuioRrTdocOHeLDDz/c5ud88MEHdWqM+Ee/fNydLgAA8Ekj1AAAoKgNGzYs7r777nj++edr3qexxdChQ+MHP/hBvPnmm/HII4/E7rvvHn379o2If7zvIJfLxYIFC7Z5t8HWL6HOR0PuZsjXSSedFL/85S9j8uTJsd9++8Xee++9zeVee+21OOyww2LAgAFx+eWXR8+ePaOkpCT+8Ic/xBVXXFHrxeofZ1t/aK/Pxo0bY/HixTU1rF+/vk4otC277LLLdsOfDz/8MI455ph47rnn4r777ot999231vwuXbpEu3btYuXKlXXW3TJt63dlPP300/HOO+9ERMTzzz+/3btetqcxbe+2225RVVUV77zzTq0Q5cMPP4xVq1Zt830eq1evrjeUAwCATyqPnwIAoKh99L0aS5YsiUMOOaRm3uDBg6Ndu3axePHimndtbNGvX7/Isiz69OkThx9+eJ1/9b2PIiKiV69esXLlyjp3Obz66qtN3o58/4/7YcOGxZ577hmLFy/e7l0ad999d2zcuDHuuuuu+Pa3vx1f/vKX4/DDD99mQNGcdwFMmjQpXnzxxbjsssti2bJl9b5YfGsDBgyIZcuWbXNedXV1nHbaabFw4cKYN29eDB8+vM4yrVq1is985jPx5JNP1pn32GOPRd++faNTp04109atWxff/OY3Y++9945x48bFpZdeGk888UQDt7Lpbe+///4REXWWffLJJ6O6urpm/habN2+OFStWxMCBA5tUGwAAFIpQAwCAonbQQQdF+/bt4ze/+U28+eabte7UaNeuXRx44IFx7bXXxrp162oCkIiIY445Jlq3bh1Tpkyp83ijLMti1apV9bY5cuTI2LRpU1x33XU106qrq+Paa69t8nZsuWthzZo1TVo/l8vFL37xi5g0aVKceuqp9S635a6Rj25zRUVFzJ07t86yHTt2bHI9H/XYY4/FZZddFueff35ccMEF8YMf/CCuueaaePDBBz923SFDhsTq1au3+f6R73znO3HrrbfGrFmz4phjjqn3M77xjW/EE088USswePnll+OBBx6IY489ttayP/zhD+ONN96IG2+8MS6//PLo3bt3jB07dpuPkGqIhrY9YsSI6NKlS8yePbvW+rNnz47S0tIYPXp0rekvvPBCfPDBB7XGOwAApMDjpwAAKGolJSXx2c9+Nh5++OFo165dDB48uNb8oUOHxsyZMyMiaoUa/fr1i2nTpsWECRNi+fLlMWbMmOjUqVMsW7Ys7rjjjhg3blxceOGF22xzzJgxcfDBB8cFF1wQr776agwYMCDuuuuueO+99yKiaXc4dOjQIfbee++49dZb41Of+lR06dIl9t133zqPU9qeo446Ko466qjtLnPkkUdGSUlJfPWrX41vf/vbsXbt2rjuuuuie/fudR6TNHjw4Jg9e3ZMmzYt9tprr+jevXuMGDGiUdv1wQcfxNixY6N///4xffr0iIiYMmVK3H333fHNb34znn/++ejYsWO9648ePTratGkTf/rTn2LcuHE106+88sqYNWtWDBkyJEpLS+Pmm2+utd7RRx9d87njx4+P6667LkaPHh0XXnhhtG3bNi6//PLo0aNHXHDBBTXrPPDAAzFr1qyYNGlSHHjggRERMXfu3Dj00ENj4sSJcemll9Yse9NNN8Xrr79ec7fOQw89FNOmTYuIiFNPPTV69erVqLY7dOgQl1xySZxzzjlx7LHHxsiRI+Phhx+Om2++OaZPnx5dunSptX33339/lJaWxhFHHNHAPQEAAJ8QGQAAFLkJEyZkEZENHTq0zrzbb789i4isU6dO2ebNm+vM//3vf58NGzYs69ixY9axY8dswIAB2TnnnJO9/PLLNcuMHTs269WrV631/vd//zc76aSTsk6dOmXl5eXZ6aefni1ZsiSLiGz+/Pm11u3YsWOddidNmpRtfTn/6KOPZoMHD85KSkqyiMgmTZpU7zYvWrQoi4jsd7/7Xb3LZFmWDR8+PNtnn31qTbvrrruyQYMGZe3bt8969+6d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uVwunnnmmQa3edVVV8UNN9xQ8/Ohhx4a559/foPXBwAAPnnaFLoAAACAHaG8vLzQJQAAAM3MnRoAAFDEDj300DjvvPPioosuii5dusSuu+4akydPrrVMLpeL2bNnx6hRo6JDhw7Rt2/fuO2222rmL168OHK5XKxZs6Zm2jPPPBO5XC6WL18eixcvjm9+85tRUVERuVwucrlcnTYaa8udH/fdd18MHDgwdtppp/jSl74UK1eurFnmo3elnH766fHggw/GVVddVVPD8uXLY/Xq1XHyySdHt27dokOHDtG/f/+YO3duXrUBAAA7jlADAACK3I033hgdO3aMxx57LC699NKYOnVq3H///bWWmThxYnz961+PZ599Nk4++eQ44YQT4sUXX2zQ5w8dOjSuvPLKKCsri5UrV8bKlSvjwgsvzLvu9evXx2WXXRY33XRTPPTQQ/HGG2/U+7lXXXVVDBkyJM4888yaGnr27BkTJ06MF154IRYsWBAvvvhizJ49O7p27Zp3bQAAwI7h8VMAAFDkBg0aFJMmTYqIiP79+8c111wTCxcujCOOOKJmmWOPPTa+9a1vRUTEJZdcEvfff39cffXVMWvWrI/9/JKSkigvL49cLhe77rprs9W9adOm+OUvfxn9+vWLiIhzzz03pk6dus1ly8vLo6SkJEpLS2vV8MYbb8QBBxwQBx10UERE9O7du9nqAwAAmp87NQAAoMgNGjSo1s+77bZbvPPOO7WmDRkypM7PDb1TY0cpLS2tCTQitl33xzn77LNj/vz5sf/++8dFF10Ujz76aHOXCQAANCOhBgAAFLm2bdvW+jmXy0V1dXWD12/V6h+/VmRZVjNt06ZNTaqlrKwsKioq6kzf8r6Oj778e1t1f7SGhhg1alS8/vrr8b3vfS/eeuutOOyww5rl0VgAAMCOIdQAAAA+1p///Oc6Pw8cODAiIrp16xYRUesl3c8880yt5UtKSqKqqupj2/n0pz8df//73+N//ud/ak1/6qmnon379rHnnns2pfzt1tCtW7cYO3Zs3HzzzXHllVfGnDlzmtwGAACwY3mnBgAA8LF+97vfxUEHHRTDhg2L3/zmN/H444/H9ddfHxERe+21V/Ts2TMmT54c06dPj//+7/+OmTNn1lq/d+/esXbt2li4cGHst99+UVpaGqWlpXXaGTlyZHz605+OE088MaZNmxa77rprPPXUU/GTn/wkvvvd70br1q2bvA29e/eOxx57LJYvXx477bRTdOnSJSZPnhyDBw+OffbZJzZu3Bj/+Z//WRPWAAAAnzzu1AAAAD7WlClTYv78+TFo0KD49a9/HbfcckvsvffeEfGPx0Ddcsst8dJLL8WgQYPi5z//eUybNq3W+kOHDo2zzjorjj/++OjWrVtceuml22ynTZs28cc//jH23HPPOPHEE2PfffeNSZMmxXe/+9245JJL8tqGCy+8MFq3bh177713dOvWLd54440oKSmJCRMmxKBBg+KLX/xitG7dOubPn59XOwAAwI6Tyxr70FkAAKCo5HK5uOOOO2LMmDGFLgUAAChy7tQAAAAAAACSINQAAAAAAACS4EXhAADAdnliLQAA8EnhTg0AAAAAACAJQg0AAAAAACAJQg0AAAAAACAJQg0AAAAAACAJQg0AAAAAACAJQg0AAAAAACAJQg0AAAAAACAJQg0AAAAAACAJ/w+jI5PWqXp0xQAAAABJRU5ErkJggg=="
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Extract the weight matrix from the self.fc1 layer\n",
        "weight_matrix = saved_model.fc5.weight.data.cpu().numpy()\n",
        "\n",
        "# Set the figure size to make the plot larger\n",
        "plt.figure(figsize=(20, 10))  # Adjust the values as needed\n",
        "\n",
        "# Plot the weight matrix\n",
        "plt.imshow(weight_matrix, cmap='coolwarm', aspect='auto')  # 'aspect' ensures proper scaling\n",
        "plt.title('Weight Matrix (10x20)')  # Corrected labels\n",
        "plt.xlabel('Input Units')  # Corrected label\n",
        "plt.ylabel('Output Units')  # Corrected label\n",
        "\n",
        "# Remove ticks from both axes\n",
        "plt.xticks([])\n",
        "plt.yticks([])\n",
        "\n",
        "plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 713
        },
        "id": "QqY2XcnSoDw0",
        "outputId": "91d113ae-fb86-42b8-f2e7-3ed63bf8dca1"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 2000x1000 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABjUAAAM/CAYAAACZIFDIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA9J0lEQVR4nO3de5hVBb34/8/mfp0R5KIekAHFEBU10BNI6cGUiEqk1NQU80lTpLI0iwq5hFkc8S6WHo+WhnQT0+NRKwQvSKjlrUSPGighHg8Kg4gizuzvH/6Yn8MAzh4Hho+8Xs/D87DXWnuvz6a19yDv1lqFYrFYDAAAAAAAgO1cs6YeAAAAAAAAoD5EDQAAAAAAIAVRAwAAAAAASEHUAAAAAAAAUhA1AAAAAACAFEQNAAAAAAAgBVEDAAAAAABIQdQAAAAAAABSEDUAAAAAAIAURA0AAGgip5xySlRUVDT4uR06dGjcgbZjN9xwQxQKhViyZEmjvu6nP/3pOO200xr1NbcnTz31VLRo0SL+9re/NfUoAADQKEQNAAB4j1//+tdRKBRi9uzZddbtv//+USgUYu7cuXXW7b777jFkyJBtMWJJ1q5dG5MmTYp58+bVa/t58+ZFoVCIQqEQN9100ya3OeSQQ6JQKMS+++7boJlmzJgRN9xwQ4Oe25jmz58ff/jDH+I73/lOreUXXHBBfO5zn4vu3btHoVCISZMmbfY1li1bFscee2zstNNOUVZWFkcddVT84x//aNA8Tz/9dJx33nlxwAEHRMeOHWPXXXeNkSNHxiOPPNLgfffv3z9GjhwZ559/foNmAgCA7Y2oAQAA7zF06NCIiHjggQdqLV+9enX87W9/ixYtWsT8+fNrrVu6dGksXbq05rn1de2118YzzzzzwQZ+H2vXro3JkyfXO2ps0KZNm5g5c2ad5UuWLIkHH3ww2rRp0+CZGhI1TjrppHjzzTejV69eDd7vxv793/89Dj/88Nhzzz1rLf/BD34QDz/8cBx44IFbfP6aNWvi3/7t3+Lee++N733vezF58uR49NFH49BDD41XX3215Hn+4z/+I6699toYNGhQTJ8+Pb71rW/FM888Ex/72MfiT3/6U4P3fcYZZ8Ts2bPj+eefL3kmAADY3rRo6gEAAGB7sttuu0Xv3r3rRI0FCxZEsViMY445ps66DY9LjRotW7b8YMNuRZ/+9KfjtttuixUrVkSXLl1qls+cOTO6d+8effv2jZUrV271Od54441o3759NG/ePJo3b95or/vKK6/EHXfcET/96U/rrFu8eHFUVFTEihUromvXrpt9jRkzZsSzzz4bDz30UBx00EERETFixIjYd999Y/r06fGjH/2opJmOP/74mDRpUq3Lip166qmx9957x6RJk+KTn/xkg/b9yU9+Mjp16hQ///nPY8qUKSXNBAAA2xtnagAAwEaGDh0ajz76aLz55ps1y+bPnx/77LNPjBgxIv785z9HdXV1rXWFQiEOOeSQmmU33XRTDBw4MNq2bRudO3eOL37xi7F06dJa+9nUPTVeffXVOOmkk6KsrCx22mmnGDNmTDz++ONRKBQ2eXbDsmXLYtSoUdGhQ4fo2rVrnHvuuVFVVRUR755VseEf5SdPnlxzWaktXU5pg6OOOipat24dv/nNb2otnzlzZhx77LGbDAzXX399DBs2LLp16xatW7eO/v37x9VXX11rm4qKivj73/8e9957b808hx12WET8//fNuPfee2Ps2LHRrVu36NGjR611G+6pcc8990SzZs3qXFZp5syZUSgU6ux3Y3fccUe88847tULBe2esj9/+9rdx0EEH1USFiIh+/frF4YcfHr/+9a9rlo0ZMybatGkTixYtqvX84cOHR6dOneKll16KiIiBAwfWuU/KzjvvHB//+MfrPLe++454N54ddthh8fvf/75e7wsAALZnogYAAGxk6NChsX79+li4cGHNsvnz58eQIUNiyJAhUVlZWevGy/Pnz49+/frFzjvvHBHv3pPh5JNPjr59+8bFF18cZ599dsyZMyc+8YlPxKpVqza73+rq6vjsZz8bN998c4wZMyYuuOCCWL58eYwZM2aT21dVVcXw4cNj5513josuuigOPfTQmD59elxzzTUREdG1a9eaf9w/+uij48Ybb4wbb7wxRo8e/b5/Bu3atYujjjoqbr755ppljz/+ePz973+PE044YZPPufrqq6NXr17xve99L6ZPnx49e/aMsWPHxlVXXVWzzaWXXho9evSIfv361czz/e9/v9brjB07Np566qk4//zz47vf/e4m9zVs2LAYO3ZsXHjhhfHXv/41IiKWL18eX/va1+KTn/xknHHGGVt8fw8++GDsvPPODb6cVXV1dTzxxBMxaNCgOusOPvjgeP755+P111+PiIjLLrssunbtGmPGjKkJTj/72c/iD3/4Q1xxxRWx2267bXFfL7/8cq2zZUrZ9wYDBw6Mv/3tb7F69eqS3ysAAGxPRA0AANjIxvfVeOedd2LhwoVxyCGHxB577BHdu3evWff666/Hk08+WfOcF154ISZOnBhTp06NWbNmxZlnnhnnn39+zJ07N/75z3/GjBkzNrvfW2+9NRYsWBDTp0+PK664Is4666y46667amLJxt5666047rjj4rrrroszzjgjfvvb38aBBx4Y1113XUREtG/fPr7whS9ERMSAAQPiS1/6UnzpS1+KAQMG1OvP4YQTTogHHnig5gyTX/7yl9GnT5/42Mc+tsnt77333rj++uvj7LPPjnHjxsXdd98dw4cPj4svvrhmm1GjRkV5eXl07969Zp4jjjii1ut07tw55syZE+PGjatzE+/3mjZtWlRUVMTJJ58c69ati9NOOy3eeeeduO6666JQKGzxvT399NP1PiNjU1577bVYt25d7LrrrnXWbVi24QyMnXbaKa677rp4+OGH48c//nEsXrw4zj333Bg1alR86Utf2uJ+7r///liwYEEcd9xxDdr3Bn369Inq6up4+umnS3ujAACwnRE1AABgI3vvvXfsvPPONeHi8ccfjzfeeCOGDBkSERFDhgypuVn4ggULoqqqqiZq3HLLLVFdXR3HHntsrFixoubXLrvsEn379o25c+dudr933XVXtGzZMk477bSaZc2aNYuzzjprs8/Z+IyEj3/84/GPf/yjYW98I0ceeWR07tw5Zs2aFcViMWbNmhXHH3/8Zrdv27Ztze8rKytjxYoVceihh8Y//vGPqKysrPd+TzvttHrdP6Ndu3Zxww03xKJFi+ITn/hE3HHHHXHJJZfE7rvv/r7PffXVV6NTp071nmljGy5N1rp16zrrNtxE/b2XLzvyyCPjq1/9akyZMiVGjx4dbdq0iZ/97Gdb3Mcrr7wSJ5xwQvTu3TvOO++8Bu87Imre64oVK973vQEAwPbMjcIBAGAjhUIhhgwZEvfdd19UV1fH/Pnzo1u3brHnnntGxLtR48orr4yIqIkbG6LGs88+G8ViMfr27bvJ197SzcFfeOGF2HXXXaNdu3a1lm/Y78batGlT50bWnTp1arQbeLds2TKOOeaYmDlzZhx88MGxdOnSzV56KuLdP4uJEyfGggULYu3atbXWVVZWRnl5eb3227t373rPeMghh8SZZ54ZV111VQwfPjxOPfXUej+3WCzWe9uNbQg469atq7PurbfeqrXNBhdddFH8/ve/j8ceeyxmzpwZ3bp12+zrv/HGG/GZz3wmXn/99XjggQdq3WujIfve8F7f7wwWAADY3okaAACwCUOHDo3bb789nnzyyZr7aWwwZMiQ+Pa3vx3Lli2LBx54IHbbbbfo06dPRLx7v4NCoRB33nnnJs822PhG0B9Efc5m+KBOOOGE+OlPfxqTJk2K/fffP/r377/J7Z5//vk4/PDDo1+/fnHxxRdHz549o1WrVvHf//3fcckll9S6sfr72fgf5Ldk3bp1MW/evJoZ1q5dWycKbcrOO+/8geJP586do3Xr1rF8+fI66zYs2/heGY8++mi88sorERHx5JNPbvasl7fffjtGjx4dTzzxRNx9992x7777fuB9b3iv7703BwAAZCRqAADAJrz3vhrz58+Ps88+u2bdwIEDo3Xr1jFv3rxYuHBhfPrTn65Zt8cee0SxWIzevXvHXnvtVdI+e/XqFXPnzq3zD/PPPfdcg9/HB/1/5g8dOjR23333mDdvXvzkJz/Z7Ha33357rFu3Lm677bZal3/a1OW2GvNsgYkTJ8aiRYvioosuiu985zvx3e9+Ny6//PL3fV6/fv3id7/7XYP326xZs9hvv/3ikUceqbNu4cKF0adPn+jYsWPNsjfeeCO+/OUvR//+/WPIkCExbdq0OProo+Oggw6q9dzq6uo4+eSTY86cOfHrX/86Dj300A+874iIxYsXR7NmzUo+JgEAYHvjnhoAALAJgwYNijZt2sQvf/nLWLZsWa0zNVq3bh0f/ehH46qrroo33nijJoBERIwePTqaN28ekydPrnN5o2KxGK+++upm9zl8+PBYv359XHvttTXLqqur46qrrmrw+9gQR1atWtWg5xcKhbj88stj4sSJcdJJJ212uw1njbz3PVdWVsb1119fZ9v27ds3eJ73WrhwYVx00UVx9tlnxznnnBPf/va348orr4x77733fZ87ePDgWLly5Qe6/8gXvvCFePjhh2vFhWeeeSbuueeeOOaYY2pt+53vfCdefPHF+PnPfx4XX3xxVFRUxJgxY+pcQuprX/ta/OpXv4oZM2bE6NGjG2XfERF/+ctfYp999qn3JcAAAGB75UwNAADYhFatWsVBBx0U999/f7Ru3ToGDhxYa/2QIUNi+vTpERG1osYee+wRU6dOjfHjx8eSJUti1KhR0bFjx1i8eHHMnj07Tj/99Dj33HM3uc9Ro0bFwQcfHOecc04899xz0a9fv7jtttvitddei4iGneHQtm3b6N+/f/zqV7+KvfbaKzp37hz77rtvnUsabclRRx0VRx111Ba3OfLII6NVq1bx2c9+Nr761a/GmjVr4tprr41u3brVuUzSwIED4+qrr46pU6fGnnvuGd26dYthw4aV9L7eeuutGDNmTPTt2zcuuOCCiIiYPHly3H777fHlL385nnzyyWjfvv1mnz9y5Mho0aJF/OlPf4rTTz+91robb7wxXnjhhZr7gtx3330xderUiIg46aSTolevXhERMXbs2Lj22mtj5MiRce6550bLli3j4osvju7du8c555xT83r33HNPzJgxIyZOnBgf/ehHIyLi+uuvj8MOOywmTJgQ06ZNi4iISy+9NGbMmBGDBw+Odu3axU033VRrrqOPPrrmPdV33xER69evj3vvvTfGjh1b0p8xAABsl4oAAMAmjR8/vhgRxSFDhtRZd8sttxQjotixY8fiO++8U2f97373u+LQoUOL7du3L7Zv377Yr1+/4llnnVV85plnarYZM2ZMsVevXrWe93//93/FE044odixY8dieXl58ZRTTinOnz+/GBHFWbNm1Xpu+/bt6+x34sSJxY3/mv/ggw8WBw4cWGzVqlUxIooTJ07c7HueO3duMSKKv/nNbza7TbFYLB566KHFffbZp9ay2267rThgwIBimzZtihUVFcWf/OQnxf/8z/8sRkRx8eLFNdu9/PLLxZEjRxY7duxYjIjioYceWiwWi8Xrr7++GBHFhx9+uM7+Nqzb8Drf/OY3i82bNy8uXLiw1naPPPJIsUWLFsUzzzxzi/MXi8Xi5z73ueLhhx++yfcWEZv8NXfu3FrbLl26tPiFL3yhWFZWVuzQoUPxM5/5TPHZZ5+tWb969epir169ih/96EeL69evr/Xcb37zm8VmzZoVFyxYUCwW3/3fdHP73fjPsD773uDOO+8sRsQm1wEAQDaFYnGjc+IBAIDtyq233hpHH310PPDAA3HIIYc09TgfGvfff38cdthh8fTTT0ffvn2bepytZtSoUVEoFGL27NlNPQoAAHxg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AAAAKYgaAAAAAABACqIGAAAAAACQgqgBAAAAAACkIGoAAAAAAAApiBoAAAAAAEAKogYAAAAAAJDCB44aq1evjltvvTUWLVrUGPMAAAAAAABsUslR49hjj40rr7wyIiLefPPNGDRoUBx77LExYMCA+N3vftfoAwIAAAAAAEQ0IGrcd9998fGPfzwiImbPnh3FYjFWrVoVl19+eUydOrXRBwQAAAAAAIhoQNSorKyMzp07R0TEXXfdFZ///OejXbt2MXLkyHj22WcbfUAAAAAAAICIBkSNnj17xoIFC+KNN96Iu+66K4488siIiFi5cmW0adOm0QcEAAAAAACIiGhR6hPOPvvsOPHEE6NDhw7Rq1evOOywwyLi3ctS7bfffo09HwAAAAAAQEQ0IGqMHTs2/vVf/zVefPHFOOKII6JZs3dP9ujTp09ccMEFjT4gAAAAAABARAMuPzVlypTYe++94+ijj44OHTrULB82bFj86U9/atThAAAAAAAANig5akyePDnWrFlTZ/natWtj8uTJjTIUAAAAAADAxkqOGsViMQqFQp3ljz/+eHTu3LlRhgIAAAAAANhYve+p0alTpygUClEoFGKvvfaqFTaqqqpizZo1ccYZZ2yVIQEAAAAAAOodNS699NIoFotx6qmnxuTJk6O8vLxmXatWraKioiIGDx68VYYEAAAAAACod9QYM2ZMRET07t07hgwZEi1bttxqQwEAAAAAAGysXlFj9erVUVZWFhERBx54YLz55pvx5ptvbnLbDdsBAAAAAAA0pnpFjU6dOsXy5cujW7dusdNOO23yRuEbbiBeVVXV6EMCAAAAAADUK2rcc8890blz54iImDt37lYdCAAAAAAAYFPqFTUOPfTQTf4eAAAAAABgW6n3jcLfa9WqVfHQQw/FK6+8EtXV1bXWnXzyyY0yGAAAAAAAwHuVHDVuv/32OPHEE2PNmjVRVlZW6/4ahUJB1AAAAAAAALaKZqU+4ZxzzolTTz011qxZE6tWrYqVK1fW/Hrttde2xowAAAAAAAClR41ly5bF17/+9WjXrt3WmAcAAAAAAGCTSo4aw4cPj0ceeWRrzAIAAAAAALBZJd9TY+TIkfHtb387nnrqqdhvv/2iZcuWtdZ/7nOfa7ThAAAAAAAANig5apx22mkRETFlypQ66wqFQlRVVX3wqQAAAAAAADZSctSo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AAAAAACAUrlROAAAAAAAkIKoAQAAAAAApCBqAAAAAAAAKYgaAAAAAABACqIGAADwoXTKKafEqFGjmnoMAACgEYkaAACwA2mqf+i/4YYbYqeddnrf7SZNmhQHHHBAneVLliyJQqEQjz32WL33edlll8UNN9xQ8/iwww6Ls88+u97PBwAAtj8tmnoAAACAraG8vLypRwAAABqZMzUAAGAHdthhh8XXv/71OO+886Jz586xyy67xKRJk2ptUygU4uqrr44RI0ZE27Zto0+fPvHb3/62Zv28efOiUCjEqlWrapY99thjUSgUYsmSJTFv3rz48pe/HJWVlVEoFKJQKNTZR6k2nPlx9913x9577x0dOnSIT33qU7F8+fKabd57Vsopp5wS9957b1x22WU1MyxZsiRWrlwZJ554YnTt2jXatm0bffv2jeuvv/4DzQYAAGw9ogYAAOzgfv7zn0f79u1j4cKFMW3atJgyZUr88Y9/rLXNhAkT4vOf/3w8/vjjceKJJ8YXv/jFWLRoUb1ef8iQIXHppZdGWVlZLF++PJYvXx7nnnvuB5577dq1cdFFF8WNN94Y9913X7z44oubfd3LLrssBg8eHKeddlrNDD179owJEybEU089FXfeeWcsWrQorr766ujSpcsHng0AANg6XH4KAAB2cAMGDIiJEydGRETfvn3jyiuvjDlz5sQRRxxRs80xxxwTX/nKVyIi4oc//GH88Y9/jCuuuCJmzJjxvq/fqlWrKC8vj0KhELvsskujzb1+/fr46U9/GnvssUdERIwbNy6mTJmyyW3Ly8ujVatW0a5du1ozvPjii3HggQfGoEGDIiKioqKi0eYDAAAanzM1AABgBzdgwIBaj3fdddd45ZVXai0bPHhwncf1PVNja2nXrl1N0IjY9Nzv58wzz4xZs2bFAQccEOedd148+OCDjT0mAADQiEQNAADYwbVs2bLW40KhENXV1fV+frNm7/5nRbFYrFm2fv36Bs1SVlYWlZWVdZZvuF/He2/+vam53ztDfYwYMSJeeOGF+OY3vxkvvfRSHH744Y1yaSwAAGDrEDUAAID39ec//7nO47333jsiIrp27RoRUesm3Y899lit7Vu1ahVVVVXvu5+PfOQj8c9//jP+93//t9byv/71r9GmTZvYfffdGzL+Fmfo2rVrjBkzJm666aa49NJL45prrmnwPgAAgK3LPTUAAID39Zvf/CYGDRoUQ4cOjV/+8pfx0EMPxXXXXRcREXvuuWf07NkzJk2aFBdccEH8z//8T0yfPr3W8ysqKmLNmjUxZ86c2H///aNdu3bRrl27OvsZPnx4fOQjH4njjz8+pk6dGrvsskv89a9/jR/84AfxjW98I5o3b97g91BRURELFy6MJUuWRIcOHaJz584xadKkGDhwYOyzzz6xbt26+K//+q+aWAMAAGx/nKkBAAC8r8mTJ8esWbNiwIAB8Ytf/CJuvvnm6N+/f0S8exmom2++OZ5++ukYMGBA/OQnP4mpU6fWev6QIUPijDPOiOOOOy66du0a06ZN2+R+WrRoEX/4wx9i9913j+OPPz723XffmDhxYnzjG9+IH/7whx/oPZx77rnRvHnz6N+/f3Tt2jVefPHFaNWqVYwfPz4GDBgQn/jEJ6J58+Yxa9asD7QfAABg6ykUS73oLAAAsEMpFAoxe/bsGDVqVFOPAgAA7OCcqQEAAAAAAKQgagAAAAAAACm4UTgAALBFrlgLAABsL5ypAQAAAAAApCBqAAAAAAAAKYgaAAAAAABACqIGAAAAAACQgqgBAAAAAACkIGoAAAAAAAApiBoAAAAAAEAKogYAAAAAAJDC/wNY2EQcvQQACAAAAABJRU5ErkJggg=="
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "The BNN defined above has a single block that includes fc1, bn1, tanh1.\n",
        "\n",
        "This is then followed by the output block with fc5 & softmax.\n",
        "\n",
        "The inputs to & the outputs from the block are binarised & can hence be encoded as CNF formulas.\n",
        "\n",
        "I have used an availabe tool, [NPAQ](https://www.google.com/url?sa=t&rct=j&q=&esrc=s&source=web&cd=&cad=rja&uact=8&ved=2ahUKEwjw9sPCgLqCAxUUrVYBHSBBCAMQFnoECAoQAQ&url=https%3A%2F%2Fgithub.com%2Fteobaluta%2FNPAQ&usg=AOvVaw2nCo_P_isYRPC5LD4feVF7&opi=89978449) to convert the above trained pytorch model of a BNN into its corresponding CNF formula.\n",
        "\n",
        "NPAQ has some specific environment/OS requiremnenst, hence was done locally.\n",
        "\n",
        "The trained pytorch model for above model definition is & The generated CNF formula for the same is included in the supplemenatry material.\n",
        "\n",
        "The CNF formulas generated for a small BNN above has\n",
        "\n",
        "p cnf 61405 115888\n",
        "\n",
        "variables & clauses, hence i went with a simpler network for demonstration.\n",
        "\n"
      ],
      "metadata": {
        "id": "kWmCNm2BXCQh"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "While the trained Pytorch model is aroung 75% accurate at classifying MNIST digits, it is of interest to know if the model is aware of what differnt digits in the MNIST dataset looklike.\n",
        "\n",
        "Network Inversion can provide us access to the input space of the model for a given output label. To perform inversion we append additional clauses to the above CNF formula that constraint the output to take a particular value.\n",
        "\n",
        "After doing so we look for Satisfying assignmnets for the CNF Formula and using the satisying assignmnets for the inputs we can now recnstruct the inputs that will have the same label as it was restricted to above.\n",
        "\n",
        "To get better idea of the input space the for a particular output label, we uniformly sample from the input space using [cmsgen](https://www.google.com/url?sa=t&rct=j&q=&esrc=s&source=web&cd=&cad=rja&uact=8&ved=2ahUKEwiRg__XlbuCAxXLp1YBHYUYDx0QFnoECBAQAQ&url=https%3A%2F%2Fgithub.com%2Fmeelgroup%2Fcmsgen&usg=AOvVaw3nh6pCiLPmCMo1RvioYQaa&opi=89978449), an almost uniform sampler that allows us to visualsie the entire input space.\n",
        "\n",
        "Using the satisfying assignments of CNF formula for different output labels constraints, we can reconstruct the ipnut images for each of the labels."
      ],
      "metadata": {
        "id": "c3lG0T2XvMv5"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "The reconstructed images for the differnet output labels are also part of the supplementary material and visualised below for labels from 0 to 9 respectively.\n"
      ],
      "metadata": {
        "id": "pOfCytCfxIGy"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "def visualize_images(image_folder):\n",
        "    # Get a list of image file names in the folder\n",
        "    image_files = [f for f in os.listdir(image_folder) if f.endswith('.png')]\n",
        "\n",
        "    # Take the first 5 images for visualization (adjust as needed)\n",
        "    selected_images = image_files[:5]\n",
        "\n",
        "    # Create a 1x5 subplot for visualization\n",
        "    fig, axes = plt.subplots(1, 5, figsize=(15, 3))\n",
        "\n",
        "    # Load and display the selected images in the subplot\n",
        "    for i, image_file in enumerate(selected_images):\n",
        "        image_path = os.path.join(image_folder, image_file)\n",
        "        image = cv2.imread(image_path)\n",
        "        axes[i].imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))\n",
        "        axes[i].set_title(f'Image {i+1}')\n",
        "        axes[i].axis('off')\n",
        "\n",
        "    # Adjust spacing between subplots for clarity\n",
        "    plt.tight_layout()\n",
        "\n",
        "    # Show the visualization\n",
        "    plt.show()"
      ],
      "metadata": {
        "id": "7SCb-zxeetUn"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images0'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "WITm1zo2glJc",
        "outputId": "0cc66828-6f4f-40da-e0f4-3e8a15786178"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "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61s7bRswYECcdtppR7xX9oABA+LZZ5+t/vnw4cOxfPnyuOWWW2L79u3R0dFR/bu3vOUt1d8/8cQTMWLEiCM+3qv/y2x7e3tERMyYMeN117tv3744+eSTj3HvgO4u64zq6OiIT33qU/Hoo4/Gz3/+83jHO95x1PsA5ZNxRp166qlx6qmnRkTEZZddFosWLYqJEydGe3u7H24J3UymGXXXXXfFli1b4i9/+cvr3h/oXjLNqNfSq1evuPbaa6sR/IILLjjm+9JYwnciJ510Upe2F0VR/f2iRYvihhtuiM9+9rNx4403ximnnBI9evSIz3/+8zVdmf3yfW666aYYPXr0a96mtbW1yx8X6L6yzqirr746fvrTn8batWtjwoQJXV4LUA5ZZ9QrXXbZZXH99dfHxo0bvacudDOZZtS8efNi2rRp0atXr/jHP/4REf//Q3d37twZL7zwggsJoJvJNKNez+mnnx4RL/0wTroP4ZuIiPjRj34U48ePj+9///udtu/duzcGDRpU/fOwYcPi0UcfjaIoOn2X7e9//3un+40YMSIiIvr37x8f+chHTuDKgWZQ1hk1b968uO2222LZsmVx+eWX1/xxgO6trDPq1V7+r7n79u07bh8TKL+yzaidO3fGunXrXvMHxZ133nlxzjnnxMMPP9zljwt0T2WbUa/n5bdnefWV7ZSb9/gmIl76Ltwrv+MWEXH33XfHrl27Om2bNGlS7Nq1K37yk59Utx06dCi+973vdbrd+eefHyNGjIglS5bEc889d8TjPf3008dx9UB2ZZxRN910UyxZsiTmz58fc+bM6cruAMmUbUbt3r37iPVERKxcuTIiIsaMGfPGOwSkUrYZtX79+iN+ffKTn4yIiNtvvz2+/e1vd2n/gO6tbDPqtf5+//79sWzZshg0aFCcf/75R90nysMV30RExOTJk2PhwoUxc+bMGDduXGzbti3Wrl0bZ5xxRqfbXXPNNbFixYq4/PLLY86cOfH2t7891q5dG3369ImIqH7XrUePHrFy5cpoa2uLs88+O2bOnBlDhgyJXbt2xebNm6N///5xzz33vOGa7rnnnti6dWtERLz44ovxyCOPxNe//vWIiJgyZUq8//3vP96HASipss2o9evXxxe/+MU488wz473vfW+sWbOm099PnDix+r66QH5lm1Fr1qyJ73znOzF16tQ444wz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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images1'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "iwucyOjZgn0w",
        "outputId": "c8d1929c-a661-4b74-a6f1-4d6f7265b45a"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "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m9/85g6XtbS0xGmnnXbcZ2W3tLTEs88+W/31sWPHYtWqVXHLLbfErl27or29vfp7b3rTm6o/f+KJJ2L06NHHfb2X/5fZtra2iIiYPXv2q6734MGDcfLJJ3fy6IDeLuuMam9vj0984hPx6KOPxk9/+tN429ve9rq3Acon44w69dRT49RTT42IiMsuuyyWLl0ara2t0dbW5ptbQi+TaUbdddddsX379vjTn/70qrcHepdMM+qV9OvXL6699tpqBL/gggs6fVvqS/hO5KSTTurS5UVRVH++dOnSuOGGG+LTn/503HjjjXHKKadEnz594rOf/Wy33pn90m1uuummGDdu3Ctep7m5uctfF+i9ss6oq6++On784x/Hhg0bYvLkyV1eC1AOWWfUf7vsssvi+uuvjy1btvhMXehlMs2ohQsXxsyZM6Nfv37xt7/9LSL+/5vu7tmzJ1544QVvJIBeJtOMejWnn356RPznm3HSewjfRETED37wg5g0aVJ897vf7XD5gQMHYujQodVfjxw5Mh599NEoiqLDv7L99a9/7XC70aNHR0TE4MGD40Mf+lAPrhxoBGWdUQsXLozbbrstVq5cGZdffnm3vw7Qu5V1Rr3cS/819+DBgyfsawLlV7YZtWfPnti4ceMrfqO48847L84555x4+OGHu/x1gd6pbDPq1bz08Swvf2c75eYzvomI//wr3H//i1tExN133x179+7tcNmUKVNi79698aMf/ah62dGjR+M73/lOh+udf/75MXr06Fi+fHk899xzx93f008/fQJXD2RXxhl10003xfLly2PRokUxf/78rhwOkEzZZtS+ffuOW09ExJo1ayIiYvz48a99QEAqZZtRmzZtOu7Hxz/+8YiIuP322+Ob3/xml44P6N3KNqNe6fcPHToUK1eujKFDh8b555//usdEeXjHNxERMW3atFiyZEnMmTMnJk6cGDt37owNGzbEGWec0eF611xzTaxevTouv/zymD9/frz1rW+NDRs2xIABAyIiqv/q1qdPn1izZk1MnTo1zj777JgzZ04MHz489u7dG9u2bYvBgwfHPffc85pruueee2LHjh0REfHiiy/GI488El/96lcjImL69Onx3ve+90SfBqCkyjajNm3aFJ///OfjzDPPjHe/+92xfv36Dr/f2tpa/VxdIL+yzaj169fHt771rZgxY0ac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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images2'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "3Bl8o7fxgsHz",
        "outputId": "2b727e9f-1c66-424e-c722-f65ddb794360"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "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eOtb39rutiFDhsRpp5123HtlDxkyJJ599tnqr48ePRqrV6+OW265JXbv3h1tbW3V33vLW95S/fkTTzwRY8aMOe7jvfK/zO7atSsiIubMmfOa6z1w4ECcfPLJHTw6oKfLOqPa2triU5/6VDz66KPx85//PN7xjne84WOA8sk4o0499dQ49dRTIyLisssui2XLlkVTU1Ps2rXLN7eEHibTjLrrrrti+/bt8Ze//OU1Hw/0LJlm1Kvp169fXHvttdUIfsEFF3T4sdSX8J3ISSed1Knbi6Ko/nzZsmVxww03xGc/+9m48cYb45RTTok+ffrE5z//+S5dmX3sMTfddFOMHz/+Ve/T2NjY6Y8L9FxZZ9TVV18dP/3pT6O5uTmmTJnS6bUA5ZB1Rr3cZZddFtdff31s2bLFe+pCD5NpRi1atChmzZoV/fr1i3/84x8R8f/fdLelpSVeeOEFFxJAD5NpRr2W008/PSJe+mac9BzCNxER8aMf/SgmT54c3//+99vdvn///hg2bFj116NGjYpHH300iqJo969sf//739s9bsyYMRERMXjw4PjIRz7SjSsHeoOyzqhFixbFbbfdFqtWrYrLL7+8yx8H6NnKOqNe6dh/zT1w4MAJ+5hA+ZVtRrW0tMTGjRtf9RvFnXfeeXHOOefEww8/3OmPC/RMZZtRr+XY27O88sp2ys17fBMRL/0r3Mv/xS0i4u677469e/e2u23q1Kmxd+/e+MlPflK97ciRI/G9732v3f3OP//8GDNmTKxYsSKee+654z7f008/fQJXD2RXxhl10003xYoVK2Lx4sWxYMGCzhwOkEzZZlRra+tx64mIWLt2bURETJgw4fUPCEilbDNq06ZNx/345Cc/GRERt99+e3z729/u1PEBPVvZZtSr/f7Bgwdj1apVMWzYsDj//PPf8JgoD1d8ExER06dPj6VLl8bcuXNj0qRJsXPnzmhubo4zzjij3f2uueaaWLNmTVx++eWxYMGCePvb3x7Nzc0xYMCAiIjqv7r16dMn1q5dG9OmTYuzzz475s6dGyNGjIi9e/fGtm3bYvDgwXHPPfe87pruueee2LFjR0REvPjii/HII4/E17/+9YiImDFjRrz//e8/0acBKKmyzahNmzbFF7/4xTjzzDPjve99b2zYsKHd7zc1NVXfVxfIr2wzasOGDfGd73wnZs6cGWec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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images3'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "YERQcD1zgu0D",
        "outputId": "d9cc0bf1-e182-4244-c2b5-0aaace8e30f5"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "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AfHWt7613W1NTU1x2mmnHfde2U1NTfHss89Wf3306NFYtWpV3HLLLbFz585oa2ur/t5b3vKW6s+feOKJGD169HEf75X/Zba1tTUiImbPnv2a6z1w4ECcfPLJHXx2QE+XdUa1tbXFpz71qXj00Ufj5z//ebzjHe94w8cA5ZNxRp166qlx6qmnRkTEZZddFkuXLo3m5uZobW31zS2hh8k0o+66667Ytm1b/OUvf3nNxwM9S6YZ9Wr69esX1157bTWCX3DBBR1+LPUlfCdy0kknder2oiiqP1+6dGnccMMN8dnPfjZuvPHGOOWUU6JPnz7x+c9/vktXZh97zE033RTjxo171fs0NjZ2+uMCPVfWGXX11VfHT3/602hpaYnJkyd3ei1AOWSdUS932WWXxfXXXx+bN2/2nrrQw2SaUQsXLoyZM2dGv3794h//+EdE/P833d29e3e88MILLiSAHibTjHotp59+ekS89M046TmEbyIi4kc/+lFMmjQpvv/977e7ff/+/TF06NDqr0eOHBmPPvpoFEXR7l/Z/v73v7d73OjRoyMiYvDgwfGRj3ykG1cO9AZlnVELFy6M2267LVauXBmXX355lz8O0LOVdUa90rH/mnvgwIET9jGB8ivbjNq9e3ds2LDhVb9R3HnnnRfnnHNOPPzww53+uEDPVLYZ9VqOvT3LK69sp9y8xzcR8dK/wr38X9wiIu6+++7Ys2dPu9umTJkSe/bsiZ/85CfV244cORLf+9732t3v/PPPj9GjR8fy5cvjueeeO+7zPf300ydw9UB2ZZxRN910UyxfvjwWLVoU8+fP78zTAZIp24zau3fvceuJiFizZk1ERIwfP/71nxCQStlm1MaNG4/78clPfjIiIm6//fb49re/3annB/RsZZtRr/b7Bw8ejJUrV8bQoUPj/PPPf8PnRHm44puIiJg2bVosWbIk5syZExMnTowdO3ZES0tLnHHGGe3ud80118Tq1avj8ssvj/nz58fb3/72aGlpiQEDBkREVP/VrU+fPrFmzZqYOnVqnH322TFnzpwYPnx47NmzJ7Zu3RqDBw+Oe+6553XXdM8998T27dsjIuLFF1+MRx55JL7+9a9HRMT06dPj/e9//4k+DEBJlW1Gbdy4Mb74xS/GmWeeGe9973tj/fr17X6/ubm5+r66QH5lm1Hr16+P73znOzFjxow4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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images4'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "DOVHzxmKgxaq",
        "outputId": "ad8f6609-42bf-4b84-d5b9-498a8675923c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "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b33rW9vc1tLSEmecccZx75Xd0tISzz//fPXXR44cieXLl8dtt90WO3bsiNbW1urvveUtb6n+/Kmnnorhw4cf9/Fe/V9mt2/fHhERM2bMeN317t+/P0499dR2Hh3Q3WWdUa2trfGpT30qHn/88fj5z38e73jHO97wMUD5ZJxRp59+epx++ukREXHFFVfEokWLYsKECbF9+3bf3BK6mUwz6p577oktW7bEX/7yl9d9PNC9ZJpRr6VXr15x/fXXVyP4RRdd1O7HUl/CdyKnnHJKh24viqL680WLFsVNN90Un/3sZ+Pmm2+O0047LXr06BGf//znO3Vl9tHH3HLLLTFq1KjXvE9zc3OHPy7QfWWdUddee2389Kc/jbVr18b48eM7vBagHLLOqGNdccUVceONN8bGjRu9py50M5lm1Lx582LatGnRq1ev+Mc//hER//9Nd3ft2hUvvfSSCwmgm8k0o17PmWeeGRGvfDNOug/hm4iI+NGPfhTjxo2L73//+21u37dvXwwcOLD666FDh8bjjz8eRVG0+Ve2v//9720eN3z48IiI6N+/f3zkIx/pwpUDjaCsM2revHlxxx13xLJly+LKK6/s9McBureyzqhXO/pfc/fv33/SPiZQfmWbUbt27Yp169a95jeKu+CCC+K8886LRx99tMMfF+ieyjajXs/Rt2d59ZXtlJv3+CYiXvlXuGP/xS0i4t57743du3e3uW3ixImxe/fu+MlPflK97fDhw/G9732vzf0uvPDCGD58eCxZsiReeOGF4z7fs88+exJXD2RXxhl1yy23xJIlS2L+/PkxZ86cjhwOkEzZZtSePXuOW09ExMqVKyMiYvTo0Sc+ICCVss2o9evXH/fjk5/8ZERE3HnnnfHtb3+7Q8cHdG9lm1Gv9fsHDhyIZcuWxcCBA+PCCy98w2OiPFzxTURETJ48ORYuXBgzZ86MsWPHxrZt22Lt2rVx1llntbnfddddFytWrIgrr7wy5syZE29/+9tj7dq10adPn4iI6r+69ejRI1auXBmTJk2Kc889N2bOnBmDBw+O3bt3x+bNm6N///5x3333nXBN9913X2zdujUiIl5++eV47LHH4utf/3pEREyZMiXe//73n+zTAJRU2WbU+vXr44tf/GKcffbZ8d73vjfWrFnT5vcnTJhQfV9dIL+yzag1a9bEd77znZg6dWqc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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images5'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "lFjF6-Zigzfd",
        "outputId": "ffd1c055-a4e7-4f9d-966e-611b18fdf069"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABb4AAAExCAYAAACzsrRmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAXrklEQVR4nO3df6zVdf3A8ddB4te9ARolhQJJRiklKqONXApFeB0yVlLZEqR08odIbFENMxY2FkkEG2orQjJAnTUga8V0Ui0p+6VIORdNEiRrgkKIMO3ez/eP5vl6wR/3XrnnfM7rPh4bGxzOuef9+ZzP53Uvz/vh3EpRFEUAAAAAAEASveq9AAAAAAAAOJGEbwAAAAAAUhG+AQAAAABIRfgGAAAAACAV4RsAAAAAgFSEbwAAAAAAUhG+AQAAAABIRfgGAAAAACAV4RsAAAAAgFSEbwAAAAAAUhG+G9DatWujUqnEH//4x3ovpVvdeuutMWPGjBg+fHhUKpW48sor670koAN6wozas2dPfO1rX4vx48fHySefHEOGDImLLroo7rvvvnovDXgdPWFGHTlyJD73uc/FmDFjYtCgQdHc3BznnHNOrFy5Ml588cV6Lw94DT1hRh3rN7/5TVQqlahUKrFv3756Lwd4DT1lRr00k4799Y1vfKPeS6OTetd7AfBqli5dGocOHYrx48fHU089Ve/lAFRt3rw5li5dGtOnT49Zs2bFf//737j99ttj8uTJsWbNmpg9e3a9lwj0YEeOHIm//vWvcckll8TIkSOjV69esW3btpg/f348+OCDsWHDhnovESAiItra2mLu3LnR1NQUhw8frvdyAKomT54cM2fObHfbueeeW6fV0FXCN6X1q1/9qnq1d3Nzc72XA1A1ceLE2L17dwwZMqR625w5c2Ls2LHx1a9+VfgG6uqUU06J3/3ud+1umzNnTgwaNChWrVoVy5cvj6FDh9ZpdQD/77vf/W7s2bMnrrrqqli5cmW9lwNQ9e53vzs+85nP1HsZvEHe6iSJK6+8Mpqbm2P37t0xderUaG5ujmHDhsXNN98cERE7duyISZMmRVNTU4wYMeK4K32eeeaZ+MIXvhDve9/7orm5OQYOHBgtLS2xffv2457riSeeiGnTpkVTU1O87W1vi/nz58eWLVuiUqnEL3/5y3b3ffDBB+Piiy+OQYMGxYABA+LCCy+MBx54oEPbNGLEiKhUKl3bIUCpZJtRZ599drvoHRHRt2/fuOSSS+LJJ5+MQ4cOdXIPAfWUbUa9mpEjR0ZExIEDB7r8MYDayzqjnnnmmfjKV74SixcvjsGDB3d6vwDlkHVGRfzvf9EdPXq0czuEUhG+E2ltbY2WlpY4/fTT45vf/GaMHDkyrr322li7dm1cfPHFMW7cuFi6dGm8+c1vjpkzZ8auXbuqj3388cdj06ZNMXXq1Fi+fHksWLAgduzYERdeeGH885//rN7v8OHDMWnSpLjvvvviuuuui+uvvz62bdsWX/rSl45bz/333x8f+tCH4j//+U8sWrQolixZEgcOHIhJkybF73//+5rsE6A8esKM+te//hUDBgyIAQMGdOnxQP1knFEvvPBC7Nu3L/bs2RMbN26MZcuWxYgRI+Jd73rXG99hQE1lnFE33HBDDB06NK655po3voOAuso4o9auXRtNTU3Rv3//OOuss7xVXKMqaDi33XZbERHFH/7wh+pts2bNKiKiWLJkSfW2Z599tujfv39RqVSKO++8s3r7Y489VkREsWjRouptR48eLVpbW9s9z65du4q+ffsWixcvrt72rW99q4iIYtOmTdXbjhw5UrznPe8pIqLYunVrURRF0dbWVpx55pnFlClTira2tup9n3/++eKd73xnMXny5E5tc1NTUzFr1qxOPQaoj544o4qiKHbu3Fn069evuOKKKzr9WKB2etKMuuOOO4qIqP4aN25c8cgjj3TosUB99JQZtX379uKkk04qtmzZUhRFUSxatKiIiOLpp59+3ccC9dNTZtSECROKFStWFJs3by5uvfXWYsyYMUVEFLfccsvr7yRKxRXfyVx11VXV3w8ePDhGjx4dTU1N8YlPfKJ6++jRo2Pw4MHx+OOPV2/r27dv9Or1v8OhtbU19u/fH83NzTF69Oj485//XL3fL37xixg2bFhMmzatelu/fv3i6quvbreOhx9+OHbu3Bmf/vSnY//+/bFv377Yt29fHD58OD784Q/Hr3/962hrazvh2w+UW9YZ9fzzz8eMGTOif//+ftI3NLBsM2rixIlx7733xt133x1z5syJN73pTX54HDSwTDPquuuui5aWlvjoRz/atZ0BlE6mGfXAAw/EvHnzYtq0aTFnzpz405/+FGPGjImFCxfGkSNHuraDqAs/3DKRfv36xVvf+tZ2tw0aNChOO+20494re9CgQfHss89W/9zW1hYrV66MW265JXbt2hWtra3Vv3vLW95S/f0TTzwRo0aNOu7jHftfZnfu3BkREbNmzXrV9R48eDBOPvnkDm4d0OiyzqjW1tb41Kc+FY8++mj8/Oc/j3e84x2v+xigfDLOqFNPPTVOPfXUiIi47LLLYsmSJTF58uTYuXOnH24JDSbTjLrrrrti27Zt8Ze//OVVHw80lkwz6pX06dMnrr322moEv+CCCzr8WOpL+E7kpJNO6tTtRVFUf79kyZK44YYb4rOf/WzceOONccopp0SvXr3i85//fJeuzH7pMTfddFOMHTv2Fe/T3Nzc6Y8LNK6sM+rqq6+On/70p7F+/fqYNGlSp9cClEPWGfVyl112WVx//fWxefNm76kLDSbTjFqwYEHMmDEj+vTpE//4xz8i4v9/6O6ePXvihRdecCEBNJhMM+rVnH766RHxvx/GSeMQvomIiB/96EcxceLE+P73v9/u9gMHDsSQIUOqfx4xYkQ8+uijURRFu++y/f3vf2/3uFGjRkVExMCBA+MjH/lIN64c6AnKOqMWLFgQt912W6xYsSIuv/zyLn8coLGVdUYd66X/mnvw4MET9jGB8ivbjNqzZ09s2LDhFX9Q3HnnnRfnnHNOPPzww53+uEBjKtuMejUvvT3LsVe2U27e45uI+N934V7+HbeIiLvvvjv27t3b7rYpU6bE3r174yc/+Un1tqNHj8b3vve9dvc7//zzY9SoUbFs2bJ47rnnjnu+p59++gSuHsiujDPqpptuimXLlsXChQtj3rx5ndkcIJmyzah9+/Ydt56IiNWrV0dExLhx4157g4BUyjajNm7ceNyvT37ykxERcfvtt8e3v/3tTm0f0NjKNqNe6e8PHToUK1asiCFDhsT555//uttEebjim4iImDp1aixevDhmz54dEyZMiB07dsT69evjjDPOaHe/a665JlatWhWXX355zJs3L97+9rfH+vXro1+/fhER1e+69erVK1avXh0tLS1x9tlnx+zZs2PYsGGxd+/e2Lp1awwcODDuueee11zTPffcE9u3b4+IiBdffDEeeeSR+PrXvx4REdOmTYv3v//9J3o3ACVVthm1cePG+OIXvxhnnnlmvPe9741169a1+/vJkydX31cXyK9sM2rdunXxne98J6ZPnx5n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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images6'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "jFmZ0yeHg1X-",
        "outputId": "38dfae68-2aa5-481e-a733-dd8801fee2e3"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABb4AAAExCAYAAACzsrRmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAXfUlEQVR4nO3df6yVdR3A8c9B4te9ARolhQJJRiklKqONXAp1QxwyVlLZEqR08odIbFENMxY2FkkEG2orQjJAnTUga8V0Ui0p+6VIORdNEiRrgkKIMO3y9Ifj5BXUe6/cc577Oa/XxgaHc+79nuf5ns+FNw/nVoqiKAIAAAAAAJLoUe8FAAAAAADAiSR8AwAAAACQivANAAAAAEAqwjcAAAAAAKkI3wAAAAAApCJ8AwAAAACQivANAAAAAEAqwjcAAAAAAKkI3wAAAAAApCJ8AwAAAACQivDdDa1evToqlUr88Y9/rPdSutStt94a06ZNi6FDh0alUokrr7yy3ksC2qERZtSuXbvia1/7WowdOzZOPvnkGDRoUFx00UVx33331XtpwOtohBl16NCh+NznPhejRo2KAQMGRHNzc5xzzjmxfPnyePHFF+u9POA1NMKMeqXf/OY3UalUolKpxJ49e+q9HOA1NMqMOjqTXvnjG9/4Rr2XRgf1rPcC4NUsXrw4Dhw4EGPHjo2nnnqq3ssBqNq4cWMsXrw4pk6dGjNmzIj//ve/cfvtt0dLS0usWrUqZs6cWe8lAg3s0KFD8de//jUuueSSGD58ePTo0SO2bNkSc+fOjQcffDDWrVtX7yUCRETEkSNHYvbs2dHU1BQHDx6s93IAqlpaWmL69Oltbjv33HPrtBo6S/imtH71q19Vr/Zubm6u93IAqsaPHx87d+6MQYMGVW+bNWtWjB49Or761a8K30BdnXLKKfG73/2uzW2zZs2KAQMGxIoVK2Lp0qUxePDgOq0O4P+++93vxq5du+Kqq66K5cuX13s5AFXvfve74zOf+Uy9l8Eb5K1Okrjyyiujubk5du7cGZMnT47m5uYYMmRI3HzzzRERsW3btpgwYUI0NTXFsGHDjrnS55lnnokvfOEL8b73vS+am5ujf//+MWnSpNi6desxn+uJJ56IKVOmRFNTU7ztbW+LuXPnxqZNm6JSqcQvf/nLNvd98MEH4+KLL44BAwZEv3794sILL4wHHnigXc9p2LBhUalUOndAgFLJNqPOPvvsNtE7IqJ3795xySWXxJNPPhkHDhzo4BEC6inbjHo1w4cPj4iIffv2dfpjALWXdUY988wz8ZWvfCUWLlwYAwcO7PBxAcoh64yKeOl/0R0+fLhjB4RSEb4TaW1tjUmTJsXpp58e3/zmN2P48OFx7bXXxurVq+Piiy+OMWPGxOLFi+PNb35zTJ8+PXbs2FF97OOPPx4bNmyIyZMnx9KlS2PevHmxbdu2uPDCC+Of//xn9X4HDx6MCRMmxH333RfXXXddXH/99bFly5b40pe+dMx67r///vjQhz4U//nPf2LBggWxaNGi2LdvX0yYMCF+//vf1+SYAOXRCDPqX//6V/Tr1y/69evXqccD9ZNxRr3wwguxZ8+e2LVrV6xfvz6WLFkSw4YNi3e9611v/IABNZVxRt1www0xePDguOaaa974AQLqKuOMWr16dTQ1NUXfvn3jrLPO8lZx3VVBt3PbbbcVEVH84Q9/qN42Y8aMIiKKRYsWVW979tlni759+xaVSqW48847q7c/9thjRUQUCxYsqN52+PDhorW1tc3n2bFjR9G7d+9i4cKF1du+9a1vFRFRbNiwoXrboUOHive85z1FRBSbN28uiqIojhw5Upx55pnFxIkTiyNHjlTv+/zzzxfvfOc7i5aWlg4956ampmLGjBkdegxQH404o4qiKLZv31706dOnuOKKKzr8WKB2GmlG3XHHHUVEVH+MGTOmeOSRR9r1WKA+GmVGbd26tTjppJOKTZs2FUVRFAsWLCgionj66adf97FA/TTKjBo3blyxbNmyYuPGjcWtt95ajBo1qoiI4pZbbnn9g0SpuOI7mauuuqr684EDB8bIkSOjqakpPvGJT1RvHzlyZAwcODAef/zx6m29e/eOHj1e2g6tra2xd+/eaG5ujpEjR8af//zn6v1+8YtfxJAhQ2LKlCnV2/r06RNXX311m3U8/PDDsX379vj0pz8de/fujT179sSePXvi4MGD8eEPfzh+/etfx5EjR0748wfKLeuMev7552PatGnRt29f3+kburFsM2r8+PFx7733xt133x2zZs2KN73pTb55HHRjmWbUddddF5MmTYqPfvSjnTsYQOlkmlEPPPBAzJkzJ6ZMmRKzZs2KP/3pTzFq1KiYP39+HDp0qHMHiLrwzS0T6dOnT7z1rW9tc9uAAQPitNNOO+a9sgcMGBDPPvts9ddHjhyJ5cuXxy233BI7duyI1tbW6u+95S1vqf78iSeeiBEjRhzz8V75X2a3b98eEREzZsx41fXu378/Tj755HY+O6C7yzqjWltb41Of+lQ8+uij8fOf/zze8Y53vO5jgPLJOKNOPfXUOPXUUyMi4rLLLotFixZFS0tLbN++3Te3hG4m04y66667YsuWLfGXv/zlVR8PdC+ZZtTx9OrVK6699tpqBL/gggva/VjqS/hO5KSTTurQ7UVRVH++aNGiuOGGG+Kzn/1s3HjjjXHKKadEjx494vOf/3ynrsw++pibbropRo8efdz7NDc3d/jjAt1X1hl19dVXx09/+tNYu3ZtTJgwocNrAcoh64x6ucsuuyyuv/762Lhxo/fUhW4m04yaN29eTJs2LXr16hX/+Mc/IuL/33R3165d8cILL7iQALqZTDPq1Zx++ukR8dI346T7EL6JiIgf/ehHMX78+Pj+97/f5vZ9+/bFoEGDqr8eNmxYPProo1EURZt/Zfv73//e5nEjRoyIiIj+/fvHRz7ykS5cOdAIyjqj5s2bF7fddlssW7YsLr/88k5/HKB7K+uMeqWj/zV3//79J+xjAuVXthm1a9euWLdu3XG/Udx5550X55xzTjz88MMd/rhA91S2GfVqjr49yyuvbKfcvMc3EfHSv8K9/F/cIiLuvvvu2L17d5vbJk6cGLt3746f/OQn1dsOHz4c3/ve99rc7/zzz48RI0bEkiVL4rnnnjvm8z399NMncPVAdmWcUTfddFMsWbIk5s+fH3PmzOnI0wGSKduM2rNnzzHriYhYuXJlRESMGTPmtZ8QkErZZtT69euP+fHJT34yIiJuv/32+Pa3v92h5wd0b2WbUcf7/QMHDsSyZcti0KBBcf7557/uc6I8XPFNRERMnjw5Fi5cGDNnzoxx48bFtm3bYu3atXHGGWe0ud8111wTK1asiMsvvzzmzJkTb3/722Pt2rXRp0+fiIjqv7r16NEjVq5cGZMmTYqzzz47Zs6cGUOGDIndu3fH5s2bo3///nHPPfe85pruueee2Lp1a0REvPjii/HII4/E17/+9YiImDJlSrz//e8/0YcBKKmyzaj169fHF7/4xTjzzDPjve99b6xZs6bN77e0tFTfVxfIr2wzas2aNfGd73wnpk6dGmec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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images7'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "ZyfvGYSZg3Je",
        "outputId": "adb2bf0f-89c7-41d6-e655-ce2b82086e43"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABb4AAAExCAYAAACzsrRmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAXiElEQVR4nO3df6yVdR3A8c9B4te9ARolhQJJRiklKqONXAp1w+uQsZLKliClkz9EYotqmLGwsUgi2FBbEZIB6qwBWSumk2pJ2S9FyrloklzJmqAQIky7PP3hOHnBH9wrnPPcz3m9NjY4nHPP93nOcz738L4P51SKoigCAAAAAACS6FHvBQAAAAAAwPEkfAMAAAAAkIrwDQAAAABAKsI3AAAAAACpCN8AAAAAAKQifAMAAAAAkIrwDQAAAABAKsI3AAAAAACpCN8AAAAAAKQifAMAAAAAkIrw3Q2tWrUqKpVK/PGPf6z3Uk6oW2+9NaZOnRpDhw6NSqUSV155Zb2XBByDRphRbW1t8bWvfS3Gjh0bJ598cgwaNCguuuiiuO++++q9NOB1NMKMOnDgQHzuc5+LUaNGxYABA6K5uTnOOeecWLZsWbz44ov1Xh7wGhphRh3pN7/5TVQqlahUKrFr1656Lwd4DY0yow7PpCN/feMb36j30uiknvVeALyaRYsWxb59+2Ls2LHx1FNP1Xs5AFUbNmyIRYsWxZQpU2L69Onx3//+N26//fZoaWmJlStXxowZM+q9RKCBHThwIP7617/GJZdcEsOHD48ePXrE5s2bY86cOfHggw/G2rVr671EgIiIOHToUMyaNSuamppi//799V4OQFVLS0tMmzatw2XnnntunVZDVwnflNavfvWr6tnezc3N9V4OQNX48eNjx44dMWjQoOplM2fOjNGjR8dXv/pV4Ruoq1NOOSV+97vfdbhs5syZMWDAgFi+fHksWbIkBg8eXKfVAfzfd7/73Whra4urrroqli1bVu/lAFS9+93vjs985jP1XgZvkLc6SeLKK6+M5ubm2LFjR0yaNCmam5tjyJAhcfPNN0dExNatW2PChAnR1NQUw4YNO+pMn2eeeSa+8IUvxPve975obm6O/v37R2tra2zZsuWo+3riiSdi8uTJ0dTUFG9729tizpw5sXHjxqhUKvHLX/6yw3UffPDBuPjii2PAgAHRr1+/uPDCC+OBBx44pm0aNmxYVCqVru0QoFSyzaizzz67Q/SOiOjdu3dccskl8eSTT8a+ffs6uYeAeso2o17N8OHDIyJiz549Xf4aQO1lnVHPPPNMfOUrX4kFCxbEwIEDO71fgHLIOqMiXvpfdAcPHuzcDqFUhO9E2tvbo7W1NU4//fT45je/GcOHD49rr702Vq1aFRdffHGMGTMmFi1aFG9+85tj2rRpsX379uptH3/88Vi/fn1MmjQplixZEnPnzo2tW7fGhRdeGP/85z+r19u/f39MmDAh7rvvvrjuuuvi+uuvj82bN8eXvvSlo9Zz//33x4c+9KH4z3/+E/Pnz4+FCxfGnj17YsKECfH73/++JvsEKI9GmFH/+te/ol+/ftGvX78u3R6on4wz6oUXXohdu3ZFW1tbrFu3LhYvXhzDhg2Ld73rXW98hwE1lXFG3XDDDTF48OC45ppr3vgOAuoq44xatWpVNDU1Rd++feOss87yVnHdVUG3c9tttxURUfzhD3+oXjZ9+vQiIoqFCxdWL3v22WeLvn37FpVKpbjzzjurlz/22GNFRBTz58+vXnbw4MGivb29w/1s37696N27d7FgwYLqZd/61reKiCjWr19fvezAgQPFe97zniIiik2bNhVFURSHDh0qzjzzzGLixInFoUOHqtd9/vnni3e+851FS0tLp7a5qampmD59eqduA9RHI86ooiiKbdu2FX369CmuuOKKTt8WqJ1GmlF33HFHERHVX2PGjCkeeeSRY7otUB+NMqO2bNlSnHTSScXGjRuLoiiK+fPnFxFRPP300697W6B+GmVGjRs3rli6dGmxYcOG4tZbby1GjRpVRERxyy23vP5OolSc8Z3MVVddVf39wIEDY+TIkdHU1BSf+MQnqpePHDkyBg4cGI8//nj1st69e0ePHi8dDu3t7bF79+5obm6OkSNHxp///Ofq9X7xi1/EkCFDYvLkydXL+vTpE1dffXWHdTz88MOxbdu2+PSnPx27d++OXbt2xa5du2L//v3x4Q9/OH7961/HoUOHjvv2A+WWdUY9//zzMXXq1Ojbt69P+oZuLNuMGj9+fNx7771x9913x8yZM+NNb3qTD4+DbizTjLruuuuitbU1PvrRj3ZtZwClk2lGPfDAAzF79uyYPHlyzJw5M/70pz/FqFGjYt68eXHgwIGu7SDqwodbJtKnT59461vf2uGyAQMGxGmnnXbUe2UPGDAgnn322eqfDx06FMuWLYtbbrkltm/fHu3t7dW/e8tb3lL9/RNPPBEjRow46usd+V9mt23bFhER06dPf9X17t27N04++eRj3Dqgu8s6o9rb2+NTn/pUPProo/Hzn/883vGOd7zubYDyyTijTj311Dj11FMjIuKyyy6LhQsXRktLS2zbts2HW0I3k2lG3XXXXbF58+b4y1/+8qq3B7qXTDPqlfTq1SuuvfbaagS/4IILjvm21JfwnchJJ53UqcuLoqj+fuHChXHDDTfEZz/72bjxxhvjlFNOiR49esTnP//5Lp2Zffg2N910U4wePfoVr9Pc3Nzprwt0X1ln1NVXXx0//elPY82aNTFhwoROrwUoh6wz6uUuu+yyuP7662PDhg3eUxe6mUwzau7cuTF16tTo1atX/OMf/4iI/3/obltbW7zwwgtOJIBuJtOMejWnn356RLz0YZx0H8I3ERHxox/9KMaPHx/f//73O1y+Z8+eGDRoUPXPw4YNi0cffTSKoujwU7a///3vHW43YsSIiIjo379/fOQjHzmBKwcaQVln1Ny5c+O2226LpUuXxuWXX97lrwN0b2WdUUc6/F9z9+7de9y+JlB+ZZtRbW1tsXbt2lf8oLjzzjsvzjnnnHj44Yc7/XWB7qlsM+rVHH57liPPbKfcvMc3EfHST+Fe/hO3iIi77747du7c2eGyiRMnxs6dO+MnP/lJ9bKDBw/G9773vQ7XO//882PEiBGxePHieO655466v6effvo4rh7Irowz6qabborFixfHvHnzYvbs2Z3ZHCCZss2oXbt2HbWeiIgVK1ZERMSYMWNee4OAVMo2o9atW3fUr09+8pMREXH77bfHt7/97U5tH9C9lW1GvdLf79u3L5YuXRqDBg2K888//3W3ifJwxjcRETFp0qRYsGBBzJgxI8aNGxdbt26NNWvWxBlnnNHhetdcc00sX748Lr/88pg9e3a8/e1vjzVr1kSfPn0iIqo/devRo0esWLEiWltb4+yzz44ZM2bEkCFDYufOnbFp06bo379/3HPPPa+5pnvuuSe2bNkSEREvvvhiPPLII/H1r389IiImT54c73//+4/3bgBKqmwzat26dfHFL34xzjzzzHjve98bq1ev7vD3LS0t1ffVBfIr24xavXp1fOc734kpU6bEGWecEfv2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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images8'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "MbouYPILg6JZ",
        "outputId": "1372d0ce-49f8-4890-9c02-c437887be832"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABb4AAAExCAYAAACzsrRmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAXvklEQVR4nO3df6yVdR3A8c9B4te9cdEoKRRIMkopURlt5FIoQhwyVlLZEqR08odIbFENMxY2FkkEG2orQjJAnTUga8V0Ui0p+6VIORdNEiRrgkKIMO3y9Ifj5BXFe6+Xc57zua/XxgaHe+79Ps/5ns+9vO/DuZWiKIoAAAAAAIAketR7AQAAAAAA0JWEbwAAAAAAUhG+AQAAAABIRfgGAAAAACAV4RsAAAAAgFSEbwAAAAAAUhG+AQAAAABIRfgGAAAAACAV4RsAAAAAgFSEbwAAAAAAUhG+G9Dq1aujUqnEH//4x3ov5YS69dZbY9q0aTFkyJCoVCpx5ZVX1ntJQDt0hxm1a9eu+NrXvhZjxoyJk08+OQYOHBgXXXRR3HffffVeGvA6usOMOnToUHzuc5+LkSNHRktLSzQ3N8c555wTy5cvjxdffLHeywOOozvMqFf6zW9+E5VKJSqVSuzZs6feywGOo7vMqKMz6ZW/vvGNb9R7aXRQz3ovAF7L4sWL48CBAzFmzJh46qmn6r0cgKqNGzfG4sWLY+rUqTFjxoz473//G7fffntMmDAhVq1aFTNnzqz3EoFu7NChQ/HXv/41Lrnkkhg2bFj06NEjtmzZEnPnzo0HH3ww1q1bV+8lAkRExJEjR2L27NnR1NQUBw8erPdyAKomTJgQ06dPb3PbueeeW6fV0FnCN6X1q1/9qnq1d3Nzc72XA1A1bty42LlzZwwcOLB626xZs2LUqFHx1a9+VfgG6uqUU06J3/3ud21umzVrVrS0tMSKFSti6dKlMWjQoDqtDuD/vvvd78auXbviqquuiuXLl9d7OQBV7373u+Mzn/lMvZfBG+SlTpK48soro7m5OXbu3BmTJ0+O5ubmGDx4cNx8880REbFt27YYP358NDU1xdChQ4+50ueZZ56JL3zhC/G+970vmpubo3///jFp0qTYunXrMR/riSeeiClTpkRTU1O87W1vi7lz58amTZuiUqnEL3/5yzZv++CDD8bFF18cLS0t0a9fv7jwwgvjgQceaNcxDR06NCqVSudOCFAq2WbU2Wef3SZ6R0T07t07LrnkknjyySfjwIEDHTxDQD1lm1GvZdiwYRERsW/fvk6/D6D2ss6oZ555Jr7yla/EwoULY8CAAR0+L0A5ZJ1RES/9L7rDhw937IRQKsJ3Iq2trTFp0qQ4/fTT45vf/GYMGzYsrr322li9enVcfPHFMXr06Fi8eHG8+c1vjunTp8eOHTuq93388cdjw4YNMXny5Fi6dGnMmzcvtm3bFhdeeGH885//rL7dwYMHY/z48XHffffFddddF9dff31s2bIlvvSlLx2znvvvvz8+9KEPxX/+859YsGBBLFq0KPbt2xfjx4+P3//+9zU5J0B5dIcZ9a9//Sv69esX/fr169T9gfrJOKNeeOGF2LNnT+zatSvWr18fS5YsiaFDh8a73vWuN37CgJrKOKNuuOGGGDRoUFxzzTVv/AQBdZVxRq1evTqampqib9++cdZZZ3mpuEZV0HBuu+22IiKKP/zhD9XbZsyYUUREsWjRouptzz77bNG3b9+iUqkUd955Z/X2xx57rIiIYsGCBdXbDh8+XLS2trb5ODt27Ch69+5dLFy4sHrbt771rSIiig0bNlRvO3ToUPGe97yniIhi8+bNRVEUxZEjR4ozzzyzmDhxYnHkyJHq2z7//PPFO9/5zmLChAkdOuampqZixowZHboPUB/dcUYVRVFs37696NOnT3HFFVd0+L5A7XSnGXXHHXcUEVH9NXr06OKRRx5p132B+uguM2rr1q3FSSedVGzatKkoiqJYsGBBERHF008//br3Beqnu8yosWPHFsuWLSs2btxY3HrrrcXIkSOLiChuueWW1z9JlIorvpO56qqrqr8fMGBAjBgxIpqamuITn/hE9fYRI0bEgAED4vHHH6/e1rt37+jR46Xt0NraGnv37o3m5uYYMWJE/PnPf66+3S9+8YsYPHhwTJkypXpbnz594uqrr26zjocffji2b98en/70p2Pv3r2xZ8+e2LNnTxw8eDA+/OEPx69//es4cuRIlx8/UG5ZZ9Tzzz8f06ZNi759+/pJ39DAss2ocePGxb333ht33313zJo1K970pjf54XHQwDLNqOuuuy4mTZoUH/3oRzt3MoDSyTSjHnjggZgzZ05MmTIlZs2aFX/6059i5MiRMX/+/Dh06FDnThB14YdbJtKnT59461vf2ua2lpaWOO200455reyWlpZ49tlnq38+cuRILF++PG655ZbYsWNHtLa2Vv/uLW95S/X3TzzxRAwfPvyY9/fK/zK7ffv2iIiYMWPGa653//79cfLJJ7fz6IBGl3VGtba2xqc+9al49NFH4+c//3m84x3veN37AOWTcUadeuqpceqpp0ZExGWXXRaLFi2KCRMmxPbt2/1wS2gwmWbUXXfdFVu2bIm//OUvr3l/oLFkmlGvplevXnHttddWI/gFF1zQ7vtSX8J3IieddFKHbi+Kovr7RYsWxQ033BCf/exn48Ybb4xTTjklevToEZ///Oc7dWX20fvcdNNNMWrUqFd9m+bm5g6/X6BxZZ1RV199dfz0pz+NtWvXxvjx4zu8FqAcss6ol7vsssvi+uuvj40bN3pNXWgwmWbUvHnzYtq0adGrV6/4xz/+ERH//6G7u3btihdeeMGFBNBgMs2o13L66adHxEs/jJPGIXwTERE/+tGPYty4cfH973+/ze379u2LgQMHVv88dOjQePTRR6MoijbfZfv73//e5n7Dhw+PiIj+/fvHRz7ykRO4cqA7KOuMmjdvXtx2222xbNmyuPzyyzv9foDGVtYZ9UpH/2vu/v37u+x9AuVXthm1a9euWLdu3av+oLjzzjsvzjnnnHj44Yc7/H6BxlS2GfVajr48yyuvbKfcvMY3EfHSd+Fe/h23iIi77747du/e3ea2iRMnxu7du+MnP/lJ9bbDhw/H9773vTZvd/7558fw4cNjyZIl8dxzzx3z8Z5++ukuXD2QXRln1E033RRLliyJ+fPnx5w5czpyOEAyZZtRe/bsOWY9ERErV66MiIjRo0cf/4CAVMo2o9avX3/Mr09+8pMREXH77bfHt7/97Q4dH9DYyjajXu3vDxw4EMuWLYuBAwfG+eef/7rHRHm44puIiJg8eXIsXLgwZs6cGWPHjo1t27bF2rVr44wzzmjzdtdcc02sWLEiLr/88pgzZ068/e1vj7Vr10afPn0iIqrfdevRo0esXLkyJk2aFGeffXbMnDkzBg8eHLt3747NmzdH//7945577jnumu65557YunVrRES8+OKL8cgjj8TXv/71iIiYMmVKvP/97+/q0wCUVNlm1Pr16+OLX/xinHnmmfHe97431qxZ0+bvJ0yYUH1dXSC/ss2oNWvWxHe+852YOnVqnHHG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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = 'Downloads/Images/Images9'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 293
        },
        "id": "VAvKVIlgg87P",
        "outputId": "e3b28f8c-fced-40fc-cc8e-77f0e0162434"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 5 Axes>"
            ],
            "image/png": "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"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Now to verify that the reconstrucetd images indeed haev the same output label, the imaegs are forward passed through the saved pytorch model after going through the same normalisation, resize transformation.\n"
      ],
      "metadata": {
        "id": "UrZFzFDIxowb"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "l13uS-oia3ZZ"
      },
      "outputs": [],
      "source": [
        "from PIL import Image\n",
        "import os\n",
        "saved_model.eval()\n",
        "saved_transform = transforms.Compose([\n",
        "    transforms.ToTensor(),  # Convert the image to a tensor\n",
        "    transforms.Normalize((0.1307,), (0.3081,)),\n",
        "])\n",
        "\n",
        "def get_prediction(image_path):\n",
        "    image = Image.open(image_path)  # Open the image using PIL\n",
        "    image = saved_transform(image)  # Apply transformations to the image\n",
        "    image = image.unsqueeze(0)  # Add a batch dimension to the image\n",
        "    image = image.to(device)\n",
        "    with torch.no_grad():\n",
        "        output = saved_model(image)  # Perform the forward pass\n",
        "        _, predicted = torch.max(output, 1)  # Get the index of the predicted class\n",
        "\n",
        "    return predicted.item()  # Return the predicted label as an integer"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "fyxGrPgavXyT",
        "outputId": "d7887289-63ff-4394-fc58-dd19480fef83"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 0\n",
            "Image: image2.png, Predicted Label: 0\n",
            "Image: image3.png, Predicted Label: 0\n",
            "Image: image4.png, Predicted Label: 0\n",
            "Image: image5.png, Predicted Label: 0\n",
            "Image: image6.png, Predicted Label: 0\n",
            "Image: image7.png, Predicted Label: 0\n",
            "Image: image8.png, Predicted Label: 0\n",
            "Image: image9.png, Predicted Label: 0\n",
            "Image: image10.png, Predicted Label: 0\n",
            "Image: image11.png, Predicted Label: 0\n",
            "Image: image12.png, Predicted Label: 0\n",
            "Image: image13.png, Predicted Label: 0\n",
            "Image: image14.png, Predicted Label: 0\n",
            "Image: image15.png, Predicted Label: 0\n",
            "Image: image16.png, Predicted Label: 0\n",
            "Image: image17.png, Predicted Label: 0\n",
            "Image: image18.png, Predicted Label: 0\n",
            "Image: image19.png, Predicted Label: 0\n",
            "Image: image20.png, Predicted Label: 0\n",
            "Image: image21.png, Predicted Label: 0\n",
            "Image: image22.png, Predicted Label: 0\n",
            "Image: image23.png, Predicted Label: 0\n",
            "Image: image24.png, Predicted Label: 0\n",
            "Image: image25.png, Predicted Label: 0\n",
            "Image: image26.png, Predicted Label: 0\n",
            "Image: image27.png, Predicted Label: 0\n",
            "Image: image28.png, Predicted Label: 0\n",
            "Image: image29.png, Predicted Label: 0\n",
            "Image: image30.png, Predicted Label: 0\n",
            "Image: image31.png, Predicted Label: 0\n",
            "Image: image32.png, Predicted Label: 0\n",
            "Image: image33.png, Predicted Label: 0\n",
            "Image: image34.png, Predicted Label: 0\n",
            "Image: image35.png, Predicted Label: 0\n",
            "Image: image36.png, Predicted Label: 0\n",
            "Image: image37.png, Predicted Label: 0\n",
            "Image: image38.png, Predicted Label: 0\n",
            "Image: image39.png, Predicted Label: 0\n",
            "Image: image40.png, Predicted Label: 0\n",
            "Image: image41.png, Predicted Label: 0\n",
            "Image: image42.png, Predicted Label: 0\n",
            "Image: image43.png, Predicted Label: 0\n",
            "Image: image44.png, Predicted Label: 0\n",
            "Image: image45.png, Predicted Label: 0\n",
            "Image: image46.png, Predicted Label: 0\n",
            "Image: image47.png, Predicted Label: 0\n",
            "Image: image48.png, Predicted Label: 0\n",
            "Image: image49.png, Predicted Label: 0\n",
            "Image: image50.png, Predicted Label: 0\n",
            "Image: image51.png, Predicted Label: 0\n",
            "Image: image52.png, Predicted Label: 0\n",
            "Image: image53.png, Predicted Label: 0\n",
            "Image: image54.png, Predicted Label: 0\n",
            "Image: image55.png, Predicted Label: 0\n",
            "Image: image56.png, Predicted Label: 0\n",
            "Image: image57.png, Predicted Label: 0\n",
            "Image: image58.png, Predicted Label: 0\n",
            "Image: image59.png, Predicted Label: 0\n",
            "Image: image60.png, Predicted Label: 0\n",
            "Image: image61.png, Predicted Label: 0\n",
            "Image: image62.png, Predicted Label: 0\n",
            "Image: image63.png, Predicted Label: 0\n",
            "Image: image64.png, Predicted Label: 0\n",
            "Image: image65.png, Predicted Label: 0\n",
            "Image: image66.png, Predicted Label: 0\n",
            "Image: image67.png, Predicted Label: 0\n",
            "Image: image68.png, Predicted Label: 0\n",
            "Image: image69.png, Predicted Label: 0\n",
            "Image: image70.png, Predicted Label: 0\n",
            "Image: image71.png, Predicted Label: 0\n",
            "Image: image72.png, Predicted Label: 0\n",
            "Image: image73.png, Predicted Label: 0\n",
            "Image: image74.png, Predicted Label: 0\n",
            "Image: image75.png, Predicted Label: 0\n",
            "Image: image76.png, Predicted Label: 0\n",
            "Image: image77.png, Predicted Label: 0\n",
            "Image: image78.png, Predicted Label: 0\n",
            "Image: image79.png, Predicted Label: 0\n",
            "Image: image80.png, Predicted Label: 0\n",
            "Image: image81.png, Predicted Label: 0\n",
            "Image: image82.png, Predicted Label: 0\n",
            "Image: image83.png, Predicted Label: 0\n",
            "Image: image84.png, Predicted Label: 0\n",
            "Image: image85.png, Predicted Label: 0\n",
            "Image: image86.png, Predicted Label: 0\n",
            "Image: image87.png, Predicted Label: 0\n",
            "Image: image88.png, Predicted Label: 0\n",
            "Image: image89.png, Predicted Label: 0\n",
            "Image: image90.png, Predicted Label: 0\n",
            "Image: image91.png, Predicted Label: 0\n",
            "Image: image92.png, Predicted Label: 0\n",
            "Image: image93.png, Predicted Label: 0\n",
            "Image: image94.png, Predicted Label: 0\n",
            "Image: image95.png, Predicted Label: 0\n",
            "Image: image96.png, Predicted Label: 0\n",
            "Image: image97.png, Predicted Label: 0\n",
            "Image: image98.png, Predicted Label: 0\n",
            "Image: image99.png, Predicted Label: 0\n",
            "Image: image100.png, Predicted Label: 0\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_0'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wHOlJmhh9d3A",
        "outputId": "16aa63f2-b957-4e28-fefe-6f109b1b3f42"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 1\n",
            "Image: image2.png, Predicted Label: 1\n",
            "Image: image3.png, Predicted Label: 1\n",
            "Image: image4.png, Predicted Label: 1\n",
            "Image: image5.png, Predicted Label: 1\n",
            "Image: image6.png, Predicted Label: 1\n",
            "Image: image7.png, Predicted Label: 1\n",
            "Image: image8.png, Predicted Label: 1\n",
            "Image: image9.png, Predicted Label: 1\n",
            "Image: image10.png, Predicted Label: 1\n",
            "Image: image11.png, Predicted Label: 1\n",
            "Image: image12.png, Predicted Label: 1\n",
            "Image: image13.png, Predicted Label: 1\n",
            "Image: image14.png, Predicted Label: 1\n",
            "Image: image15.png, Predicted Label: 1\n",
            "Image: image16.png, Predicted Label: 1\n",
            "Image: image17.png, Predicted Label: 1\n",
            "Image: image18.png, Predicted Label: 1\n",
            "Image: image19.png, Predicted Label: 1\n",
            "Image: image20.png, Predicted Label: 1\n",
            "Image: image21.png, Predicted Label: 1\n",
            "Image: image22.png, Predicted Label: 1\n",
            "Image: image23.png, Predicted Label: 1\n",
            "Image: image24.png, Predicted Label: 1\n",
            "Image: image25.png, Predicted Label: 1\n",
            "Image: image26.png, Predicted Label: 1\n",
            "Image: image27.png, Predicted Label: 1\n",
            "Image: image28.png, Predicted Label: 1\n",
            "Image: image29.png, Predicted Label: 1\n",
            "Image: image30.png, Predicted Label: 1\n",
            "Image: image31.png, Predicted Label: 1\n",
            "Image: image32.png, Predicted Label: 1\n",
            "Image: image33.png, Predicted Label: 1\n",
            "Image: image34.png, Predicted Label: 1\n",
            "Image: image35.png, Predicted Label: 1\n",
            "Image: image36.png, Predicted Label: 1\n",
            "Image: image37.png, Predicted Label: 1\n",
            "Image: image38.png, Predicted Label: 1\n",
            "Image: image39.png, Predicted Label: 1\n",
            "Image: image40.png, Predicted Label: 1\n",
            "Image: image41.png, Predicted Label: 1\n",
            "Image: image42.png, Predicted Label: 1\n",
            "Image: image43.png, Predicted Label: 1\n",
            "Image: image44.png, Predicted Label: 1\n",
            "Image: image45.png, Predicted Label: 1\n",
            "Image: image46.png, Predicted Label: 1\n",
            "Image: image47.png, Predicted Label: 1\n",
            "Image: image48.png, Predicted Label: 1\n",
            "Image: image49.png, Predicted Label: 1\n",
            "Image: image50.png, Predicted Label: 1\n",
            "Image: image51.png, Predicted Label: 1\n",
            "Image: image52.png, Predicted Label: 1\n",
            "Image: image53.png, Predicted Label: 1\n",
            "Image: image54.png, Predicted Label: 1\n",
            "Image: image55.png, Predicted Label: 1\n",
            "Image: image56.png, Predicted Label: 1\n",
            "Image: image57.png, Predicted Label: 1\n",
            "Image: image58.png, Predicted Label: 1\n",
            "Image: image59.png, Predicted Label: 1\n",
            "Image: image60.png, Predicted Label: 1\n",
            "Image: image61.png, Predicted Label: 1\n",
            "Image: image62.png, Predicted Label: 1\n",
            "Image: image63.png, Predicted Label: 1\n",
            "Image: image64.png, Predicted Label: 1\n",
            "Image: image65.png, Predicted Label: 1\n",
            "Image: image66.png, Predicted Label: 1\n",
            "Image: image67.png, Predicted Label: 1\n",
            "Image: image68.png, Predicted Label: 1\n",
            "Image: image69.png, Predicted Label: 1\n",
            "Image: image70.png, Predicted Label: 1\n",
            "Image: image71.png, Predicted Label: 1\n",
            "Image: image72.png, Predicted Label: 1\n",
            "Image: image73.png, Predicted Label: 1\n",
            "Image: image74.png, Predicted Label: 1\n",
            "Image: image75.png, Predicted Label: 1\n",
            "Image: image76.png, Predicted Label: 1\n",
            "Image: image77.png, Predicted Label: 1\n",
            "Image: image78.png, Predicted Label: 1\n",
            "Image: image79.png, Predicted Label: 1\n",
            "Image: image80.png, Predicted Label: 1\n",
            "Image: image81.png, Predicted Label: 1\n",
            "Image: image82.png, Predicted Label: 1\n",
            "Image: image83.png, Predicted Label: 1\n",
            "Image: image84.png, Predicted Label: 1\n",
            "Image: image85.png, Predicted Label: 1\n",
            "Image: image86.png, Predicted Label: 1\n",
            "Image: image87.png, Predicted Label: 1\n",
            "Image: image88.png, Predicted Label: 1\n",
            "Image: image89.png, Predicted Label: 1\n",
            "Image: image90.png, Predicted Label: 1\n",
            "Image: image91.png, Predicted Label: 1\n",
            "Image: image92.png, Predicted Label: 1\n",
            "Image: image93.png, Predicted Label: 1\n",
            "Image: image94.png, Predicted Label: 1\n",
            "Image: image95.png, Predicted Label: 1\n",
            "Image: image96.png, Predicted Label: 1\n",
            "Image: image97.png, Predicted Label: 1\n",
            "Image: image98.png, Predicted Label: 1\n",
            "Image: image99.png, Predicted Label: 1\n",
            "Image: image100.png, Predicted Label: 1\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_1'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "HZJ4LD63wcZJ",
        "outputId": "0193b1fe-d34c-4b00-c759-5d01b6d78b90"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 2\n",
            "Image: image2.png, Predicted Label: 2\n",
            "Image: image3.png, Predicted Label: 2\n",
            "Image: image4.png, Predicted Label: 2\n",
            "Image: image5.png, Predicted Label: 2\n",
            "Image: image6.png, Predicted Label: 2\n",
            "Image: image7.png, Predicted Label: 2\n",
            "Image: image8.png, Predicted Label: 2\n",
            "Image: image9.png, Predicted Label: 2\n",
            "Image: image10.png, Predicted Label: 2\n",
            "Image: image11.png, Predicted Label: 2\n",
            "Image: image12.png, Predicted Label: 2\n",
            "Image: image13.png, Predicted Label: 2\n",
            "Image: image14.png, Predicted Label: 2\n",
            "Image: image15.png, Predicted Label: 2\n",
            "Image: image16.png, Predicted Label: 2\n",
            "Image: image17.png, Predicted Label: 2\n",
            "Image: image18.png, Predicted Label: 2\n",
            "Image: image19.png, Predicted Label: 2\n",
            "Image: image20.png, Predicted Label: 2\n",
            "Image: image21.png, Predicted Label: 2\n",
            "Image: image22.png, Predicted Label: 2\n",
            "Image: image23.png, Predicted Label: 2\n",
            "Image: image24.png, Predicted Label: 2\n",
            "Image: image25.png, Predicted Label: 2\n",
            "Image: image26.png, Predicted Label: 2\n",
            "Image: image27.png, Predicted Label: 2\n",
            "Image: image28.png, Predicted Label: 2\n",
            "Image: image29.png, Predicted Label: 2\n",
            "Image: image30.png, Predicted Label: 2\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_2'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 31):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "IM8sDGAlEAVh",
        "outputId": "da209ae7-04ea-4a90-9a42-c7e874634317"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 3\n",
            "Image: image2.png, Predicted Label: 3\n",
            "Image: image3.png, Predicted Label: 3\n",
            "Image: image4.png, Predicted Label: 3\n",
            "Image: image5.png, Predicted Label: 3\n",
            "Image: image6.png, Predicted Label: 3\n",
            "Image: image7.png, Predicted Label: 3\n",
            "Image: image8.png, Predicted Label: 3\n",
            "Image: image9.png, Predicted Label: 3\n",
            "Image: image10.png, Predicted Label: 3\n",
            "Image: image11.png, Predicted Label: 3\n",
            "Image: image12.png, Predicted Label: 3\n",
            "Image: image13.png, Predicted Label: 3\n",
            "Image: image14.png, Predicted Label: 3\n",
            "Image: image15.png, Predicted Label: 3\n",
            "Image: image16.png, Predicted Label: 3\n",
            "Image: image17.png, Predicted Label: 3\n",
            "Image: image18.png, Predicted Label: 3\n",
            "Image: image19.png, Predicted Label: 3\n",
            "Image: image20.png, Predicted Label: 3\n",
            "Image: image21.png, Predicted Label: 3\n",
            "Image: image22.png, Predicted Label: 3\n",
            "Image: image23.png, Predicted Label: 3\n",
            "Image: image24.png, Predicted Label: 3\n",
            "Image: image25.png, Predicted Label: 3\n",
            "Image: image26.png, Predicted Label: 3\n",
            "Image: image27.png, Predicted Label: 3\n",
            "Image: image28.png, Predicted Label: 3\n",
            "Image: image29.png, Predicted Label: 3\n",
            "Image: image30.png, Predicted Label: 3\n",
            "Image: image31.png, Predicted Label: 3\n",
            "Image: image32.png, Predicted Label: 3\n",
            "Image: image33.png, Predicted Label: 3\n",
            "Image: image34.png, Predicted Label: 3\n",
            "Image: image35.png, Predicted Label: 3\n",
            "Image: image36.png, Predicted Label: 3\n",
            "Image: image37.png, Predicted Label: 3\n",
            "Image: image38.png, Predicted Label: 3\n",
            "Image: image39.png, Predicted Label: 3\n",
            "Image: image40.png, Predicted Label: 3\n",
            "Image: image41.png, Predicted Label: 3\n",
            "Image: image42.png, Predicted Label: 3\n",
            "Image: image43.png, Predicted Label: 3\n",
            "Image: image44.png, Predicted Label: 3\n",
            "Image: image45.png, Predicted Label: 3\n",
            "Image: image46.png, Predicted Label: 3\n",
            "Image: image47.png, Predicted Label: 3\n",
            "Image: image48.png, Predicted Label: 3\n",
            "Image: image49.png, Predicted Label: 3\n",
            "Image: image50.png, Predicted Label: 3\n",
            "Image: image51.png, Predicted Label: 3\n",
            "Image: image52.png, Predicted Label: 3\n",
            "Image: image53.png, Predicted Label: 3\n",
            "Image: image54.png, Predicted Label: 3\n",
            "Image: image55.png, Predicted Label: 3\n",
            "Image: image56.png, Predicted Label: 3\n",
            "Image: image57.png, Predicted Label: 3\n",
            "Image: image58.png, Predicted Label: 3\n",
            "Image: image59.png, Predicted Label: 3\n",
            "Image: image60.png, Predicted Label: 3\n",
            "Image: image61.png, Predicted Label: 3\n",
            "Image: image62.png, Predicted Label: 3\n",
            "Image: image63.png, Predicted Label: 3\n",
            "Image: image64.png, Predicted Label: 3\n",
            "Image: image65.png, Predicted Label: 3\n",
            "Image: image66.png, Predicted Label: 3\n",
            "Image: image67.png, Predicted Label: 3\n",
            "Image: image68.png, Predicted Label: 3\n",
            "Image: image69.png, Predicted Label: 3\n",
            "Image: image70.png, Predicted Label: 3\n",
            "Image: image71.png, Predicted Label: 3\n",
            "Image: image72.png, Predicted Label: 3\n",
            "Image: image73.png, Predicted Label: 3\n",
            "Image: image74.png, Predicted Label: 3\n",
            "Image: image75.png, Predicted Label: 3\n",
            "Image: image76.png, Predicted Label: 3\n",
            "Image: image77.png, Predicted Label: 3\n",
            "Image: image78.png, Predicted Label: 3\n",
            "Image: image79.png, Predicted Label: 3\n",
            "Image: image80.png, Predicted Label: 3\n",
            "Image: image81.png, Predicted Label: 3\n",
            "Image: image82.png, Predicted Label: 3\n",
            "Image: image83.png, Predicted Label: 3\n",
            "Image: image84.png, Predicted Label: 3\n",
            "Image: image85.png, Predicted Label: 3\n",
            "Image: image86.png, Predicted Label: 3\n",
            "Image: image87.png, Predicted Label: 3\n",
            "Image: image88.png, Predicted Label: 3\n",
            "Image: image89.png, Predicted Label: 3\n",
            "Image: image90.png, Predicted Label: 3\n",
            "Image: image91.png, Predicted Label: 3\n",
            "Image: image92.png, Predicted Label: 3\n",
            "Image: image93.png, Predicted Label: 3\n",
            "Image: image94.png, Predicted Label: 3\n",
            "Image: image95.png, Predicted Label: 3\n",
            "Image: image96.png, Predicted Label: 3\n",
            "Image: image97.png, Predicted Label: 3\n",
            "Image: image98.png, Predicted Label: 3\n",
            "Image: image99.png, Predicted Label: 3\n",
            "Image: image100.png, Predicted Label: 3\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_3'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "x-3cbvgNB_rC",
        "outputId": "2f9ac23a-1e66-4ed1-8df5-c952aff27189"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 4\n",
            "Image: image2.png, Predicted Label: 4\n",
            "Image: image3.png, Predicted Label: 4\n",
            "Image: image4.png, Predicted Label: 4\n",
            "Image: image5.png, Predicted Label: 4\n",
            "Image: image6.png, Predicted Label: 4\n",
            "Image: image7.png, Predicted Label: 4\n",
            "Image: image8.png, Predicted Label: 4\n",
            "Image: image9.png, Predicted Label: 4\n",
            "Image: image10.png, Predicted Label: 4\n",
            "Image: image11.png, Predicted Label: 4\n",
            "Image: image12.png, Predicted Label: 4\n",
            "Image: image13.png, Predicted Label: 4\n",
            "Image: image14.png, Predicted Label: 4\n",
            "Image: image15.png, Predicted Label: 4\n",
            "Image: image16.png, Predicted Label: 4\n",
            "Image: image17.png, Predicted Label: 4\n",
            "Image: image18.png, Predicted Label: 4\n",
            "Image: image19.png, Predicted Label: 4\n",
            "Image: image20.png, Predicted Label: 4\n",
            "Image: image21.png, Predicted Label: 4\n",
            "Image: image22.png, Predicted Label: 4\n",
            "Image: image23.png, Predicted Label: 4\n",
            "Image: image24.png, Predicted Label: 4\n",
            "Image: image25.png, Predicted Label: 4\n",
            "Image: image26.png, Predicted Label: 4\n",
            "Image: image27.png, Predicted Label: 4\n",
            "Image: image28.png, Predicted Label: 4\n",
            "Image: image29.png, Predicted Label: 4\n",
            "Image: image30.png, Predicted Label: 4\n",
            "Image: image31.png, Predicted Label: 4\n",
            "Image: image32.png, Predicted Label: 4\n",
            "Image: image33.png, Predicted Label: 4\n",
            "Image: image34.png, Predicted Label: 4\n",
            "Image: image35.png, Predicted Label: 4\n",
            "Image: image36.png, Predicted Label: 4\n",
            "Image: image37.png, Predicted Label: 4\n",
            "Image: image38.png, Predicted Label: 4\n",
            "Image: image39.png, Predicted Label: 4\n",
            "Image: image40.png, Predicted Label: 4\n",
            "Image: image41.png, Predicted Label: 4\n",
            "Image: image42.png, Predicted Label: 4\n",
            "Image: image43.png, Predicted Label: 4\n",
            "Image: image44.png, Predicted Label: 4\n",
            "Image: image45.png, Predicted Label: 4\n",
            "Image: image46.png, Predicted Label: 4\n",
            "Image: image47.png, Predicted Label: 4\n",
            "Image: image48.png, Predicted Label: 4\n",
            "Image: image49.png, Predicted Label: 4\n",
            "Image: image50.png, Predicted Label: 4\n",
            "Image: image51.png, Predicted Label: 4\n",
            "Image: image52.png, Predicted Label: 4\n",
            "Image: image53.png, Predicted Label: 4\n",
            "Image: image54.png, Predicted Label: 4\n",
            "Image: image55.png, Predicted Label: 4\n",
            "Image: image56.png, Predicted Label: 4\n",
            "Image: image57.png, Predicted Label: 4\n",
            "Image: image58.png, Predicted Label: 4\n",
            "Image: image59.png, Predicted Label: 4\n",
            "Image: image60.png, Predicted Label: 4\n",
            "Image: image61.png, Predicted Label: 4\n",
            "Image: image62.png, Predicted Label: 4\n",
            "Image: image63.png, Predicted Label: 4\n",
            "Image: image64.png, Predicted Label: 4\n",
            "Image: image65.png, Predicted Label: 4\n",
            "Image: image66.png, Predicted Label: 4\n",
            "Image: image67.png, Predicted Label: 4\n",
            "Image: image68.png, Predicted Label: 4\n",
            "Image: image69.png, Predicted Label: 4\n",
            "Image: image70.png, Predicted Label: 4\n",
            "Image: image71.png, Predicted Label: 4\n",
            "Image: image72.png, Predicted Label: 4\n",
            "Image: image73.png, Predicted Label: 4\n",
            "Image: image74.png, Predicted Label: 4\n",
            "Image: image75.png, Predicted Label: 4\n",
            "Image: image76.png, Predicted Label: 4\n",
            "Image: image77.png, Predicted Label: 4\n",
            "Image: image78.png, Predicted Label: 4\n",
            "Image: image79.png, Predicted Label: 4\n",
            "Image: image80.png, Predicted Label: 4\n",
            "Image: image81.png, Predicted Label: 4\n",
            "Image: image82.png, Predicted Label: 4\n",
            "Image: image83.png, Predicted Label: 4\n",
            "Image: image84.png, Predicted Label: 4\n",
            "Image: image85.png, Predicted Label: 4\n",
            "Image: image86.png, Predicted Label: 4\n",
            "Image: image87.png, Predicted Label: 4\n",
            "Image: image88.png, Predicted Label: 4\n",
            "Image: image89.png, Predicted Label: 4\n",
            "Image: image90.png, Predicted Label: 4\n",
            "Image: image91.png, Predicted Label: 4\n",
            "Image: image92.png, Predicted Label: 4\n",
            "Image: image93.png, Predicted Label: 4\n",
            "Image: image94.png, Predicted Label: 4\n",
            "Image: image95.png, Predicted Label: 4\n",
            "Image: image96.png, Predicted Label: 4\n",
            "Image: image97.png, Predicted Label: 4\n",
            "Image: image98.png, Predicted Label: 4\n",
            "Image: image99.png, Predicted Label: 4\n",
            "Image: image100.png, Predicted Label: 4\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_4'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "v_7ABRdV-lP4",
        "outputId": "8c942653-f5e8-415b-fa06-b49409fe96e0"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 5\n",
            "Image: image2.png, Predicted Label: 5\n",
            "Image: image3.png, Predicted Label: 5\n",
            "Image: image4.png, Predicted Label: 5\n",
            "Image: image5.png, Predicted Label: 5\n",
            "Image: image6.png, Predicted Label: 5\n",
            "Image: image7.png, Predicted Label: 5\n",
            "Image: image8.png, Predicted Label: 5\n",
            "Image: image9.png, Predicted Label: 5\n",
            "Image: image10.png, Predicted Label: 5\n",
            "Image: image11.png, Predicted Label: 5\n",
            "Image: image12.png, Predicted Label: 5\n",
            "Image: image13.png, Predicted Label: 5\n",
            "Image: image14.png, Predicted Label: 5\n",
            "Image: image15.png, Predicted Label: 5\n",
            "Image: image16.png, Predicted Label: 5\n",
            "Image: image17.png, Predicted Label: 5\n",
            "Image: image18.png, Predicted Label: 5\n",
            "Image: image19.png, Predicted Label: 5\n",
            "Image: image20.png, Predicted Label: 5\n",
            "Image: image21.png, Predicted Label: 5\n",
            "Image: image22.png, Predicted Label: 5\n",
            "Image: image23.png, Predicted Label: 5\n",
            "Image: image24.png, Predicted Label: 5\n",
            "Image: image25.png, Predicted Label: 5\n",
            "Image: image26.png, Predicted Label: 5\n",
            "Image: image27.png, Predicted Label: 5\n",
            "Image: image28.png, Predicted Label: 5\n",
            "Image: image29.png, Predicted Label: 5\n",
            "Image: image30.png, Predicted Label: 5\n",
            "Image: image31.png, Predicted Label: 5\n",
            "Image: image32.png, Predicted Label: 5\n",
            "Image: image33.png, Predicted Label: 5\n",
            "Image: image34.png, Predicted Label: 5\n",
            "Image: image35.png, Predicted Label: 5\n",
            "Image: image36.png, Predicted Label: 5\n",
            "Image: image37.png, Predicted Label: 5\n",
            "Image: image38.png, Predicted Label: 5\n",
            "Image: image39.png, Predicted Label: 5\n",
            "Image: image40.png, Predicted Label: 5\n",
            "Image: image41.png, Predicted Label: 5\n",
            "Image: image42.png, Predicted Label: 5\n",
            "Image: image43.png, Predicted Label: 5\n",
            "Image: image44.png, Predicted Label: 5\n",
            "Image: image45.png, Predicted Label: 5\n",
            "Image: image46.png, Predicted Label: 5\n",
            "Image: image47.png, Predicted Label: 5\n",
            "Image: image48.png, Predicted Label: 5\n",
            "Image: image49.png, Predicted Label: 5\n",
            "Image: image50.png, Predicted Label: 5\n",
            "Image: image51.png, Predicted Label: 5\n",
            "Image: image52.png, Predicted Label: 5\n",
            "Image: image53.png, Predicted Label: 5\n",
            "Image: image54.png, Predicted Label: 5\n",
            "Image: image55.png, Predicted Label: 5\n",
            "Image: image56.png, Predicted Label: 5\n",
            "Image: image57.png, Predicted Label: 5\n",
            "Image: image58.png, Predicted Label: 5\n",
            "Image: image59.png, Predicted Label: 5\n",
            "Image: image60.png, Predicted Label: 5\n",
            "Image: image61.png, Predicted Label: 5\n",
            "Image: image62.png, Predicted Label: 5\n",
            "Image: image63.png, Predicted Label: 5\n",
            "Image: image64.png, Predicted Label: 5\n",
            "Image: image65.png, Predicted Label: 5\n",
            "Image: image66.png, Predicted Label: 5\n",
            "Image: image67.png, Predicted Label: 5\n",
            "Image: image68.png, Predicted Label: 5\n",
            "Image: image69.png, Predicted Label: 5\n",
            "Image: image70.png, Predicted Label: 5\n",
            "Image: image71.png, Predicted Label: 5\n",
            "Image: image72.png, Predicted Label: 5\n",
            "Image: image73.png, Predicted Label: 5\n",
            "Image: image74.png, Predicted Label: 5\n",
            "Image: image75.png, Predicted Label: 5\n",
            "Image: image76.png, Predicted Label: 5\n",
            "Image: image77.png, Predicted Label: 5\n",
            "Image: image78.png, Predicted Label: 5\n",
            "Image: image79.png, Predicted Label: 5\n",
            "Image: image80.png, Predicted Label: 5\n",
            "Image: image81.png, Predicted Label: 5\n",
            "Image: image82.png, Predicted Label: 5\n",
            "Image: image83.png, Predicted Label: 5\n",
            "Image: image84.png, Predicted Label: 5\n",
            "Image: image85.png, Predicted Label: 5\n",
            "Image: image86.png, Predicted Label: 5\n",
            "Image: image87.png, Predicted Label: 5\n",
            "Image: image88.png, Predicted Label: 5\n",
            "Image: image89.png, Predicted Label: 5\n",
            "Image: image90.png, Predicted Label: 5\n",
            "Image: image91.png, Predicted Label: 5\n",
            "Image: image92.png, Predicted Label: 5\n",
            "Image: image93.png, Predicted Label: 5\n",
            "Image: image94.png, Predicted Label: 5\n",
            "Image: image95.png, Predicted Label: 5\n",
            "Image: image96.png, Predicted Label: 5\n",
            "Image: image97.png, Predicted Label: 5\n",
            "Image: image98.png, Predicted Label: 5\n",
            "Image: image99.png, Predicted Label: 5\n",
            "Image: image100.png, Predicted Label: 5\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_5'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "S2cIfdqtLsrq",
        "outputId": "3ff29611-a09c-43f2-9ab2-eb881cb1019e"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 6\n",
            "Image: image2.png, Predicted Label: 6\n",
            "Image: image3.png, Predicted Label: 6\n",
            "Image: image4.png, Predicted Label: 6\n",
            "Image: image5.png, Predicted Label: 6\n",
            "Image: image6.png, Predicted Label: 6\n",
            "Image: image7.png, Predicted Label: 6\n",
            "Image: image8.png, Predicted Label: 6\n",
            "Image: image9.png, Predicted Label: 6\n",
            "Image: image10.png, Predicted Label: 6\n",
            "Image: image11.png, Predicted Label: 6\n",
            "Image: image12.png, Predicted Label: 6\n",
            "Image: image13.png, Predicted Label: 6\n",
            "Image: image14.png, Predicted Label: 6\n",
            "Image: image15.png, Predicted Label: 6\n",
            "Image: image16.png, Predicted Label: 6\n",
            "Image: image17.png, Predicted Label: 6\n",
            "Image: image18.png, Predicted Label: 6\n",
            "Image: image19.png, Predicted Label: 6\n",
            "Image: image20.png, Predicted Label: 6\n",
            "Image: image21.png, Predicted Label: 6\n",
            "Image: image22.png, Predicted Label: 6\n",
            "Image: image23.png, Predicted Label: 6\n",
            "Image: image24.png, Predicted Label: 6\n",
            "Image: image25.png, Predicted Label: 6\n",
            "Image: image26.png, Predicted Label: 6\n",
            "Image: image27.png, Predicted Label: 6\n",
            "Image: image28.png, Predicted Label: 6\n",
            "Image: image29.png, Predicted Label: 6\n",
            "Image: image30.png, Predicted Label: 6\n",
            "Image: image31.png, Predicted Label: 6\n",
            "Image: image32.png, Predicted Label: 6\n",
            "Image: image33.png, Predicted Label: 6\n",
            "Image: image34.png, Predicted Label: 6\n",
            "Image: image35.png, Predicted Label: 6\n",
            "Image: image36.png, Predicted Label: 6\n",
            "Image: image37.png, Predicted Label: 6\n",
            "Image: image38.png, Predicted Label: 6\n",
            "Image: image39.png, Predicted Label: 6\n",
            "Image: image40.png, Predicted Label: 6\n",
            "Image: image41.png, Predicted Label: 6\n",
            "Image: image42.png, Predicted Label: 6\n",
            "Image: image43.png, Predicted Label: 6\n",
            "Image: image44.png, Predicted Label: 6\n",
            "Image: image45.png, Predicted Label: 6\n",
            "Image: image46.png, Predicted Label: 6\n",
            "Image: image47.png, Predicted Label: 6\n",
            "Image: image48.png, Predicted Label: 6\n",
            "Image: image49.png, Predicted Label: 6\n",
            "Image: image50.png, Predicted Label: 6\n",
            "Image: image51.png, Predicted Label: 6\n",
            "Image: image52.png, Predicted Label: 6\n",
            "Image: image53.png, Predicted Label: 6\n",
            "Image: image54.png, Predicted Label: 6\n",
            "Image: image55.png, Predicted Label: 6\n",
            "Image: image56.png, Predicted Label: 6\n",
            "Image: image57.png, Predicted Label: 6\n",
            "Image: image58.png, Predicted Label: 6\n",
            "Image: image59.png, Predicted Label: 6\n",
            "Image: image60.png, Predicted Label: 6\n",
            "Image: image61.png, Predicted Label: 6\n",
            "Image: image62.png, Predicted Label: 6\n",
            "Image: image63.png, Predicted Label: 6\n",
            "Image: image64.png, Predicted Label: 6\n",
            "Image: image65.png, Predicted Label: 6\n",
            "Image: image66.png, Predicted Label: 6\n",
            "Image: image67.png, Predicted Label: 6\n",
            "Image: image68.png, Predicted Label: 6\n",
            "Image: image69.png, Predicted Label: 6\n",
            "Image: image70.png, Predicted Label: 6\n",
            "Image: image71.png, Predicted Label: 6\n",
            "Image: image72.png, Predicted Label: 6\n",
            "Image: image73.png, Predicted Label: 6\n",
            "Image: image74.png, Predicted Label: 6\n",
            "Image: image75.png, Predicted Label: 6\n",
            "Image: image76.png, Predicted Label: 6\n",
            "Image: image77.png, Predicted Label: 6\n",
            "Image: image78.png, Predicted Label: 6\n",
            "Image: image79.png, Predicted Label: 6\n",
            "Image: image80.png, Predicted Label: 6\n",
            "Image: image81.png, Predicted Label: 6\n",
            "Image: image82.png, Predicted Label: 6\n",
            "Image: image83.png, Predicted Label: 6\n",
            "Image: image84.png, Predicted Label: 6\n",
            "Image: image85.png, Predicted Label: 6\n",
            "Image: image86.png, Predicted Label: 6\n",
            "Image: image87.png, Predicted Label: 6\n",
            "Image: image88.png, Predicted Label: 6\n",
            "Image: image89.png, Predicted Label: 6\n",
            "Image: image90.png, Predicted Label: 6\n",
            "Image: image91.png, Predicted Label: 6\n",
            "Image: image92.png, Predicted Label: 6\n",
            "Image: image93.png, Predicted Label: 6\n",
            "Image: image94.png, Predicted Label: 6\n",
            "Image: image95.png, Predicted Label: 6\n",
            "Image: image96.png, Predicted Label: 6\n",
            "Image: image97.png, Predicted Label: 6\n",
            "Image: image98.png, Predicted Label: 6\n",
            "Image: image99.png, Predicted Label: 6\n",
            "Image: image100.png, Predicted Label: 6\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_6'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ZerWbkkLMRYS",
        "outputId": "6c278929-0133-466b-9841-4966bfe3f2f2"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 7\n",
            "Image: image2.png, Predicted Label: 7\n",
            "Image: image3.png, Predicted Label: 7\n",
            "Image: image4.png, Predicted Label: 7\n",
            "Image: image5.png, Predicted Label: 7\n",
            "Image: image6.png, Predicted Label: 7\n",
            "Image: image7.png, Predicted Label: 7\n",
            "Image: image8.png, Predicted Label: 7\n",
            "Image: image9.png, Predicted Label: 7\n",
            "Image: image10.png, Predicted Label: 7\n",
            "Image: image11.png, Predicted Label: 7\n",
            "Image: image12.png, Predicted Label: 7\n",
            "Image: image13.png, Predicted Label: 7\n",
            "Image: image14.png, Predicted Label: 7\n",
            "Image: image15.png, Predicted Label: 7\n",
            "Image: image16.png, Predicted Label: 7\n",
            "Image: image17.png, Predicted Label: 7\n",
            "Image: image18.png, Predicted Label: 7\n",
            "Image: image19.png, Predicted Label: 7\n",
            "Image: image20.png, Predicted Label: 7\n",
            "Image: image21.png, Predicted Label: 7\n",
            "Image: image22.png, Predicted Label: 7\n",
            "Image: image23.png, Predicted Label: 7\n",
            "Image: image24.png, Predicted Label: 7\n",
            "Image: image25.png, Predicted Label: 7\n",
            "Image: image26.png, Predicted Label: 7\n",
            "Image: image27.png, Predicted Label: 7\n",
            "Image: image28.png, Predicted Label: 7\n",
            "Image: image29.png, Predicted Label: 7\n",
            "Image: image30.png, Predicted Label: 7\n",
            "Image: image31.png, Predicted Label: 7\n",
            "Image: image32.png, Predicted Label: 7\n",
            "Image: image33.png, Predicted Label: 7\n",
            "Image: image34.png, Predicted Label: 7\n",
            "Image: image35.png, Predicted Label: 7\n",
            "Image: image36.png, Predicted Label: 7\n",
            "Image: image37.png, Predicted Label: 7\n",
            "Image: image38.png, Predicted Label: 7\n",
            "Image: image39.png, Predicted Label: 7\n",
            "Image: image40.png, Predicted Label: 7\n",
            "Image: image41.png, Predicted Label: 7\n",
            "Image: image42.png, Predicted Label: 7\n",
            "Image: image43.png, Predicted Label: 7\n",
            "Image: image44.png, Predicted Label: 7\n",
            "Image: image45.png, Predicted Label: 7\n",
            "Image: image46.png, Predicted Label: 7\n",
            "Image: image47.png, Predicted Label: 7\n",
            "Image: image48.png, Predicted Label: 7\n",
            "Image: image49.png, Predicted Label: 7\n",
            "Image: image50.png, Predicted Label: 7\n",
            "Image: image51.png, Predicted Label: 7\n",
            "Image: image52.png, Predicted Label: 7\n",
            "Image: image53.png, Predicted Label: 7\n",
            "Image: image54.png, Predicted Label: 7\n",
            "Image: image55.png, Predicted Label: 7\n",
            "Image: image56.png, Predicted Label: 7\n",
            "Image: image57.png, Predicted Label: 7\n",
            "Image: image58.png, Predicted Label: 7\n",
            "Image: image59.png, Predicted Label: 7\n",
            "Image: image60.png, Predicted Label: 7\n",
            "Image: image61.png, Predicted Label: 7\n",
            "Image: image62.png, Predicted Label: 7\n",
            "Image: image63.png, Predicted Label: 7\n",
            "Image: image64.png, Predicted Label: 7\n",
            "Image: image65.png, Predicted Label: 7\n",
            "Image: image66.png, Predicted Label: 7\n",
            "Image: image67.png, Predicted Label: 7\n",
            "Image: image68.png, Predicted Label: 7\n",
            "Image: image69.png, Predicted Label: 7\n",
            "Image: image70.png, Predicted Label: 7\n",
            "Image: image71.png, Predicted Label: 7\n",
            "Image: image72.png, Predicted Label: 7\n",
            "Image: image73.png, Predicted Label: 7\n",
            "Image: image74.png, Predicted Label: 7\n",
            "Image: image75.png, Predicted Label: 7\n",
            "Image: image76.png, Predicted Label: 7\n",
            "Image: image77.png, Predicted Label: 7\n",
            "Image: image78.png, Predicted Label: 7\n",
            "Image: image79.png, Predicted Label: 7\n",
            "Image: image80.png, Predicted Label: 7\n",
            "Image: image81.png, Predicted Label: 7\n",
            "Image: image82.png, Predicted Label: 7\n",
            "Image: image83.png, Predicted Label: 7\n",
            "Image: image84.png, Predicted Label: 7\n",
            "Image: image85.png, Predicted Label: 7\n",
            "Image: image86.png, Predicted Label: 7\n",
            "Image: image87.png, Predicted Label: 7\n",
            "Image: image88.png, Predicted Label: 7\n",
            "Image: image89.png, Predicted Label: 7\n",
            "Image: image90.png, Predicted Label: 7\n",
            "Image: image91.png, Predicted Label: 7\n",
            "Image: image92.png, Predicted Label: 7\n",
            "Image: image93.png, Predicted Label: 7\n",
            "Image: image94.png, Predicted Label: 7\n",
            "Image: image95.png, Predicted Label: 7\n",
            "Image: image96.png, Predicted Label: 7\n",
            "Image: image97.png, Predicted Label: 7\n",
            "Image: image98.png, Predicted Label: 7\n",
            "Image: image99.png, Predicted Label: 7\n",
            "Image: image100.png, Predicted Label: 7\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_7'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "dtG7ogkSMoxq",
        "outputId": "79308202-58c6-409b-d31c-bcec3b28199b"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 8\n",
            "Image: image2.png, Predicted Label: 8\n",
            "Image: image3.png, Predicted Label: 8\n",
            "Image: image4.png, Predicted Label: 8\n",
            "Image: image5.png, Predicted Label: 8\n",
            "Image: image6.png, Predicted Label: 8\n",
            "Image: image7.png, Predicted Label: 8\n",
            "Image: image8.png, Predicted Label: 8\n",
            "Image: image9.png, Predicted Label: 8\n",
            "Image: image10.png, Predicted Label: 8\n",
            "Image: image11.png, Predicted Label: 8\n",
            "Image: image12.png, Predicted Label: 8\n",
            "Image: image13.png, Predicted Label: 8\n",
            "Image: image14.png, Predicted Label: 8\n",
            "Image: image15.png, Predicted Label: 8\n",
            "Image: image16.png, Predicted Label: 8\n",
            "Image: image17.png, Predicted Label: 8\n",
            "Image: image18.png, Predicted Label: 8\n",
            "Image: image19.png, Predicted Label: 8\n",
            "Image: image20.png, Predicted Label: 8\n",
            "Image: image21.png, Predicted Label: 8\n",
            "Image: image22.png, Predicted Label: 8\n",
            "Image: image23.png, Predicted Label: 8\n",
            "Image: image24.png, Predicted Label: 8\n",
            "Image: image25.png, Predicted Label: 8\n",
            "Image: image26.png, Predicted Label: 8\n",
            "Image: image27.png, Predicted Label: 8\n",
            "Image: image28.png, Predicted Label: 8\n",
            "Image: image29.png, Predicted Label: 8\n",
            "Image: image30.png, Predicted Label: 8\n",
            "Image: image31.png, Predicted Label: 8\n",
            "Image: image32.png, Predicted Label: 8\n",
            "Image: image33.png, Predicted Label: 8\n",
            "Image: image34.png, Predicted Label: 8\n",
            "Image: image35.png, Predicted Label: 8\n",
            "Image: image36.png, Predicted Label: 8\n",
            "Image: image37.png, Predicted Label: 8\n",
            "Image: image38.png, Predicted Label: 8\n",
            "Image: image39.png, Predicted Label: 8\n",
            "Image: image40.png, Predicted Label: 8\n",
            "Image: image41.png, Predicted Label: 8\n",
            "Image: image42.png, Predicted Label: 8\n",
            "Image: image43.png, Predicted Label: 8\n",
            "Image: image44.png, Predicted Label: 8\n",
            "Image: image45.png, Predicted Label: 8\n",
            "Image: image46.png, Predicted Label: 8\n",
            "Image: image47.png, Predicted Label: 8\n",
            "Image: image48.png, Predicted Label: 8\n",
            "Image: image49.png, Predicted Label: 8\n",
            "Image: image50.png, Predicted Label: 8\n",
            "Image: image51.png, Predicted Label: 8\n",
            "Image: image52.png, Predicted Label: 8\n",
            "Image: image53.png, Predicted Label: 8\n",
            "Image: image54.png, Predicted Label: 8\n",
            "Image: image55.png, Predicted Label: 8\n",
            "Image: image56.png, Predicted Label: 8\n",
            "Image: image57.png, Predicted Label: 8\n",
            "Image: image58.png, Predicted Label: 8\n",
            "Image: image59.png, Predicted Label: 8\n",
            "Image: image60.png, Predicted Label: 8\n",
            "Image: image61.png, Predicted Label: 8\n",
            "Image: image62.png, Predicted Label: 8\n",
            "Image: image63.png, Predicted Label: 8\n",
            "Image: image64.png, Predicted Label: 8\n",
            "Image: image65.png, Predicted Label: 8\n",
            "Image: image66.png, Predicted Label: 8\n",
            "Image: image67.png, Predicted Label: 8\n",
            "Image: image68.png, Predicted Label: 8\n",
            "Image: image69.png, Predicted Label: 8\n",
            "Image: image70.png, Predicted Label: 8\n",
            "Image: image71.png, Predicted Label: 8\n",
            "Image: image72.png, Predicted Label: 8\n",
            "Image: image73.png, Predicted Label: 8\n",
            "Image: image74.png, Predicted Label: 8\n",
            "Image: image75.png, Predicted Label: 8\n",
            "Image: image76.png, Predicted Label: 8\n",
            "Image: image77.png, Predicted Label: 8\n",
            "Image: image78.png, Predicted Label: 8\n",
            "Image: image79.png, Predicted Label: 8\n",
            "Image: image80.png, Predicted Label: 8\n",
            "Image: image81.png, Predicted Label: 8\n",
            "Image: image82.png, Predicted Label: 8\n",
            "Image: image83.png, Predicted Label: 8\n",
            "Image: image84.png, Predicted Label: 8\n",
            "Image: image85.png, Predicted Label: 8\n",
            "Image: image86.png, Predicted Label: 8\n",
            "Image: image87.png, Predicted Label: 8\n",
            "Image: image88.png, Predicted Label: 8\n",
            "Image: image89.png, Predicted Label: 8\n",
            "Image: image90.png, Predicted Label: 8\n",
            "Image: image91.png, Predicted Label: 8\n",
            "Image: image92.png, Predicted Label: 8\n",
            "Image: image93.png, Predicted Label: 8\n",
            "Image: image94.png, Predicted Label: 8\n",
            "Image: image95.png, Predicted Label: 8\n",
            "Image: image96.png, Predicted Label: 8\n",
            "Image: image97.png, Predicted Label: 8\n",
            "Image: image98.png, Predicted Label: 8\n",
            "Image: image99.png, Predicted Label: 8\n",
            "Image: image100.png, Predicted Label: 8\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_8'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "F3OAaSXBM625",
        "outputId": "23b3669e-fb78-4ad8-c1a8-9e17db82d1fd"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-10-0129fb38037d>:27: UserWarning: Implicit dimension choice for log_softmax has been deprecated. Change the call to include dim=X as an argument.\n",
            "  return self.logsoftmax(x)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Image: image1.png, Predicted Label: 9\n",
            "Image: image2.png, Predicted Label: 9\n",
            "Image: image3.png, Predicted Label: 9\n",
            "Image: image4.png, Predicted Label: 9\n",
            "Image: image5.png, Predicted Label: 9\n",
            "Image: image6.png, Predicted Label: 9\n",
            "Image: image7.png, Predicted Label: 9\n",
            "Image: image8.png, Predicted Label: 9\n",
            "Image: image9.png, Predicted Label: 9\n",
            "Image: image10.png, Predicted Label: 9\n",
            "Image: image11.png, Predicted Label: 9\n",
            "Image: image12.png, Predicted Label: 9\n",
            "Image: image13.png, Predicted Label: 9\n",
            "Image: image14.png, Predicted Label: 9\n",
            "Image: image15.png, Predicted Label: 9\n",
            "Image: image16.png, Predicted Label: 9\n",
            "Image: image17.png, Predicted Label: 9\n",
            "Image: image18.png, Predicted Label: 9\n",
            "Image: image19.png, Predicted Label: 9\n",
            "Image: image20.png, Predicted Label: 9\n",
            "Image: image21.png, Predicted Label: 9\n",
            "Image: image22.png, Predicted Label: 9\n",
            "Image: image23.png, Predicted Label: 9\n",
            "Image: image24.png, Predicted Label: 9\n",
            "Image: image25.png, Predicted Label: 9\n",
            "Image: image26.png, Predicted Label: 9\n",
            "Image: image27.png, Predicted Label: 9\n",
            "Image: image28.png, Predicted Label: 9\n",
            "Image: image29.png, Predicted Label: 9\n",
            "Image: image30.png, Predicted Label: 9\n",
            "Image: image31.png, Predicted Label: 9\n",
            "Image: image32.png, Predicted Label: 9\n",
            "Image: image33.png, Predicted Label: 9\n",
            "Image: image34.png, Predicted Label: 9\n",
            "Image: image35.png, Predicted Label: 9\n",
            "Image: image36.png, Predicted Label: 9\n",
            "Image: image37.png, Predicted Label: 9\n",
            "Image: image38.png, Predicted Label: 9\n",
            "Image: image39.png, Predicted Label: 9\n",
            "Image: image40.png, Predicted Label: 9\n",
            "Image: image41.png, Predicted Label: 9\n",
            "Image: image42.png, Predicted Label: 9\n",
            "Image: image43.png, Predicted Label: 9\n",
            "Image: image44.png, Predicted Label: 9\n",
            "Image: image45.png, Predicted Label: 9\n",
            "Image: image46.png, Predicted Label: 9\n",
            "Image: image47.png, Predicted Label: 9\n",
            "Image: image48.png, Predicted Label: 9\n",
            "Image: image49.png, Predicted Label: 9\n",
            "Image: image50.png, Predicted Label: 9\n",
            "Image: image51.png, Predicted Label: 9\n",
            "Image: image52.png, Predicted Label: 9\n",
            "Image: image53.png, Predicted Label: 9\n",
            "Image: image54.png, Predicted Label: 9\n",
            "Image: image55.png, Predicted Label: 9\n",
            "Image: image56.png, Predicted Label: 9\n",
            "Image: image57.png, Predicted Label: 9\n",
            "Image: image58.png, Predicted Label: 9\n",
            "Image: image59.png, Predicted Label: 9\n",
            "Image: image60.png, Predicted Label: 9\n",
            "Image: image61.png, Predicted Label: 9\n",
            "Image: image62.png, Predicted Label: 9\n",
            "Image: image63.png, Predicted Label: 9\n",
            "Image: image64.png, Predicted Label: 9\n",
            "Image: image65.png, Predicted Label: 9\n",
            "Image: image66.png, Predicted Label: 9\n",
            "Image: image67.png, Predicted Label: 9\n",
            "Image: image68.png, Predicted Label: 9\n",
            "Image: image69.png, Predicted Label: 9\n",
            "Image: image70.png, Predicted Label: 9\n",
            "Image: image71.png, Predicted Label: 9\n",
            "Image: image72.png, Predicted Label: 9\n",
            "Image: image73.png, Predicted Label: 9\n",
            "Image: image74.png, Predicted Label: 9\n",
            "Image: image75.png, Predicted Label: 9\n",
            "Image: image76.png, Predicted Label: 9\n",
            "Image: image77.png, Predicted Label: 9\n",
            "Image: image78.png, Predicted Label: 9\n",
            "Image: image79.png, Predicted Label: 9\n",
            "Image: image80.png, Predicted Label: 9\n",
            "Image: image81.png, Predicted Label: 9\n",
            "Image: image82.png, Predicted Label: 9\n",
            "Image: image83.png, Predicted Label: 9\n",
            "Image: image84.png, Predicted Label: 9\n",
            "Image: image85.png, Predicted Label: 9\n",
            "Image: image86.png, Predicted Label: 9\n",
            "Image: image87.png, Predicted Label: 9\n",
            "Image: image88.png, Predicted Label: 9\n",
            "Image: image89.png, Predicted Label: 9\n",
            "Image: image90.png, Predicted Label: 9\n",
            "Image: image91.png, Predicted Label: 9\n",
            "Image: image92.png, Predicted Label: 9\n",
            "Image: image93.png, Predicted Label: 9\n",
            "Image: image94.png, Predicted Label: 9\n",
            "Image: image95.png, Predicted Label: 9\n",
            "Image: image96.png, Predicted Label: 9\n",
            "Image: image97.png, Predicted Label: 9\n",
            "Image: image98.png, Predicted Label: 9\n",
            "Image: image99.png, Predicted Label: 9\n",
            "Image: image100.png, Predicted Label: 9\n"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/Images/Images_9'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 101):\n",
        "    image_name = f\"image{i}.png\"\n",
        "    image_path = os.path.join(folder_path, image_name)\n",
        "    predicted_label = get_prediction(image_path)\n",
        "    print(f\"Image: {image_name}, Predicted Label: {predicted_label}\")"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Since all the reconstructed images have the same label, the Network Inversion performed is exact.\n",
        "\n",
        "The inversion process demonstrates that while the model does a good job classifying MNIST digits, it deos not necessarily imply that the model is in anyway aware of what differnt digits look like.\n",
        "\n",
        "To refine the model & the decision boundaries, we can use the reconstrucetd images to retrain the model now with an extra class for the above OOD samples after passing them through an oracle or a large model.\n",
        "\n",
        "The iterative retraining process can be continued till the uniformly sampled reconstructed images from the input space of the newly trained model for a particluar label, start to look like the MNIST digits.\n",
        "\n"
      ],
      "metadata": {
        "id": "FW0HRFcF0aM8"
      }
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "provenance": []
    },
    "gpuClass": "standard",
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}