{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "KrTEd7hNXeqT"
      },
      "outputs": [],
      "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 useded 5x5 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",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "42b99cdb-066e-4dcb-af5a-55e73d1565dc"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz\n",
            "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz to ./data/MNIST/raw/train-images-idx3-ubyte.gz\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 9912422/9912422 [00:00<00:00, 360206124.00it/s]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting ./data/MNIST/raw/train-images-idx3-ubyte.gz to ./data/MNIST/raw\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz\n",
            "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz to ./data/MNIST/raw/train-labels-idx1-ubyte.gz\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 28881/28881 [00:00<00:00, 41428075.86it/s]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting ./data/MNIST/raw/train-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
            "\n",
            "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz\n",
            "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz to ./data/MNIST/raw/t10k-images-idx3-ubyte.gz\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\n",
            "100%|██████████| 1648877/1648877 [00:00<00:00, 64090033.24it/s]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting ./data/MNIST/raw/t10k-images-idx3-ubyte.gz to ./data/MNIST/raw\n",
            "\n",
            "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz\n",
            "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz to ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 4542/4542 [00:00<00:00, 2492219.88it/s]"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Extracting ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "\n"
          ]
        }
      ],
      "source": [
        "transform=transforms.Compose([\n",
        "                       transforms.ToTensor(),\n",
        "                       transforms.Normalize((0.1307,), (0.3081,)),\n",
        "                       transforms.Resize((5,5)),\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=4096, shuffle=True)\n",
        "test_loader = DataLoader(dataset_test, batch_size=4096, 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": 614
        },
        "id": "4ckxZT9IbMCH",
        "outputId": "042bf507-c9d9-488d-b991-b7447f1be513"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.10/dist-packages/torchvision/transforms/functional.py:1603: UserWarning: The default value of the antialias parameter of all the resizing transforms (Resize(), RandomResizedCrop(), etc.) will change from None to True in v0.17, in order to be consistent across the PIL and Tensor backends. To suppress this warning, directly pass antialias=True (recommended, future default), antialias=None (current default, which means False for Tensors and True for PIL), or antialias=False (only works on Tensors - PIL will still use antialiasing). This also applies if you are using the inference transforms from the models weights: update the call to weights.transforms(antialias=True).\n",
            "  warnings.warn(\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1200x600 with 10 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "FYPoPnVc0U-p",
        "outputId": "5ac65d14-ca59-4eba-c0e6-62e4f260a370"
      },
      "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. 25 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_50(nn.Module):\n",
        "    def __init__(self, input_size, output_size):\n",
        "        super(BNN_1blk_50, 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_50'\n",
        "        self.fc1 = BinarizeLinear(input_size,50*self.infl_ratio)\n",
        "        self.htanh1 = nn.Hardtanh()\n",
        "        self.bn1 = nn.BatchNorm1d(50*self.infl_ratio)\n",
        "\n",
        "        self.fc5 = BinarizeLinear(50*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_50(25,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": "6bb8953d-14da-4335-a23c-0e3f259ae442"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Train Epoch: 1 [0/60000 (0%)]\tLoss: 3.709929\n",
            "Train Epoch: 1 [40960/60000 (67%)]\tLoss: 4.079579\n",
            "\n",
            "Test set: Average loss: 0.0011, Accuracy: 4744/10000 (47%)\n",
            "\n",
            "Train Epoch: 2 [0/60000 (0%)]\tLoss: 3.518269\n",
            "Train Epoch: 2 [40960/60000 (67%)]\tLoss: 3.732158\n",
            "\n",
            "Test set: Average loss: 0.0012, Accuracy: 4140/10000 (41%)\n",
            "\n",
            "Train Epoch: 3 [0/60000 (0%)]\tLoss: 3.787690\n",
            "Train Epoch: 3 [40960/60000 (67%)]\tLoss: 3.794748\n",
            "\n",
            "Test set: Average loss: 0.0011, Accuracy: 3793/10000 (38%)\n",
            "\n",
            "Train Epoch: 4 [0/60000 (0%)]\tLoss: 3.675952\n",
            "Train Epoch: 4 [40960/60000 (67%)]\tLoss: 3.748465\n",
            "\n",
            "Test set: Average loss: 0.0012, Accuracy: 4632/10000 (46%)\n",
            "\n",
            "Train Epoch: 5 [0/60000 (0%)]\tLoss: 4.057141\n",
            "Train Epoch: 5 [40960/60000 (67%)]\tLoss: 3.511351\n",
            "\n",
            "Test set: Average loss: 0.0011, Accuracy: 4663/10000 (47%)\n",
            "\n",
            "Train Epoch: 6 [0/60000 (0%)]\tLoss: 3.577096\n",
            "Train Epoch: 6 [40960/60000 (67%)]\tLoss: 3.471855\n",
            "\n",
            "Test set: Average loss: 0.0010, Accuracy: 4122/10000 (41%)\n",
            "\n",
            "Train Epoch: 7 [0/60000 (0%)]\tLoss: 3.643489\n",
            "Train Epoch: 7 [40960/60000 (67%)]\tLoss: 4.463116\n",
            "\n",
            "Test set: Average loss: 0.0013, Accuracy: 4560/10000 (46%)\n",
            "\n",
            "Train Epoch: 8 [0/60000 (0%)]\tLoss: 3.882502\n",
            "Train Epoch: 8 [40960/60000 (67%)]\tLoss: 4.101039\n",
            "\n",
            "Test set: Average loss: 0.0014, Accuracy: 3761/10000 (38%)\n",
            "\n",
            "Train Epoch: 9 [0/60000 (0%)]\tLoss: 3.688905\n",
            "Train Epoch: 9 [40960/60000 (67%)]\tLoss: 3.561526\n",
            "\n",
            "Test set: Average loss: 0.0011, Accuracy: 4752/10000 (48%)\n",
            "\n",
            "Train Epoch: 10 [0/60000 (0%)]\tLoss: 3.484452\n",
            "Train Epoch: 10 [40960/60000 (67%)]\tLoss: 3.965371\n",
            "\n",
            "Test set: Average loss: 0.0012, Accuracy: 4449/10000 (44%)\n",
            "\n"
          ]
        }
      ],
      "source": [
        "criterion = nn.CrossEntropyLoss()\n",
        "optimizer = optim.Adam(model.parameters(), lr=0.0001)\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-25-bnn_1blk_50.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": "39fd1b6d-ff0e-4339-9be3-12a7226bcee7"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "Test set: Average loss: 0.0011, Accuracy: 4752/10000 (48%)\n",
            "\n",
            "Accuracy: tensor(47.5200)\n"
          ]
        }
      ],
      "source": [
        "# Load the model\n",
        "saved_model = BNN_1blk_50(25,10)\n",
        "saved_model.load_state_dict(torch.load('/content/drive/MyDrive/25-50-10/mnist-25-bnn_1blk_50.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 and 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": "7de8f69d-9e91-4d79-e5c1-c99d7382ee34"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "BNN_1blk_50(\n",
            "  (fc1): BinarizeLinear(in_features=25, out_features=50, bias=True)\n",
            "  (htanh1): Hardtanh(min_val=-1.0, max_val=1.0)\n",
            "  (bn1): BatchNorm1d(50, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
            "  (fc5): BinarizeLinear(in_features=50, 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": "1be81470-96b1-41ba-c24d-0eae07310480"
      },
      "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.1336,  0.1012,  0.1251, -0.1230,  0.1354, -0.1572, -0.0924, -0.0163,\n",
            "        -0.0464, -0.1586,  0.1535, -0.0255,  0.0747,  0.0768,  0.1284,  0.1876,\n",
            "        -0.1090,  0.0994,  0.0314,  0.1134, -0.0306, -0.1470,  0.1503,  0.1371,\n",
            "        -0.1184,  0.0495,  0.1747,  0.1315,  0.1212, -0.0095, -0.1251,  0.0118,\n",
            "        -0.0703,  0.1503, -0.0225, -0.1292, -0.0395, -0.1521, -0.0922, -0.1600,\n",
            "         0.0984,  0.0797, -0.1618,  0.1637, -0.0485,  0.0998, -0.1069, -0.0738,\n",
            "         0.1338, -0.1378], device='cuda:0')\n",
            "bn1.weight tensor([0.7610, 0.7738, 0.7782, 0.7681, 0.8001, 0.7877, 0.7724, 0.8461, 0.7656,\n",
            "        0.7888, 0.7452, 0.7236, 0.8147, 0.8032, 0.7517, 0.7863, 0.8373, 0.7567,\n",
            "        0.7544, 0.8213, 0.8380, 0.8524, 0.7331, 0.7989, 0.7405, 0.8009, 0.7349,\n",
            "        0.7667, 0.7752, 0.7986, 0.7581, 0.8238, 0.8249, 0.7386, 0.7646, 0.7481,\n",
            "        0.7380, 0.8855, 0.7198, 0.7616, 0.7640, 0.7984, 0.7644, 0.7751, 0.8254,\n",
            "        0.7787, 0.7922, 0.7968, 0.7459, 0.7972], device='cuda:0')\n",
            "bn1.bias tensor([-0.0650,  0.0076, -0.0889,  0.0273, -0.0351, -0.0267, -0.1076, -0.0080,\n",
            "        -0.0743, -0.0637,  0.0249,  0.0236,  0.0280,  0.0549,  0.0892, -0.0264,\n",
            "        -0.0132,  0.0801,  0.0058,  0.0807,  0.0752, -0.0150, -0.0243,  0.0597,\n",
            "        -0.0117,  0.0343,  0.0716, -0.0005, -0.0514,  0.0569, -0.0022, -0.0024,\n",
            "         0.0920,  0.0176,  0.0556,  0.0890,  0.1212, -0.1106, -0.0701, -0.0726,\n",
            "         0.1006,  0.1094, -0.0292, -0.0405, -0.0325, -0.1442,  0.0390,  0.0628,\n",
            "         0.0605,  0.0212], 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., -1.,  1., -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., -1.,  1.],\n",
            "        [-1., -1.,  1.,  1., -1., -1.,  1.,  1.,  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.,  1.,  1.,  1.,  1.,  1., -1., -1.,  1.,\n",
            "          1., -1.,  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.,  1.,  1., -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.,  1.,  1.],\n",
            "        [ 1.,  1.,  1.,  1., -1., -1., -1.,  1.,  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.,  1.,  1.,  1., -1., -1., -1.,  1.,  1.,\n",
            "          1., -1., -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., -1.,  1., -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., -1.,  1.],\n",
            "        [ 1., -1., -1.,  1., -1.,  1., -1.,  1.,  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., -1., -1.,  1., -1.,  1.,  1.,  1.,  1.,\n",
            "          1., -1., -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.,  1.,  1.,  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.,  1.,  1.],\n",
            "        [ 1.,  1.,  1.,  1., -1., -1., -1.,  1.,  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., -1.,  1., -1., -1., -1., -1., -1., -1.,\n",
            "          1.,  1., -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.,  1.,  1.,  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., -1.,  1.],\n",
            "        [ 1., -1., -1.,  1., -1., -1., -1.,  1., -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., -1., -1.,  1.,  1.,  1.,  1., -1.,  1.,\n",
            "          1., -1., -1., -1.,  1.,  1., -1.,  1.]], device='cuda:0')\n",
            "fc5.bias tensor([-0.1189, -0.1580,  0.0265,  0.1830, -0.0528,  0.1711,  0.0322, -0.0003,\n",
            "         0.0294, -0.0719], 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=(5, 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 (50x25)')  # 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": 848
        },
        "id": "cr39bpnhnGdP",
        "outputId": "0d14e227-8c51-4604-d741-393d9f71d5bc"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 500x1000 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAasAAAM/CAYAAABvef0RAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA0OElEQVR4nO3deXxU9b3/8feQECCBDAQCStkXi6K4QLkPIlVE2eRSQa8gooLeYhVQUXDBlrIouBQqIorVq6BYwKLiRamgorgEBbfihjtRRJCikEjCEpLv/YNf5ueQhdmS8znO6/l48KiZOTPnO5OBV8/kZD4B55wTAACG1fJ6AQAAHAmxAgCYR6wAAOYRKwCAecQKAGAesQIAmEesAADmESsAgHnECgBgHrFCjRs1apTatGkT823r16+f2AUZtnDhQgUCAeXl5SX0fs8++2yNHj06ofdpyapVq1S/fn39+9//9nopSBBiBUnSP/7xDwUCAS1fvrzcdSeeeKICgYBefvnlcte1atVKOTk5NbHEqBQVFWnq1Klau3ZtRNuvXbtWgUBAgUBAjz32WIXbnHrqqQoEAjr++ONjWtN9992nhQsXxnTbRMrNzdXzzz+vG2+8MXRZXl5e6PEf/mfp0qXl7mPTpk3q37+/6tevr6ysLF188cUxh+Gtt97SuHHj1LlzZ2VkZKhVq1YaOnSoPvvss3Lbjho1qsI1durUKWy7/v37q0OHDrrttttiWhPsSfV6AbChZ8+ekqTXX39dQ4YMCV1eUFCgDz/8UKmpqcrNzdUZZ5wRum7Lli3asmWLLrjggqj29eCDD6q0tDQxC69EUVGRpk2bJknq1atXxLerW7euFi9erIsuuijs8ry8PK1bt05169aNeU333XefmjRpolGjRkV8m4svvlgXXHCB6tSpE/N+D/eXv/xFZ555pjp06FDuuuHDh+vss88Ou6xHjx5hX3/77bc67bTTFAwGNXPmTO3Zs0ezZs3SBx98oA0bNigtLS2q9dxxxx3Kzc3V+eefry5dumj79u2aN2+eTjnlFL355pvl/s9BnTp19D//8z9hlwWDwXL3+4c//EETJ07UtGnT1KBBg6jWBHuIFSRJzZs3V9u2bfX666+HXf7GG2/IOafzzz+/3HVlX5eFLlK1a9eOb7HV6Oyzz9aKFSu0c+dONWnSJHT54sWL1axZM3Xs2FG7du2q9nUUFhYqIyNDKSkpSklJSdj97tixQytXrtT9999f4fWnnHJKuVAfbubMmSosLNQ777yjVq1aSZK6d++uPn36aOHChbr88sujWtN1112nxYsXh0Vu2LBhOuGEE3T77beXO9JNTU094hol6bzzztNVV12lZcuW6bLLLotqTbCHtwER0rNnT7333nvau3dv6LLc3Fx17txZAwYM0Jtvvhl2RJSbm6tAIKBTTz01dNljjz2mrl27ql69esrKytIFF1ygLVu2hO2nop9Z/fDDD7r44ouVmZmphg0bauTIkdq4caMCgUCFb51t3bpVgwcPVv369ZWdna2JEyeqpKRE0qGjoOzsbEnStGnTQm8VTZ069YjPwTnnnKM6depo2bJlYZcvXrxYQ4cOrTAcCxYsUO/evdW0aVPVqVNHxx13nObPnx+2TZs2bfTRRx/plVdeCa2n7Iiv7OdSr7zyisaMGaOmTZuqRYsWYdeV/czqpZdeUq1atfTnP/+53PoCgUC5/R5u5cqVOnjwoM4666xKtyksLNSBAwcqvf7JJ5/Uf/7nf4ZCJUlnnXWWjjnmGP3jH/+QJDnndMYZZyg7O1s7duwIbXfgwAGdcMIJat++vQoLCyVJOTk55Y7GOnbsqM6dO2vTpk0VrqGkpEQFBQVVPtamTZuqS5cu+t///d8qt4M/ECuE9OzZU8XFxVq/fn3ostzcXOXk5CgnJ0f5+fn68MMPw67r1KmTGjduLEmaMWOGLrnkEnXs2FF//etfNX78eK1Zs0annXaadu/eXel+S0tLNWjQIC1ZskQjR47UjBkztG3bNo0cObLC7UtKStSvXz81btxYs2bN0umnn67Zs2frgQcekCRlZ2eH/tEeMmSIFi1apEWLFuncc8894nOQnp6uc845R0uWLAldtnHjRn300Ue68MILK7zN/Pnz1bp1a918882aPXu2WrZsqTFjxujee+8NbTNnzhy1aNFCnTp1Cq3nj3/8Y9j9jBkzRh9//LH+/Oc/66abbqpwX71799aYMWN022236d1335Ukbdu2TVdddZXOOussXXHFFVU+vnXr1qlx48Zq3bp1hddPmzZN9evXV926dfWb3/xGzz//fNj1W7du1Y4dO9StW7dyt+3evbvee+89SVIgENDDDz+sffv2ha1pypQp+uijj7RgwQJlZGRUuk7nnL7//vuwo9syRUVFyszMVDAYVFZWlsaOHas9e/ZUeD9du3bVunXrKt0PfMQB/89HH33kJLlbbrnFOedccXGxy8jIcI888ohzzrlmzZq5e++91znnXEFBgUtJSXGjR492zjmXl5fnUlJS3IwZM8Lu84MPPnCpqalhl48cOdK1bt069PWTTz7pJLk5c+aELispKXG9e/d2ktyCBQvCbivJTZ8+PWw/J598suvatWvo63//+99OkpsyZUpEj/3ll192ktyyZcvcs88+6wKBgPvmm2+cc85df/31rl27ds45504//XTXuXPnsNsWFRWVu79+/fqFblOmc+fO7vTTTy+37YIFC5wk17NnT3fw4MEKr9u8eXPossLCQtehQwfXuXNnt2/fPjdw4ECXmZnpvv766yM+zp49e4Y9T2W+/vpr17dvXzd//ny3YsUKN2fOHNeqVStXq1Yt9+yzz4a2e+utt5wk9+ijj5a7j+uvv95Jcvv27Qtd9re//c1Jco899ph78803XUpKihs/fvwR17lo0SInyT300ENhl990003uxhtvdI8//rhbsmRJ6PVw6qmnuuLi4nL3M3PmTCfJff/990fcJ2zjyAohxx57rBo3bhz6WdTGjRtVWFgYOtsvJydHubm5kg79LKukpCT086qnnnpKpaWlGjp0qHbu3Bn6c9RRR6ljx44VnklYZtWqVapdu3bYqdS1atXS2LFjK73N4UcQv/3tb/XVV1/F9sAP07dvX2VlZWnp0qVyzmnp0qUaPnx4pdvXq1cv9N/5+fnauXOnTj/9dH311VfKz8+PeL+jR4+O6OdT6enpWrhwoTZt2qTTTjtNK1eu1F133RX2tlxlfvjhBzVq1Kjc5a1atdLq1at1xRVXaNCgQbrmmmv03nvvKTs7WxMmTAhtV/YWcUUnfJSdfPLzt5Evv/xy9evXT1dddZUuvvhitW/fXjNnzqxyjZ988onGjh2rHj16lDu6vu2223T77bdr6NChuuCCC7Rw4ULNmDFDubm5euKJJ8rdV9lj3blzZ5X7hH3ECiGBQEA5OTmhn03l5uaqadOmobPGfh6rsv8ti9Xnn38u55w6duyo7OzssD+bNm0K+7nF4b7++msdffTRSk9PD7u8orPVpEP/KJb9TKpMo0aNEnbiQ+3atXX++edr8eLFevXVV7Vly5ZK3wKUDj0XZ511ljIyMtSwYUNlZ2fr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fvx+FbkSDSv9Uvn5+crMzKxyW46sAADmESsAgHnECgBgXtyxKigo0NNPP61NmzYlYj0AAJQTdayGDh2qefPmSZL27t2rbt26aejQoerSpYuefPLJhC8QAICoY/Xqq6/qt7/9rSRp+fLlcs5p9+7dmjt3rm699daELxAAgKhjlZ+fr6ysLEnSqlWrdN555yk9PV0DBw7U559/nvAFAgAQdaxatmypN954Q4WFhVq1apX69u0rSdq1a5fq1q2b8AUCAJAa7Q3Gjx+vESNGqH79+mrdurV69eol6dDbgyeccEKi1wcAQPSxGjNmjP7jP/5D33zzjfr06aNatQ4dnLVr104zZsxI+AIBAIj6bcDp06fr2GOP1ZAhQ1S/fv3Q5b1799aLL76Y0MUBACDFEKtp06Zpz5495S4vKirStGnTErIoAAB+LupYOecUCATKXb5x48bQWYIAACRSxD+zatSokQKBgAKBgI455piwYJWUlGjPnj264oorqmWRAIDkFvGIkEceeUTOOV122WWaM2eOgsFg6Lq0tDS1adNGPXr0iGinZSNCuvdbqdTaGbGtHDWOMR3wAy9fa37mxd/vg8WF2rB6YEQjQiI+sho5cqQkqW3btsrJyVHt2rVjWhwAANGKKFYFBQWh6p188snau3ev9u7dW+G2R6ojAADRiihWjRo10rZt29S0aVM1bNiwwhMsyk68KCkpSfgiAQDJLaJYvfTSS6Ez/V5++eVqXRAAAIeLKFann356hf8NAEBNiPrjliRp9+7d2rBhg3bs2KHS0tKw6y655JKELAwAgDJRx+qZZ57RiBEjtGfPHmVmZob9/CoQCBArAEDCRf0JFhMmTNBll12mPXv2aPfu3dq1a1foz48//lgdawQAJLmoY7V161ZdffXVSk9Pr471AABQTtSx6tevn95+++3qWAsAABWK+mdWAwcO1PXXX6+PP/5YJ5xwQrlPsvjd736XsMUBACDFEKvRo0dLOjTX6nD8UjAAoDpEHavDT1UHAKC6Rf0zKwAAalrER1bXXXddhZcHg0Edc8wxOvfcc1WnTp2ELQwAgDIRz7M644wzKrx89+7d+uKLL9SsWTO99NJLatWq1RHvq2ye1eO12is9kBLdin0u3lk7Xs5m8utMKr+uW/Lv2v26bq8l2yyuaplnVdUH2BYUFGjEiBG66aabtHjx4shXCgBABBLyM6vMzExNnjxZubm5ibg7AADCJOwEiyZNmvBxSwCAapGwWL355ptq3759ou4OAICQiH9m9f7771d4eX5+vt555x3NnDlTU6ZMSdjCAAAoE3GsTjrpJAUCAVV08mCTJk103XXXacyYMQldHAAAUhSx2rx5c4WXZ2ZmqlGjRglbEAAAh4s4Vq1bt67OdQAAUCk+bgkAYB6xAgCYR6wAAOYRKwCAeVHHql27dvrhhx/KXb579261a9cuIYsCAODnoo5VXl5ehdOA9+/fr61btyZkUQAA/FzEp66vWLEi9N+rV69WMBgMfV1SUqI1a9aoTZs2Ue18dp+5Sq2dEdVtyvh1DAAjI2r+9n59rUj+Xns8/Pq4/fr30ytFrkTDItw24lgNHjxYkhQIBDRy5Miw62rXrq02bdpo9uzZkd4dAAARizhWpaWlkqS2bdvqrbfeUpMmTaptUQAA/FzEsSpT2ccuAQBQXaKO1fTp06u8/s9//nPMiwEAoCJRx2r58uVhXxcXF2vz5s1KTU1V+/btiRUAIOGijtV7771X7rKCggKNGjVKQ4YMSciiAAD4uYR8gkVmZqamTZumyZMnJ+LuAAAIk7CPW8rPz1d+fn6i7g4AgJCo3wacO3du2NfOOW3btk2LFi3SgAEDErYwAADKRB2ru+66K+zrWrVqKTs7WyNHjtSkSZMStjAAAMrwe1YAAPPi+pnVli1btGXLlkStBQCACkUdq4MHD2ry5MkKBoNq06aN2rRpo2AwqD/96U8qLi6ujjUCAJJc1G8DXnXVVXrqqad05513qkePHpKkN954Q1OnTtUPP/yg+fPnJ3yRAIDkFnWsFi9erKVLl4ad+delSxe1bNlSw4cPjypWE164WumBlGiXICl5R0bEw8+P28vxJF7uGzXPr/+2+PG1drC4UFo9MKJto34bsE6dOhXOrWrbtq3S0tKivTsAAI4o6liNGzdOt9xyi/bv3x+6bP/+/ZoxY4bGjRuX0MUBACDF+NmAa9asUYsWLXTiiSdKkjZu3KgDBw7ozDPP1Lnnnhva9qmnnkrcSgEASSvqWDVs2FDnnXde2GUtW7ZM2IIAADhc1LFasGBBdawDAIBKRf0zq969e2v37t3lLi8oKFDv3r0TsSYAAMJEHau1a9fqwIED5S7ft2+fXnvttYQsCgCAn4v4bcD3338/9N8ff/yxtm/fHvq6pKREq1at0q9+9avErg4AAEURq5NOOkmBQECBQKDCt/vq1aune+65J6GLAwBAiiJWmzdvlnNO7dq104YNG5SdnR26Li0tTU2bNlVKSmyfRgEAQFUijlXr1q0lSaWlpdW2GAAAKhL1qeuPPvpolddfcsklMS8GAICKRB2ra665Juzr4uJiFRUVKS0tTenp6cQKAJBwUZ+6vmvXrrA/e/bs0aeffqqePXtqyZIl1bFGAECSi2tScJmOHTvq9ttvL3fUBQBAIkT9NmCld5Saqu+++y5Rd3dEzI3xl3i/X17OGPLy+52sr3O/Pudezk77pYs6VitWrAj72jmnbdu2ad68eTr11FMTtjAAAMpEHavBgweHfR0IBJSdna3evXtr9uzZiVoXAAAhUceK37MCANS0mE+w2Llzp3bu3JnItQAAUKGoYrV7926NHTtWTZo0UbNmzdSsWTM1adJE48aNq3BsCAAAiRDx24A//vijevTooa1bt2rEiBE69thjJR36BPaFCxdqzZo1WrdunRo1alRtiwUAJKeIYzV9+nSlpaXpyy+/VLNmzcpd17dvX02fPl133XVXwhcJAEhuEb8N+PTTT2vWrFnlQiVJRx11lO68804tX748oYsDAECKIlbbtm1T586dK73++OOPDxvICABAokQcqyZNmigvL6/S6zdv3qysrKxErAkAgDARx6pfv3764x//qAMHDpS7bv/+/Zo8ebL69++f0MUBACBFeYJFt27d1LFjR40dO1adOnWSc06bNm3Sfffdp/3792vRokXVuVYAQJKKOFYtWrTQG2+8oTFjxmjSpElyzkk69HFLffr00bx589SyZctqWygAIHlF9XFLbdu21XPPPaddu3bp888/lyR16NCBn1UBAKpVTCNCGjVqpO7duyd6Lb7h17ENjDbxHy9Ho8TDr39H4uXncTTxiPVxF7kSDYtw24QMXwQAoDoRKwCAecQKAGAesQIAmEesAADmESsAgHnECgBgHrECAJhHrAAA5hErAIB5xAoAYB6xAgCYR6wAAOYRKwCAecQKAGBeTPOsEmV2n7lKrZ0R023jmRvj15kx8fJy1o6X843ilayzmZKVl69zXmuV48gKAGAesQIAmEesAADmESsAgHnECgBgHrECAJhHrAAA5hErAIB5xAoAYB6xAgCYR6wAAOYRKwCAecQKAGAesQIA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Rx55RBkZGVq/fr3uvPNOTZ8+XS+88ELYNpMnT9Z5552njRs3asSIEbrgggu0adOmiO4/JydHc+bMUWZmprZt26Zt27Zp4sSJca+7qKhIs2bN0qJFi/Tqq6/qm2++qfR+7777bvXo0UOjR48OraFly5aaPHmyPv74Yz333HPatGmT5s+fryZNmsS9NqC68DYgklaXLl00ZcoUSVLHjh01b948rVmzRn369Altc/755+v3v/+9JOmWW27RCy+8oHvuuUf33XffEe8/LS1NwWBQgUBARx11VMLWXVxcrPvvv1/t27eXJI0bN07Tp0+vcNtgMKi0tDSlp6eHreGbb77RySefrG7dukmS2rRpk7D1AdWBIyskrS5duoR9ffTRR2vHjh1hl/Xo0aPc15EeWVWX9PT0UKikitd9JFdeeaWWLl2qk046STfccIPWrVuX6GUCCUWskLRq164d9nUgEFBpaeRja8o+ePPnH69ZXFwc01oyMzOVn59f7vKyn4f9/KSJitYd7Ud8DhgwQF9//bWuvfZafffddzrzzDMT8hYlUF2IFVCFN998s9zXxx57rCQpOztbksJObjj8FPO0tDSVlBx51s+vf/1rffvtt/r+++/DLn/33XdVt25dtWrVKpblV7mG7OxsjRw5Uo899pjmzJmjBx54IOZ9ANWNn1kBVVi2bJm6deumnj176u9//7s2bNighx56SJLUoUMHtWzZUlOnTtWMGTP02Wefafbs2WG3b9Omjfbs2aM1a9boxBNPVHp6utLT08vtp1+/fvr1r3+t4cOH69Zbb9VRRx2ld999V3/60590zTXXKCUlJebH0KZNG61fv155eXmqX7++srKyNHXqVHXt2lWdO3fW/v379eyzz4YiDFjEkRVQhWnTpmnp0qXq0qWLHn30US1ZskTHHXecpENvxy1ZskSffPKJunTpojvuuEO33npr2O1zcnJ0xRVXaNiwYcrOztadd95Z4X5SU1P1/PPPq1WrVho+fLiOP/54TZkyRddcc41uueWWuB7DxIkTlZKSouOOO07Z2dn65ptvlJaWpkmTJqlLly467bTTlJKSoqVLl8a1H6A6Mc8KqEQgENDy5cv56CLAAI6sAADmESsAgHmcYAFUgnfIATs4sgIAmEesAADmESsAgHnECgBgHrECAJhHrAAA5hErAIB5xAoAYN7/AdMMQbEWhQCSAAAAAElFTkSuQmCC\n"
          },
          "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=(10, 2))  # 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 (10x50)')  # 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": 232
        },
        "id": "QqY2XcnSoDw0",
        "outputId": "8fb8872b-0e6f-48c8-b335-fed62f5eb06b"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1000x200 with 1 Axes>"
            ],
            "image/png": "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vqVMYmKipk2bphMnTuijjz5Ss2bN1Lp1a0mXxz5YlqXNmzdXeNXAm18a6c1Ztipz33336eWXX9bMmTN10003qWPHjhWu9+2336pfv35q3769XnjhBcXGxiooKEh///vftWDBAqfJDK7lyj+6r6aoqMgx1fO3336rwsJCl+BXkUaNGnkU8KKiohQcHKycnByXZWVtV45dOXDggCO4fvnll1e9elVebGysJOncuXNq3ry5brjhBqd+ruy7rLbyyva1/AxxAFAbEVwA4Arlv89l165dmjx5smNZt27dFBwcrB07dmjv3r264447HMvatGkjY4xatWqldu3audVny5YttX37dpc/vo8ePVrt/fD0/7AnJSWpRYsW2rFjh55//vlK13v77bdVVFSkjRs3Ot2qVdGtcd78v/4zZsxQRkaG5s+fryeffFJPPfWUFi9efM3t2rdvrzfffLPa/fr5+enGG2/UJ5984rJs7969at26terXr+9oKygo0NixY9WxY0clJiZq3rx5GjZsmNOMZJUpu/Wv7Oraz372M8XExFTY9759+9SlSxeX9szMTEVHR191emcAqA24VQwArtC9e3eFhIToT3/6k06cOOF0xSU4OFg333yzXnrpJRUUFDh9f8vw4cPl7++v1NRUl1uRjDFX/WLCgQMHqri4WK+++qqjrbS01GlWLneVBaCrzWZ2NZZlafHixZoxY4ZGjx5d6XplV3/K73NeXp5WrFjhsm5YWFi16ylv7969mj9/viZPnqwpU6Zo2rRpWrJkiXbu3HnNbXv06KHz5897NB7onnvu0f79+50CxOHDh7Vt2zbde++9Tus++eSTOn78uF577TW98MILiouLU3JystPtXld+6710eQaxP/7xj0pISHBcaZEufzfLO++84zTF9tatW/XPf/7TpW9J+vTTT12+xBIAaiOuuADAFYKCgnTLLbfoww8/VHBwsLp16+a0PDExUenp6ZKcv3iyTZs2mjVrllJSUpSVlaWhQ4eqfv36yszM1IYNGzR+/HhNnTq1wj6HDh2qW2+9VVOmTNHRo0fVvn17bdy4UefOnZNUvSsV9erVU8eOHfXnP/9Z7dq1U1RUlDp37qzOnTtX+TmGDBmiIUOGXHWdAQMGKCgoSHfeeacefPBBXbhwQa+++qoaN27scktTt27dtGzZMs2aNUtt27ZV48aN1bdvX7f269KlS0pOTlZ8fLxmz54t6fI0wm+//bbGjh2rL7/8UmFhYZVuP3jwYAUEBOgf//iH05c1StKqVat07NgxFRYWSpI++OADzZo1S5I0evRoxxTKEyZM0KuvvqrBgwdr6tSpCgwM1AsvvKAmTZo4Dabftm2bli5dqhkzZujmm2+WdPk7b/r06aPp06dr3rx5kqQnnnjCcctds2bNlJWVpVdeeUUFBQVatGiRU41PP/201q1bp1/+8peaNGmSLly4oD/84Q+68cYbNXbsWKd1T58+rS+++OKqkzwAQK3huwnNAMC+UlJSjCSTmJjosmz9+vVGkqlfv77L1L3GXJ7aOCkpyYSFhZmwsDDTvn1788gjj5jDhw871rlyOmRjLk+ze99995n69eubyMhIM2bMGLNr1y4jyaxdu9Zp27CwMJd+Z8yYYa78WN+9e7fp1q2bCQoKuubUyOWnQ76aiqZD3rhxo0lISDAhISEmLi7OPP/88+aPf/yjyzTGp06dMoMHDzb169c3khxTI5dNebx//36X/q6cDvnxxx83/v7+Zu/evU7rffLJJyYgIMA8/PDDV63fGGPuuusu069fvwr3TVKFP9u3b3daNzs729xzzz0mIiLChIeHm1/96lfmyJEjjuX5+fmmZcuW5uabbzbFxcVO2z7++OPGz8/P7NmzxxhjzOrVq02vXr1MTEyMCQgIMNHR0WbYsGHm008/rbD+r776ygwYMMCEhoaaBg0amFGjRplTp065rLds2TITGhpq8vPzr3lMAMDuLGM8mFoFAFCj3nrrLQ0bNkwfffSRevbs6ety/mN8+OGH6tOnj7755hvFx8f7upwa07VrV/Xp00cLFizwdSkA4DGCCwDYxMWLF51m1SopKdGAAQP0ySef6NSpU27NuIVrGzRokJo3b+40rug/yZYtW3TPPffou+++q9L0ywBgdwQXALCJ3/72t7p48aJ69OihoqIirV+/Xrt379acOXOUkpLi6/IAAPApggsA2MTq1auVnp6uo0eP6tKlS2rbtq0efvhhTZw40delAQDgcwQXAAAAALbH97gAAAAAsD2ffI9LaWmpTp48qfr163v1W5QBAAAA1C7GGP3www9q1qyZ/Pwqv67ik+By8uRJxcbG+qJrAAAAADaUnZ2t5s2bV7rcJ8Glfv36kqQVViuFWu7frZbef7G3S7puprz/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emxZlkpLS6u8vZ/f5V8jxhhHW3FxcbVqiYiIUF5enkt72fiZ8gPuK6q7fA1VMWjQIB07dkyPP/64Tp48qX79+nnlNjYAQM0guAAArurjjz92edyhQwdJUkxMjCQ5DYy/ctrioKAglZSUXLOfn//85/r+++/1r3/9y6n9s88+U0hIiFq0aFGd8q9aQ0xMjJKTk/XGG29o4cKFWr58ebX7AADULMa4AACuat26derevbuSkpL0pz/9Sfv27dP//u//SpLatm2r2NhYzZw5U7Nnz9Y///lPpaenO20fFxenCxcuaOvWrbrpppsUGhqq0NBQl34GDhyon//85xo5cqRmzZqlpk2b6rPPPtMzzzyjSZMmyd/fv9r7EBcXp7179yorK0vh4eGKiorSzJkz1a1bN3Xq1ElFRUV65513HIEMAGA/XHEBAFxVamqq1q5dq4SEBL3++utas2aNOnbsKOnyLVtr1qzRN998o4SEBD3//POaNWuW0/aJiYl66KGH9Otf/1oxMTGaN29ehf0EBATovffeU4sWLTRy5Eh17txZM2bM0KRJk/Tcc895tA9Tp06Vv7+/OnbsqJiYGB0/flxBQUFKSUlRQkKCevXqJX9/f61du9ajfgAANccy7t4UDACoMyzL0oYNGxzfiQIAgK9wxQUAAACA7RFcAAAAANgeg/MBAJXibmIAgF1wxQUAAACA7RFcAAAAANgewQUAAACA7RFcAAAAANgewQUAAACA7RFcAAAAANgewQUAAACA7RFcAAAAANje/wNK0T/Rvos3xwAAAABJRU5ErkJggg==\n"
          },
          "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 34319 71005\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 43% 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 10 images for visualization (adjust as needed)\n",
        "    selected_images = image_files[:10]\n",
        "\n",
        "    # Create a 1x5 subplot for visualization\n",
        "    fig, axes = plt.subplots(1, 10, 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 = '/content/drive/MyDrive/25-50-10/Images/25-50-10_0'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "WITm1zo2glJc",
        "outputId": "f3dc990f-e2b3-4a0c-8274-8ec49e19e89b"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaK0lEQVR4nO3de3BU5f0H4G9AE0JQkIuAVEAo0IpVQHQctSJYRBSpUoiXVrmpoEWpo1hHa/nVtlQLVZhRtJUKowZUaIGqo9RbLZVqqRfQUkcUFERlxAtQBC/h/P5wyBjhSBKWZHfzPDOZIS97su9597M7u5/dPacgSZIkAAAAAACAnTSo6wkAAAAAAEC2UqIDAAAAAEAKJToAAAAAAKRQogMAAAAAQAolOgAAAAAApFCiAwAAAABACiU6AAAAAACkUKIDAAAAAEAKJToAAAAAAKRQogMAAAAAQIqcK9FnzZoVBQUF8e9//7uup7JX3XbbbTFs2LBo3759FBQUxIgRI+p6SnmpPuRp7dq18Ytf/CKOPvroOOCAA6Jly5Zx4oknxmOPPVbXU8tL9SFTW7dujdGjR8dhhx0WTZs2jSZNmsQRRxwR06ZNi88++6yup5dX6kOevuof//hHFBQUREFBQWzYsKGup5N36kumdmToqz833HBDXU8tr9SXPEVErF+/PsaMGRPt2rWLRo0aRceOHWP06NF1Pa28Ux8ytWMf037Kysrqeop5oz7kKSJi48aNcdVVV0WXLl2iuLg4OnToEKNHj441a9bU9dTyTn3J1Pr162PkyJFx4IEHRnFxcfTq1Svmzp1b19PKafUlO9XpMj/66KO46KKLolWrVlFSUhJ9+/aN559/vvYmWwP71PUE2LUbb7wxNm/eHEcffXS88847dT0dctjChQvjxhtvjDPOOCOGDx8en3/+edx1113Rv3//uPPOO2PkyJF1PUVyzNatW+M///lPnHrqqdGxY8do0KBBLFmyJC6//PJ49tlnY/bs2XU9RXLU9u3b49JLL42SkpLYsmVLXU+HHNe/f/84//zzK4317NmzjmZDLlu7dm0cd9xxERExduzYaNeuXbz99tvxr3/9q45nRi464YQT4u67795p/Oabb45ly5bFSSedVAezIldt3749+vfvHytWrIhLLrkkunbtGq+99lpMnz49Fi1aFP/9739jv/32q+tpkkM2bdoUxx9/fKxfvz7Gjx8fbdq0ifvvvz9KS0ujrKwszj333LqeIlmsql3m9u3b47TTTotly5bFhAkTomXLljF9+vQ48cQT47nnnosuXbrU4qyrTomepZ566qmKd26aNGlS19Mhh/Xt2zfWrFkTLVu2rBgbO3Zs9OjRI37+858r0am25s2bxzPPPFNpbOzYsdG0adO45ZZb4qabboo2bdrU0ezIZX/4wx9i7dq1ccEFF8S0adPqejrkuK5du8aPfvSjup4GeWDMmDGxzz77xNKlS6NFixZ1PR1yXKdOnaJTp06VxrZu3RqXXHJJ9OvXz3MoquWZZ56JpUuXxi233BI//vGPK8a7desWo0aNisceeyzOPPPMOpwhueb3v/99vPbaa/H4449Hv379IiLi4osvjmOOOSauuOKKGDp0aBQWFtbxLMlWVe0y582bF0uWLIm5c+fG0KFDIyKitLQ0unbtGhMnTszaD+bl3OFcdmXEiBHRpEmTWLNmTQwaNCiaNGkS7dq1i1tvvTUiIl566aXo169flJSURIcOHXa6MT744IO48sor4zvf+U40adIk9t9//xg4cGAsW7Zsp+t68803Y/DgwVFSUhIHHnhgXH755bFo0aIoKCiIv/3tb5Uu++yzz8Ypp5wSTZs2jcaNG0efPn3i6aefrtI+dejQIQoKCmq2IOyRfMtT9+7dKxXoERFFRUVx6qmnxltvvRWbN2+u5gpRXfmWqTQdO3aMiC++lsXek695+uCDD+JnP/tZXH/99dGsWbNqrws1l6+ZiviimNq2bVv1FoQ9km95euWVV+Lhhx+OCRMmRIsWLWLbtm0OXVbL8i1Tu/LAAw/E5s2b44c//GGNtqfq8i1PmzZtioiI1q1bVxpv27ZtREQUFxdXeW2omXzL1OLFi6NVq1YVBXpERIMGDaK0tDTefffdeOqpp2qwSuxKvmUnoupd5rx586J169YxZMiQirFWrVpFaWlpLFy4MD755JMqXV9ty4sSPSKivLw8Bg4cGAcffHD89re/jY4dO8a4ceNi1qxZccopp0Tv3r3jxhtvjP322y/OP//8WL16dcW2q1atigULFsSgQYPipptuigkTJsRLL70Uffr0ibfffrviclu2bIl+/frFY489Fpdddllce+21sWTJkvjpT3+603yeeOKJOOGEE2LTpk0xceLEmDRpUnz00UfR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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_1'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "iwucyOjZgn0w",
        "outputId": "f2fbe151-8d7f-48a1-bb92-f3aa074a8355"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaHUlEQVR4nO3de3BU5f0H4G9AE0JQkIuAVEAo0IpVQHQctSLYiChSpRAvrXJTQYtSR7GO1vKrbakWqjCjaCsVRg2o0AJVR6m3WirVUi+gpY4oKIjKiBegCF7C+f3hkDHCkQSW7GbzPDOZIS97su9589nN7md3zylIkiQJAAAAAABgBw2yPQEAAAAAAMhVSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASKFEBwAAAACAFEp0AAAAAABIoUQHAAAAAIAUSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASFHnSvSZM2dGQUFB/Pvf/872VPaq2267LYYOHRrt27ePgoKCGD58eLanlJfqQ57WrFkTv/jFL+Loo4+OAw44IFq2bBknnnhiPPbYY9meWl6qD5nasmVLjBo1Kg477LBo2rRpNGnSJI444oiYOnVqfPbZZ9meXl6pD3n6qn/84x9RUFAQBQUFsX79+mxPJ+/Ul0xtz9BXv2644YZsTy2v1Jc8RUSsW7cuRo8eHe3atYtGjRpFx44dY9SoUdmeVt6pD5navo9pX+Xl5dmeYt6oD3mKiNiwYUNcddVV0aVLlyguLo4OHTrEqFGjYvXq1dmeWt6pL5lat25djBgxIg488MAoLi6OXr16xZw5c7I9rTqtvmSnJl3mRx99FBdddFG0atUqSkpKom/fvvH888/X3mR3wz7ZngA7d+ONN8amTZvi6KOPjnfeeSfb06EOW7BgQdx4441xxhlnxLBhw+Lzzz+Pu+66K0pLS+POO++MESNGZHuK1DFbtmyJ//znP3HqqadGx44do0GDBrF48eK4/PLL49lnn41Zs2Zle4rUUdu2bYtLL700SkpKYvPmzdmeDnVcaWlpnH/++VXGevbsmaXZUJetWbMmjjvuuIiIGDNmTLRr1y7efvvt+Ne//pXlmVEXnXDCCXH33XfvMH7zzTfH0qVL46STTsrCrKirtm3bFqWlpbF8+fK45JJLomvXrvHaa6/FtGnTYuHChfHf//439ttvv2xPkzpk48aNcfzxx8e6deti3Lhx0aZNm7j//vujrKwsysvL49xzz832FMlh1e0yt23bFqeddlosXbo0xo8fHy1btoxp06bFiSeeGM8991x06dKlFmddfUr0HPXUU09VvnLTpEmTbE+HOqxv376xevXqaNmyZeXYmDFjokePHvHzn/9ciU6NNW/ePJ555pkqY2PGjImmTZvGLbfcEjfddFO0adMmS7OjLvvDH/4Qa9asiQsuuCCmTp2a7elQx3Xt2jV+9KMfZXsa5IHRo0fHPvvsE0uWLIkWLVpkezrUcZ06dYpOnTpVGduyZUtccskl0a9fP4+hqJFnnnkmlixZErfcckv8+Mc/rhzv1q1bjBw5Mh577LE488wzszhD6prf//738dprr8Xjjz8e/fr1i4iIiy++OI455pi44oorYsiQIVFYWJjlWZKrqttlzp07NxYvXhxz5syJIUOGREREWVlZdO3aNSZMmJCzb8yrc4dz2Znhw4dHkyZNYvXq1TFw4MBo0qRJtGvXLm699daIiHjppZeiX79+UVJSEh06dNjhl/HBBx/ElVdeGd/5zneiSZMmsf/++8eAAQNi6dKlO1zXm2++GYMGDYqSkpI48MAD4/LLL4+FCxdGQUFB/O1vf6ty2WeffTZOOeWUaNq0aTRu3Dj69OkTTz/9dLX2qUOHDlFQULB7C8Ieybc8de/evUqBHhFRVFQUp556arz11luxadOmGq4QNZVvmUrTsWPHiPjiY1nsPfmapw8++CB+9rOfxfXXXx/NmjWr8bqw+/I1UxFfFFNbt26t2YKwR/ItT6+88ko8/PDDMX78+GjRokVs3brVoctqWb5lamceeOCB2LRpU/zwhz/cre2pvnzL08aNGyMionXr1lXG27ZtGxERxcXF1V4bdk++ZWrRokXRqlWrygI9IqJBgwZRVlYW7777bjz11FO7sUrsTL5lJ6L6XebcuXOjdevWMXjw4MqxVq1aRVlZWSxYsCA++eSTal1fbcuLEj0ioqKiIgYMGBAHH3xw/Pa3v42OHTvG2LFjY+bMmXHKKadE796948Ybb4z99tsvzj///Fi1alXltitXroz58+fHwIED46abborx48fHSy+9FH369Im333678nKbN2+Ofv36xWOPPRaXXXZZXHvttbF48eL46U9/usN8nnjiiTjhhBNi48aNMWHChJg4cWJ89NFH0a9fPx/9rAPqQ57efffdaNy4cTRu3Hi3tqdm8jFTn376aaxfvz7WrFkT8+bNi8mTJ0eHDh3im9/85p4vGF8rH/N03XXXRZs2bWL06NF7vkDUWD5maubMmVFSUhLFxcVx6KGH5uw7WvJRPuVp+zlkWrduHSeddFIUFxdHcXFxDBgwIN54443MLBi7lE+Z2pny8vIoLi6uUiaw9+RTnnr37h0lJSVx3XXXxRNPPBFr166Np556Kq666qo46qij4nvf+17mFo5U+ZSpTz75ZKcvvmzvDZ577rndXSZ2Ip+yUxMvvPBC9OrVKxo0qFpLH3300fHxxx/Hq6++mrHryqikjpkxY0YSEcmSJUsqx4YNG5ZERDJx4sTKsQ8//DApLi5OCgoKknvvvbdy/JVXXkkiIpkwYULl2NatW5OKiooq17Nq1aqkqKgouf766yvHfve73yURkcyfP79ybMuWLcm3vvWtJCKSJ598MkmSJNm2bVvSpUuXpH///sm2bdsqL/vxxx8nhxxySFJaWlqjfS4pKUmGDRtWo22onvqYpyRJkhUrViSNGjVKzjvvvBpvy9erT5maPXt2EhGVX717906WLVtWrW2pnvqSp6VLlyYNGzZMFi5cmCRJkkyYMCGJiOS9997b5bbUTH3J1LHHHptMmTIlWbBgQXLbbbclhx12WBIRybRp03a9SFRbfcjTZZddlkRE0qJFi+SUU05J7rvvvmTSpElJkyZNks6dOyebN2+u3mJRLfUhU1/1/vvvJ4WFhUlZWVmNtmPX6kueHnzwwaRt27ZVHpf3798/2bRp064XiRqpD5m69NJLkwYNGiRvvPFGlfGzzz47iYhk7NixX7s9O1cfsvNVX9dllpSUJCNHjtxh/KGHHkoiInnkkUdqdF21JW/eiR4RccEFF1T+u1mzZtGtW7coKSmJsrKyyvFu3bpFs2bNYuXKlZVjRUVFla9+VFRUxPvvvx9NmjSJbt26VTkz7COPPBLt2rWLQYMGVY41atQoLrzwwirzePHFF2PFihVx7rnnxvvvvx/r16+P9evXx+bNm+Okk06Kv//977Ft27aM7z+Zla95+vjjj2Po0KFRXFwcN9xwQ/UXhD2Wb5nq27dvPProozFnzpwYM2ZM7Lvvvk4GWYvyKU+XXXZZDBgwIE4++eTdWwwyIp8y9fTTT8e4ceNi0KBBMWbMmHjuuefisMMOi2uuuSa2bNmyewtEjeRLnv73v/9FRESbNm3ioYceirKysrjyyivjjjvuiNdff90nHGpRvmTqq+bOnRuffvqpQ7nUsnzKU6tWraJnz57x61//OubPnx//93//F4sWLXLuq1qWL5m64IILomHDhlFWVhaLFy+O119/PX7zm9/EvHnzIiI8jtoL8iU7NbFly5YoKiraYbxRo0aV/5+L8ubEoo0aNYpWrVpVGWvatGl84xvf2OF4PE2bNo0PP/yw8vtt27bF1KlTY9q0abFq1aqoqKio/L8vnzzozTffjM6dO+/w87566IIVK1ZERMSwYcNS57thw4Y44IADqrl31LZ8zVNFRUWcffbZsXz58nj44YfjoIMO2uU2ZEY+Zqp169aVx18cMmRITJw4MUpLS2PFihVOirWX5VOe7rvvvli8eHG8/PLLqduz9+VTpnamsLAwxo4dW1moH3/88dXelprLpzxt/0h7WVlZlY8cDx06NM4777xYvHhxlSe/7B35lKmvKi8vj+bNm8eAAQOqdXn2XD7laeXKldG3b9+466674gc/+EFERHz/+9+Pjh07xvDhw+Phhx+WrVqQT5k6/PDDY9asWTFmzJg47rjjIuKLF5KnTJkSF1988deeLJKay6fs1ERxcfFOj3u+/VxGuXo+h7wp0Rs2bFij8SRJKv89ceLEuO6662LkyJHxy1/+Mpo3bx4NGjSIn/zkJ7v1Ksv2bSZNmhQ9evTY6WXc8eS2fM3ThRdeGA8++GCUl5dXOVEIe1++ZurLhgwZEtdee20sWLDAca33snzK0/jx42Po0KFRWFhYeXzh7SenXbNmTXz66ade8KsF+ZSpNAcffHBEfHESJvaufMrT9vufr560r2HDhtGiRYsqT2bZe/IpU1+2evXqWLRoUVx00UWx77771ngu7J58ytPMmTNj69atMXDgwCrj299x+vTTTyvRa0E+ZSrii+d1gwYNiqVLl0ZFRUX06tWr8uSTXbt2rfGcSJdv2amutm3bxjvvvLPD+PaxXH3+lzcl+p6YO3du9O3bN/74xz9WGf/oo4+iZcuWld936NAhli9fHkmSVHkF57XXXquyXefOnSMiYv/993cij3ooV/M0fvz4mDFjRkyZMiXOOeec3f451L5czdRXbf/I1YYNGzL2M8m8XMvTmjVrYtasWTs9JEKvXr3iiCOOiBdffLHGP5fak2uZSrP9469ffbcPuSXX8nTkkUdGRMTatWurjG8/ubY85b5cy9SXzZ49O5IkcSiXOiTX8rRu3bpIkqTKO1AjIj777LOIiPj8889r/DOpXbmWqe0KCwvjqKOOqvx++4m2dVy5I1ezUx09evSIRYsWxbZt26p80u/ZZ5+Nxo0b5+yLNXl1TPTd1bBhwyqv5kREzJkzZ4cHy/3794+1a9fGX/7yl8qxrVu3xh133FHlckceeWR07tw5Jk+eXHkcxS977733Mjh7ck0u5mnSpEkxefLkuOaaa2LcuHE12R1yQK5lav369TvMJyJi+vTpERHRu3fvr98hsirX8jRv3rwdvs4666yIiLjrrrvi5ptvrtH+UftyLVM7+/9NmzbFlClTomXLlpWlKLkp1/J04oknxoEHHhjl5eWVHzGO+OLdnxUVFVFaWlrtfSM7ci1TXzZr1qxo3769Q0zVIbmWp65du0aSJHH//fdXGZ89e3ZERPTs2XPXO0VW5VqmdmbFihVx++23x8CBA3O23KyP6kJ20gwZMiTWrVsXf/7znyvH1q9fH3PmzInTTz99p8dLzwXeiR4RAwcOjOuvvz5GjBgRxx57bLz00ktRXl4enTp1qnK50aNHxy233BLnnHNOjBs3Ltq2bRvl5eWVB77f/opOgwYNYvr06TFgwIDo3r17jBgxItq1axdr166NJ598Mvbff/944IEHvnZODzzwQCxdujQivngVedmyZfGrX/0qIr74aNbhhx+e6WUgQ3ItT/PmzYurrroqunTpEt/+9rfjnnvuqfL/paWlO3xEmdySa5m655574vbbb48zzjgjOnXqFJs2bYqFCxfGo48+GqeffrpDBeW4XMvTGWecscPY9neeDxgwoMq7KMhNuZapW2+9NebPnx+nn356tG/fPt5555248847Y/Xq1XH33XdHYWHh3lsM9liu5amoqCgmTZoUw4YNixNOOCHOO++8WL16dUydOjW++93vxuDBg/feYpARuZap7V5++eVYtmxZXH311Tscp5bclWt5Gj58eEyePDlGjx4dL7zwQnTv3j2ef/75mD59enTv3j3OPPPMvbcYZESuZSoi4tBDD42hQ4dG+/btY9WqVXHbbbdF8+bN4/bbb987i8BuycXsVLfLHDJkSBxzzDExYsSIWL58ebRs2TKmTZsWFRUV8Ytf/CKj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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_2'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "3Bl8o7fxgsHz",
        "outputId": "db154817-14fe-4ca6-a62d-0fd7142afc5d"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaJklEQVR4nO3de3BU5f0H4G9ACSEoyEVAKiAUaMUqIDqOWhEsIopUKcRLq9xU0KLUUayjtfxqW6qFKswo2kqFUQMqtEDVUeqtlkq11AtoqSMKCqIy4gWogpfk/P5wyBjhaAJLsjl5npnMkDd7su9597PL5rO75xQkSZIEAAAAAACwgwa1PQEAAAAAAMhXSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASKFEBwAAAACAFEp0AAAAAABIoUQHAAAAAIAUSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASFHnSvTZs2dHQUFB/Pvf/67tqexRt9xySwwfPjw6dOgQBQUFMXLkyNqeUibVhzytW7cufvGLX8SRRx4Z++23X7Rq1SqOP/74eOSRR2p7aplUHzK1devWGDNmTBxyyCHRrFmzaNq0aRx22GExffr0+PTTT2t7eplSH/L0Zf/4xz+ioKAgCgoKYuPGjbU9ncypL5nanqEvf1133XW1PbVMqS95iojYsGFDjB07Ntq3bx+NGzeOTp06xZgxY2p7WplTHzK1fR/TvkpLS2t7iplRH/IUEbFp06a44ooromvXrlFUVBQdO3aMMWPGxNq1a2t7aplTXzK1YcOGGDVqVOy///5RVFQUvXv3jnnz5tX2tOq0+pKd6nSZH3zwQVxwwQXRunXrKC4ujn79+sWzzz5bc5PdBXvV9gTYueuvvz62bNkSRx55ZLz11lu1PR3qsEWLFsX1118fp512WowYMSI+++yzuOOOO2LAgAFx++23x6hRo2p7itQxW7dujf/85z9x8sknR6dOnaJBgwaxdOnSuPTSS+Ppp5+OOXPm1PYUqaPKy8vj4osvjuLi4vjwww9rezrUcQMGDIhzzz230livXr1qaTbUZevWrYtjjjkmIiLGjRsX7du3jzfffDP+9a9/1fLMqIuOO+64uPPOO3cYv/HGG2P58uVxwgkn1MKsqKvKy8tjwIABsXLlyrjooouiW7du8corr8SMGTNi8eLF8d///jf22Wef2p4mdcjmzZvj2GOPjQ0bNsSECROibdu2ce+990ZJSUmUlpbG2WefXdtTJI9VtcssLy+PU045JZYvXx4TJ06MVq1axYwZM+L444+PZ555Jrp27VqDs646JXqeeuKJJypeuWnatGltT4c6rF+/frF27dpo1apVxdi4ceOiZ8+e8fOf/1yJTrW1aNEinnrqqUpj48aNi2bNmsVNN90UN9xwQ7Rt27aWZkdd9oc//CHWrVsX5513XkyfPr22p0Md161bt/jRj35U29MgA8aOHRt77bVXLFu2LFq2bFnb06GO69y5c3Tu3LnS2NatW+Oiiy6K/v37ew5FtTz11FOxbNmyuOmmm+LHP/5xxXj37t1j9OjR8cgjj8Tpp59eizOkrvn9738fr7zySjz66KPRv3//iIi48MIL46ijjorLLrsshg0bFo0aNarlWZKvqtplzp8/P5YuXRrz5s2LYcOGRURESUlJdOvWLSZNmpS3b8yrc4dz2ZmRI0dG06ZNY+3atTF48OBo2rRptG/fPm6++eaIiHjhhReif//+UVxcHB07dtzhxnjvvffi8ssvj+985zvRtGnT2HfffWPQoEGxfPnyHa7r9ddfjyFDhkRxcXHsv//+cemll8bixYujoKAg/va3v1W67NNPPx0nnXRSNGvWLJo0aRJ9+/aNJ598skr71LFjxygoKNi1BWG3ZC1PPXr0qFSgR0QUFhbGySefHG+88UZs2bKlmitEdWUtU2k6deoUEZ9/LIs9J6t5eu+99+JnP/tZXHvttdG8efNqrwu7LquZivi8mNq2bVv1FoTdkrU8vfTSS/Hggw/GxIkTo2XLlrFt2zaHLqthWcvUztx3332xZcuW+OEPf7hL21N1WcvT5s2bIyKiTZs2lcbbtWsXERFFRUVVXht2TdYytWTJkmjdunVFgR4R0aBBgygpKYm33347nnjiiV1YJXYma9mJqHqXOX/+/GjTpk0MHTq0Yqx169ZRUlISixYtio8//rhK11fTMlGiR0SUlZXFoEGD4sADD4zf/va30alTpxg/fnzMnj07TjrppOjTp09cf/31sc8++8S5554ba9asqdh29erVsXDhwhg8eHDccMMNMXHixHjhhReib9++8eabb1Zc7sMPP4z+/fvHI488EpdccklcffXVsXTp0vjpT3+6w3wee+yxOO6442Lz5s0xadKkmDx5cnzwwQfRv39/H/2sA+pDnt5+++1o0qRJNGnSZJe2p3qymKlPPvkkNm7cGOvWrYsFCxbE1KlTo2PHjvHNb35z9xeMr5TFPF1zzTXRtm3bGDt27O4vENWWxUzNnj07iouLo6ioKA4++OC8fUdLFmUpT9vPIdOmTZs44YQToqioKIqKimLQoEHx2muv5WbB+FpZytTOlJaWRlFRUaUygT0nS3nq06dPFBcXxzXXXBOPPfZYrF+/Pp544om44oor4ogjjojvfe97uVs4UmUpUx9//PFOX3zZ3hs888wzu7pM7ESWslMdzz33XPTu3TsaNKhcSx955JHx0Ucfxcsvv5yz68qppI6ZNWtWEhHJsmXLKsZGjBiRREQyefLkirH3338/KSoqSgoKCpK77767Yvyll15KIiKZNGlSxdi2bduSsrKyStezZs2apLCwMLn22msrxn73u98lEZEsXLiwYmzr1q3Jt771rSQikscffzxJkiQpLy9PunbtmgwcODApLy+vuOxHH32UHHTQQcmAAQOqtc/FxcXJiBEjqrUNVVMf85QkSbJq1aqkcePGyTnnnFPtbflq9SlTc+fOTSKi4qtPnz7JihUrqrQtVVNf8rR8+fKkYcOGyeLFi5MkSZJJkyYlEZG88847X7st1VNfMnX00Ucn06ZNSxYtWpTccsstySGHHJJERDJjxoyvXySqrD7k6ZJLLkkiImnZsmVy0kknJffcc08yZcqUpGnTpkmXLl2SDz/8sGqLRZXUh0x92bvvvps0atQoKSkpqdZ2fL36kqf7778/adeuXaXn5QMHDky2bNny9YtEtdSHTF188cVJgwYNktdee63S+JlnnplERDJ+/Piv3J6dqw/Z+bKv6jKLi4uT0aNH7zD+wAMPJBGRPPTQQ9W6rpqSmXeiR0Scd955Ff9u3rx5dO/ePYqLi6OkpKRivHv37tG8efNYvXp1xVhhYWHFqx9lZWXx7rvvRtOmTaN79+6Vzgz70EMPRfv27WPIkCEVY40bN47zzz+/0jyef/75WLVqVZx99tnx7rvvxsaNG2Pjxo3x4YcfxgknnBB///vfo7y8POf7T25lNU8fffRRDB8+PIqKiuK6666r+oKw27KWqX79+sXDDz8c8+bNi3HjxsXee+/tZJA1KEt5uuSSS2LQoEFx4okn7tpikBNZytSTTz4ZEyZMiCFDhsS4cePimWeeiUMOOSSuuuqq2Lp1664tENWSlTz973//i4iItm3bxgMPPBAlJSVx+eWXx2233RavvvqqTzjUoKxk6svmz58fn3zyiUO51LAs5al169bRq1ev+PWvfx0LFy6M//u//4slS5Y491UNy0qmzjvvvGjYsGGUlJTE0qVL49VXX43f/OY3sWDBgogIz6P2gKxkpzq2bt0ahYWFO4w3bty44uf5KDMnFm3cuHG0bt260lizZs3iG9/4xg7H42nWrFm8//77Fd+Xl5fH9OnTY8aMGbFmzZooKyur+NkXTx70+uuvR5cuXXb4fV8+dMGqVasiImLEiBGp8920aVPst99+Vdw7alpW81RWVhZnnnlmrFy5Mh588ME44IADvnYbciOLmWrTpk3F8ReHDRsWkydPjgEDBsSqVaucFGsPy1Ke7rnnnli6dGm8+OKLqduz52UpUzvTqFGjGD9+fEWhfuyxx1Z5W6ovS3na/pH2kpKSSh85Hj58eJxzzjmxdOnSSn/8smdkKVNfVlpaGi1atIhBgwZV6fLsvizlafXq1dGvX7+444474gc/+EFERHz/+9+PTp06xciRI+PBBx+UrRqQpUwdeuihMWfOnBg3blwcc8wxEfH5C8nTpk2LCy+88CtPFkn1ZSk71VFUVLTT455vP5dRvp7PITMlesOGDas1niRJxb8nT54c11xzTYwePTp++ctfRosWLaJBgwbxk5/8ZJdeZdm+zZQpU6Jnz547vYwHnvyW1Tydf/75cf/990dpaWmlE4Ww52U1U180bNiwuPrqq2PRokWOa72HZSlPEydOjOHDh0ejRo0qji+8/eS069ati08++cQLfjUgS5lKc+CBB0bE5ydhYs/KUp62P/58+aR9DRs2jJYtW1b6Y5Y9J0uZ+qK1a9fGkiVL4oILLoi999672nNh12QpT7Nnz45t27bF4MGDK41vf8fpk08+qUSvAVnKVMTnf9cNGTIkli9fHmVlZdG7d++Kk09269at2nMiXdayU1Xt2rWLt956a4fx7WP5+vdfZkr03TF//vzo169f/PGPf6w0/sEHH0SrVq0qvu/YsWOsXLkykiSp9ArOK6+8Umm7Ll26RETEvvvu60Qe9VC+5mnixIkxa9asmDZtWpx11lm7/HuoefmaqS/b/pGrTZs25ex3knv5lqd169bFnDlzdnpIhN69e8dhhx0Wzz//fLV/LzUn3zKVZvvHX7/8bh/yS77l6fDDD4+IiPXr11ca335ybXnKf/mWqS+aO3duJEniUC51SL7lacOGDZEkSaV3oEZEfPrppxER8dlnn1X7d1Kz8i1T2zVq1CiOOOKIiu+3n2hbx5U/8jU7VdGzZ89YsmRJlJeXV/qk39NPPx1NmjTJ2xdrMnVM9F3VsGHDSq/mRETMmzdvhyfLAwcOjPXr18df/vKXirFt27bFbbfdVulyhx9+eHTp0iWmTp1acRzFL3rnnXdyOHvyTT7macqUKTF16tS46qqrYsKECdXZHfJAvmVq48aNO8wnImLmzJkREdGnT5+v3iFqVb7lacGCBTt8nXHGGRERcccdd8SNN95Yrf2j5uVbpnb28y1btsS0adOiVatWFaUo+Snf8nT88cfH/vvvH6WlpRUfMY74/N2fZWVlMWDAgCrvG7Uj3zL1RXPmzIkOHTo4xFQdkm956tatWyRJEvfee2+l8blz50ZERK9evb5+p6hV+ZapnVm1alXceuutMXjw4LwtN+ujupCdNMOGDYsNGzbEn//854qxjRs3xrx58+LUU0/d6fHS84F3okfE4MGD49prr41Ro0bF0UcfHS+88EKUlpZG586dK11u7NixcdNNN8VZZ50VEyZMiHbt2kVpaWnFge+3v6LToEGDmDlzZgwaNCh69OgRo0aNivbt28f69evj8ccfj3333Tfuu+++r5zTfffdF8uXL4+Iz19FXrFiRfzqV7+KiM8/mnXooYfmehnIkXzL04IFC+KKK66Irl27xre//e246667Kv18wIABO3xEmfySb5m666674tZbb43TTjstOnfuHFu2bInFixfHww8/HKeeeqpDBeW5fMvTaaedtsPY9neeDxo0qNK7KMhP+Zapm2++ORYuXBinnnpqdOjQId566624/fbbY+3atXHnnXdGo0aN9txisNvyLU+FhYUxZcqUGDFiRBx33HFxzjnnxNq1a2P69Onx3e9+N4YOHbrnFoOcyLdMbffiiy/GihUr4sorr9zhOLXkr3zL08iRI2Pq1KkxduzYeO6556JHjx7x7LPPxsyZM6NHjx5x+umn77nFICfyLVMREQcffHAMHz48OnToEGvWrIlbbrklWrRoEbfeeuueWQR2ST5mp6pd5rBhw+Koo46KUaNGxcqVK6NVq1YxY8aMKCsri1/84hc5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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_3'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "YERQcD1zgu0D",
        "outputId": "bd88894b-0611-4c53-e033-8361d8b98615"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaLklEQVR4nO3de3BU5f0H4G9AgRAU5CIgFRAKtGIVER1HrQgWEUWqFuKlVW4qaL3UUayjtfxqW6qFKswo2kqFUQMqtkDVUeqtlkq11AtorSMKCqIy4gUogpdwfn84ZAxwNIElu3vyPDOZIS97su9595OT5LO755QkSZIEAAAAAACwjQb5ngAAAAAAABQqJToAAAAAAKRQogMAAAAAQAolOgAAAAAApFCiAwAAAABACiU6AAAAAACkUKIDAAAAAEAKJToAAAAAAKRQogMAAAAAQAolOgAAAAAApCi6En3GjBlRUlIS//73v/M9lV3qlltuiWHDhkXHjh2jpKQkRowYke8pZVJ9yNPKlSvjF7/4RRx22GGx1157RevWreOYY46JRx99NN9Ty6T6kKmNGzfG6NGj44ADDojmzZtHs2bN4qCDDoopU6bEZ599lu/pZUp9yNPW/vGPf0RJSUmUlJTEmjVr8j2dzKkvmdqSoa0/rrvuunxPLVPqS54iIlavXh1jxoyJDh06RJMmTaJz584xevTofE8rc+pDprbsY9pHRUVFvqeYGfUhTxERa9eujSuuuCK6desWpaWl0alTpxg9enSsWLEi31PLnPqSqdWrV8fIkSNj7733jtLS0ujdu3fMnj0739MqavUlO7XpMj/66KM477zzok2bNlFWVhb9+vWL5557ru4muwN2y/cE2L7rr78+1q9fH4cddli88847+Z4ORWzevHlx/fXXx8knnxzDhw+Pzz//PO64444YMGBA3H777TFy5Mh8T5Eis3HjxvjPf/4TJ5xwQnTu3DkaNGgQCxcujEsvvTSeeeaZmDlzZr6nSJHavHlzXHTRRVFWVhYbNmzI93QocgMGDIizzz672tjBBx+cp9lQzFauXBlHHnlkRESMHTs2OnToEG+//Xb861//yvPMKEZHH3103HnnnduM33jjjbF48eI49thj8zAritXmzZtjwIAB8fLLL8cFF1wQ3bt3j9deey2mTp0a8+fPj//+97+xxx575HuaFJF169bFUUcdFatXr45LLrkk2rVrF/fee2+Ul5dHRUVFnHnmmfmeIgWspl3m5s2b48QTT4zFixfHuHHjonXr1jF16tQ45phj4tlnn41u3brV4axrToleoJ588smqZ26aNWuW7+lQxPr16xcrVqyI1q1bV42NHTs2evXqFT//+c+V6NRay5Yt4+mnn642Nnbs2GjevHncdNNNccMNN0S7du3yNDuK2R/+8IdYuXJlnHPOOTFlypR8T4ci17179/jRj36U72mQAWPGjInddtstFi1aFK1atcr3dChyXbp0iS5dulQb27hxY1xwwQXRv39/v0NRK08//XQsWrQobrrppvjxj39cNd6jR48YNWpUPProo3HKKafkcYYUm9///vfx2muvxWOPPRb9+/ePiIjzzz8/Dj/88Ljsssti6NCh0ahRozzPkkJV0y7zvvvui4ULF8bs2bNj6NChERFRXl4e3bt3j/HjxxfsC/OK7nQu2zNixIho1qxZrFixIgYPHhzNmjWLDh06xM033xwRES+++GL0798/ysrKolOnTts8GB988EFcfvnl8Z3vfCeaNWsWe+65ZwwaNCgWL168zX29+eabMWTIkCgrK4u99947Lr300pg/f36UlJTE3/72t2q3feaZZ+L444+P5s2bR9OmTaNv377x1FNP1WifOnXqFCUlJTu2IOyUrOWpZ8+e1Qr0iIjGjRvHCSecEG+99VasX7++litEbWUtU2k6d+4cEV+8LYtdJ6t5+uCDD+JnP/tZXHvttdGiRYtarws7LquZiviimNq0aVPtFoSdkrU8vfLKK/HQQw/FuHHjolWrVrFp0yanLqtjWcvU9tx///2xfv36+OEPf7hD21NzWcvTunXrIiKibdu21cbbt28fERGlpaU1Xht2TNYytWDBgmjTpk1VgR4R0aBBgygvL4933303nnzyyR1YJbYna9mJqHmXed9990Xbtm3j1FNPrRpr06ZNlJeXx7x58+KTTz6p0f3VtUyU6BERlZWVMWjQoNh3333jt7/9bXTu3DkuvPDCmDFjRhx//PHRp0+fuP7662OPPfaIs88+O5YvX1617bJly2Lu3LkxePDguOGGG2LcuHHx4osvRt++fePtt9+uut2GDRuif//+8eijj8bFF18cV199dSxcuDB++tOfbjOfxx9/PI4++uhYt25djB8/PiZMmBAfffRR9O/f31s/i0B9yNO7774bTZs2jaZNm+7Q9tROFjP16aefxpo1a2LlypUxZ86cmDRpUnTq1Cm++c1v7vyC8ZWymKdrrrkm2rVrF2PGjNn5BaLWspipGTNmRFlZWZSWlsb+++9fsK9oyaIs5WnLNWTatm0bxx57bJSWlkZpaWkMGjQo3njjjdwsGF8rS5nanoqKiigtLa1WJrDrZClPffr0ibKysrjmmmvi8ccfj1WrVsWTTz4ZV1xxRRx66KHxve99L3cLR6osZeqTTz7Z7pMvW3qDZ599dkeXie3IUnZq4/nnn4/evXtHgwbVa+nDDjssPv7443j11Vdzdl85lRSZ6dOnJxGRLFq0qGps+PDhSUQkEyZMqBr78MMPk9LS0qSkpCS5++67q8ZfeeWVJCKS8ePHV41t2rQpqaysrHY/y5cvTxo3bpxce+21VWO/+93vkohI5s6dWzW2cePG5Fvf+lYSEckTTzyRJEmSbN68OenWrVsycODAZPPmzVW3/fjjj5P99tsvGTBgQK32uaysLBk+fHittqFm6mOekiRJli5dmjRp0iQ566yzar0tX60+ZWrWrFlJRFR99OnTJ1myZEmNtqVm6kueFi9enDRs2DCZP39+kiRJMn78+CQikvfee+9rt6V26kumjjjiiGTy5MnJvHnzkltuuSU54IADkohIpk6d+vWLRI3VhzxdfPHFSUQkrVq1So4//vjknnvuSSZOnJg0a9Ys6dq1a7Jhw4aaLRY1Uh8ytbX3338/adSoUVJeXl6r7fh69SVPDzzwQNK+fftqv5cPHDgwWb9+/dcvErVSHzJ10UUXJQ0aNEjeeOONauOnn356EhHJhRde+JXbs331ITtb+6ous6ysLBk1atQ24w8++GASEcnDDz9cq/uqK5l5JXpExDnnnFP17xYtWkSPHj2irKwsysvLq8Z79OgRLVq0iGXLllWNNW7cuOrZj8rKynj//fejWbNm0aNHj2pXhn344YejQ4cOMWTIkKqxJk2axLnnnlttHi+88EIsXbo0zjzzzHj//fdjzZo1sWbNmtiwYUMce+yx8fe//z02b96c8/0nt7Kap48//jiGDRsWpaWlcd1119V8QdhpWctUv3794pFHHonZs2fH2LFjY/fdd3cxyDqUpTxdfPHFMWjQoDjuuON2bDHIiSxl6qmnnopLLrkkhgwZEmPHjo1nn302DjjggLjqqqti48aNO7ZA1EpW8vS///0vIiLatWsXDz74YJSXl8fll18et912W7z++uve4VCHspKprd13333x6aefOpVLHctSntq0aRMHH3xw/PrXv465c+fG//3f/8WCBQtc+6qOZSVT55xzTjRs2DDKy8tj4cKF8frrr8dvfvObmDNnTkSE36N2gaxkpzY2btwYjRs33ma8SZMmVf9fiDJzYdEmTZpEmzZtqo01b948vvGNb2xzPp7mzZvHhx9+WPX55s2bY8qUKTF16tRYvnx5VFZWVv3fly8e9Oabb0bXrl23+Xpbn7pg6dKlERExfPjw1PmuXbs29tprrxruHXUtq3mqrKyM008/PV5++eV46KGHYp999vnabciNLGaqbdu2VedfHDp0aEyYMCEGDBgQS5cudVGsXSxLebrnnnti4cKF8dJLL6Vuz66XpUxtT6NGjeLCCy+sKtSPOuqoGm9L7WUpT1ve0l5eXl7tLcfDhg2Ls846KxYuXFjtj192jSxlamsVFRXRsmXLGDRoUI1uz87LUp6WLVsW/fr1izvuuCN+8IMfRETE97///ejcuXOMGDEiHnroIdmqA1nK1IEHHhgzZ86MsWPHxpFHHhkRXzyRPHny5Dj//PO/8mKR1F6WslMbpaWl2z3v+ZZrGRXq9RwyU6I3bNiwVuNJklT9e8KECXHNNdfEqFGj4pe//GW0bNkyGjRoED/5yU926FmWLdtMnDgxevXqtd3bOPAUtqzm6dxzz40HHnggKioqql0ohF0vq5n6sqFDh8bVV18d8+bNc17rXSxLeRo3blwMGzYsGjVqVHV+4S0Xp125cmV8+umnnvCrA1nKVJp99903Ir64CBO7VpbytOX4s/VF+xo2bBitWrWq9scsu06WMvVlK1asiAULFsR5550Xu+++e63nwo7JUp5mzJgRmzZtisGDB1cb3/KK06eeekqJXgeylKmIL/6uGzJkSCxevDgqKyujd+/eVRef7N69e63nRLqsZaem2rdvH++8884241vGCvXvv8yU6Dvjvvvui379+sUf//jHauMfffRRtG7duurzTp06xcsvvxxJklR7Bue1116rtl3Xrl0jImLPPfd0IY96qFDzNG7cuJg+fXpMnjw5zjjjjB3+OtS9Qs3U1ra85Wrt2rU5+5rkXqHlaeXKlTFz5sztnhKhd+/ecdBBB8UL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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_4'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "DOVHzxmKgxaq",
        "outputId": "29441f60-4d52-4741-f12b-e602e3eb2195"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "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v7d+1gH1IU/vvvtuNGnSJJo0abJb21Mz+ZipTz/9NDZs2BBr166N+fPnx5QpU6Jjx47xzW9+c88XjK+Vj3m67rrrom3btjFmzJg9XyBqLB8zNWvWrCguLo6ioqI49NBDc/YVLfkon/K0/Roybdq0iZNOOimKioqiqKgoBg4cGG+88UZmFoxdyqdM7UxZWVkUFRVVKRPYe/IpT3369Ini4uK47rrr4oknnoh169bFU089FVdddVUcddRR8b3vfS9zC0eqfMrUJ598stMnX7b3Bs8999zuLhM7kU/ZqYkXXnghevfuHQ0aVK2ljz766Pj444/j1Vdfzdj3yqikjpk5c2YSEcnSpUsrx4YPH55ERDJp0qTKsQ8//DApKipKCgoKknvvvbdy/JVXXkkiIpk4cWLl2LZt25Ly8vIq32f16tVJYWFhcv3111eO/e53v0siIlmwYEHl2NatW5NvfetbSUQkTz75ZJIkSVJRUZF07do1GTBgQFJRUVF5248//jg55JBDkpKSkhrtc3FxcTJ8+PAabUP11Mc8JUmSrFy5MmncuHFy3nnn1Xhbvl59ytScOXOSiKj86NOnT7J8+fJqbUv11Jc8LVu2LGnYsGGyaNGiJEmSZOLEiUlEJO+9994ut6Vm6kumjj322GTq1KnJwoULk9tuuy057LDDkohIpk+fvutFotrqQ54uu+yyJCKSli1bJqecckpy3333JZMnT06aNm2adOnSJdmyZUv1FotqqQ+Z+qr3338/adSoUVJaWlqj7di1+pKnBx98MGnXrl2Vx+UDBgxINm/evOtFokbqQ6YuvfTSpEGDBskbb7xRZfzss89OIiIZN27c127PztWH7HzV13WZxcXFyahRo3YYf+ihh5KISB555JEafa/akjevRI+IuOCCCyr/3bx58+jevXsUFxdHaWlp5Xj37t2jefPmsWrVqsqxwsLCymc/ysvL4/3334+mTZtG9+7dq1wZ9pFHHon27dvH4MGDK8caN24cF154YZV5vPjii7Fy5co499xz4/33348NGzbEhg0bYsuWLXHSSSfF3//+96ioqMj4/pNZ+Zqnjz/+OIYNGxZFRUVxww03VH9B2GP5lql+/frFo48+GnPnzo2xY8fGvvvu62KQtSif8nTZZZfFwIED4+STT969xSAj8ilTTz/9dIwfPz4GDx4cY8eOjeeeey4O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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_5'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "lFjF6-Zigzfd",
        "outputId": "f8d84df4-ee58-4790-abd1-66231fd1f984"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaJ0lEQVR4nO3de3BU5f0H4G9AE0JQkIuAVEAo0IpVQHQctSLYiChSpRAvrXJTQYtSR7GO1vKrbakWqjCjaCsVRg2o0AJVR6m3WirVUi+gpY4oKIjKiBegCF7C+f3hkDHCkQSW7GbzPDOZIS97su9597ObzWd3zylIkiQJAAAAAABgBw2yPQEAAAAAAMhVSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASKFEBwAAAACAFEp0AAAAAABIoUQHAAAAAIAUSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASFHnSvSZM2dGQUFB/Pvf/872VPaq2267LYYOHRrt27ePgoKCGD58eLanlJfqQ57WrFkTv/jFL+Loo4+OAw44IFq2bBknnnhiPPbYY9meWl6qD5nasmVLjBo1Kg477LBo2rRpNGnSJI444oiYOnVqfPbZZ9meXl6pD3n6qn/84x9RUFAQBQUFsX79+mxPJ+/Ul0xtz9BXv2644YZsTy2v1Jc8RUSsW7cuRo8eHe3atYtGjRpFx44dY9SoUdmeVt6pD5navo9pX+Xl5dmeYt6oD3mKiNiwYUNcddVV0aVLlyguLo4OHTrEqFGjYvXq1dmeWt6pL5lat25djBgxIg488MAoLi6OXr16xZw5c7I9rTqtvmSnJl3mRx99FBdddFG0atUqSkpKom/fvvH888/X3mR3wz7ZngA7d+ONN8amTZvi6KOPjnfeeSfb06EOW7BgQdx4441xxhlnxLBhw+Lzzz+Pu+66K0pLS+POO++MESNGZHuK1DFbtmyJ//znP3HqqadGx44do0GDBrF48eK4/PLL49lnn41Zs2Zle4rUUdu2bYtLL700SkpKYvPmzdmeDnVcaWlpnH/++VXGevbsmaXZUJetWbMmjjvuuIiIGDNmTLRr1y7efvvt+Ne//pXlmVEXnXDCCXH33XfvMH7zzTfH0qVL46STTsrCrKirtm3bFqWlpbF8+fK45JJLomvXrvHaa6/FtGnTYuHChfHf//439ttvv2xPkzpk48aNcfzxx8e6deti3Lhx0aZNm7j//vujrKwsysvL49xzz832FMlh1e0yt23bFqeddlosXbo0xo8fHy1btoxp06bFiSeeGM8991x06dKlFmddfUr0HPXUU09VvnLTpEmTbE+HOqxv376xevXqaNmyZeXYmDFjokePHvHzn/9ciU6NNW/ePJ555pkqY2PGjImmTZvGLbfcEjfddFO0adMmS7OjLvvDH/4Qa9asiQsuuCCmTp2a7elQx3Xt2jV+9KMfZXsa5IHRo0fHPvvsE0uWLIkWLVpkezrUcZ06dYpOnTpVGduyZUtccskl0a9fP8+hqJFnnnkmlixZErfcckv8+Mc/rhzv1q1bjBw5Mh577LE488wzszhD6prf//738dprr8Xjjz8e/fr1i4iIiy++OI455pi44oorYsiQIVFYWJjlWZKrqttlzp07NxYvXhxz5syJIUOGREREWVlZdO3aNSZMmJCzb8yrc4dz2Znhw4dHkyZNYvXq1TFw4MBo0qRJtGvXLm699daIiHjppZeiX79+UVJSEh06dNjhxvjggw/iyiuvjO985zvRpEmT2H///WPAgAGxdOnSHa7rzTffjEGDBkVJSUkceOCBcfnll8fChQujoKAg/va3v1W57LPPPhunnHJKNG3aNBo3bhx9+vSJp59+ulr71KFDhygoKNi9BWGP5FueunfvXqVAj4goKiqKU089Nd56663YtGlTDVeImsq3TKXp2LFjRHzxsSz2nnzN0wcffBA/+9nP4vrrr49mzZrVeF3YffmaqYgviqmtW7fWbEHYI/mWp1deeSUefvjhGD9+fLRo0SK2bt3q0GW1LN8ytTMPPPBAbNq0KX74wx/u1vZUX77laePGjRER0bp16yrjbdu2jYiI4uLiaq8NuyffMrVo0aJo1apVZYEeEdGgQYMoKyuLd999N5566qndWCV2Jt+yE1H9LnPu3LnRunXrGDx4cOVYq1atoqysLBYsWBCffPJJta6vtuVFiR4RUVFREQMGDIiDDz44fvvb30bHjh1j7NixMXPmzDjllFOid+/eceONN8Z+++0X559/fqxatapy25UrV8b8+fNj4MCBcdNNN8X48ePjpZdeij59+sTbb79debnNmzdHv3794rHHHovLLrssrr322li8eHH89Kc/3WE+TzzxRJxwwgmxcePGmDBhQkycODE++uij6Nevn49+1gH1IU/vvvtuNG7cOBo3brxb21Mz+ZipTz/9NNavXx9r1qyJefPmxeTJk6NDhw7xzW9+c88XjK+Vj3m67rrrok2bNjF69Og9XyBqLB8zNXPmzCgpKYni4uI49NBDc/YdLfkon/K0/RwyrVu3jpNOOimKi4ujuLg4BgwYEG+88UZmFoxdyqdM7Ux5eXkUFxdXKRPYe/IpT717946SkpK47rrr4oknnoi1a9fGU089FVdddVUcddRR8b3vfS9zC0eqfMrUJ598stMXX7b3Bs8999zuLhM7kU/ZqYkXXnghevXqFQ0aVK2ljz766Pj444/j1Vdfzdh1ZVRSx8yYMSOJiGTJkiWVY8OGDUsiIpk4cWLl2IcffpgUFxcnBQUFyb333ls5/sorryQRkUyYMKFybOvWrUlFRUWV61m1alVSVFSUXH/99ZVjv/vd75KISObPn185tmXLluRb3/pWEhHJk08+mSRJkmzbti3p0qVL0r9//2Tbtm2Vl/3444+TQw45JCktLa3RPpeUlCTDhg2r0TZUT33MU5IkyYoVK5JGjRol5513Xo235evVp0zNnj07iYjKr969eyfLli2r1rZUT33J09KlS5OGDRsmCxcuTJIkSSZMmJBERPLee+/tcltqpr5k6thjj02mTJmSLFiwILntttuSww47LImIZNq0abteJKqtPuTpsssuSyIiadGiRXLKKack9913XzJp0qSkSZMmSefOnZPNmzdXb7GolvqQqa96//33k8LCwqSsrKxG27Fr9SVPDz74YNK2bdsqz8v79++fbNq0adeLRI3Uh0xdeumlSYMGDZI33nijyvjZZ5+dREQyduzYr92enasP2fmqr+syS0pKkpEjR+4w/tBDDyURkTzyyCM1uq7akjfvRI+IuOCCCyr/3axZs+jWrVuUlJREWVlZ5Xi3bt2iWbNmsXLlysqxoqKiylc/Kioq4v33348mTZpEt27dqpwZ9pFHHol27drFoEGDKscaNWoUF154YZV5vPjii7FixYo499xz4/3334/169fH+vXrY/PmzXHSSSfF3//+99i2bVvG95/Mytc8ffzxxzF06NAoLi6OG264ofoLwh7Lt0z17ds3Hn300ZgzZ06MGTMm9t13XyeDrEX5lKfLLrssBgwYECeffPLuLQYZkU+Zevrpp2PcuHExaNCgGDNmTDz33HNx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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_6'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "jFmZ0yeHg1X-",
        "outputId": "34c6b40a-e1c8-4fb3-c14a-496573fcb4a0"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaGklEQVR4nO3de3BU5f0H4G9ACSEoyEVAKiAUaMUqIDqOWhEsIopUKcRLq9xU0KLUUayjtfxqW6qFKswo2kqFUQMqtEDVUeqtlkq11AtoqSMKCqIy4gWogpdwfn84ZIxwNIFNsjl5npnMkJc92fe8+9nN5rO75xQkSZIEAAAAAACwkwa1PQEAAAAAAMhXSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASKFEBwAAAACAFEp0AAAAAABIoUQHAAAAAIAUSnQAAAAAAEihRAcAAAAAgBRKdAAAAAAASFHnSvTZs2dHQUFB/Pvf/67tqVSrW265JYYPHx4dOnSIgoKCGDlyZG1PKZPqQ57WrVsXv/jFL+LII4+M/fbbL1q1ahXHH398PPLII7U9tUyqD5naunVrjBkzJg455JBo1qxZNG3aNA477LCYPn16fPrpp7U9vUypD3n6sn/84x9RUFAQBQUFsXHjxtqeTubUl0ztyNCXv6677rranlqm1Jc8RURs2LAhxo4dG+3bt4/GjRtHp06dYsyYMbU9rcypD5nasY9pX6WlpbU9xcyoD3mKiNi0aVNcccUV0bVr1ygqKoqOHTvGmDFjYu3atbU9tcypL5nasGFDjBo1Kvbff/8oKiqK3r17x7x582p7WnVafclOVbrMDz74IC644IJo3bp1FBcXR79+/eLZZ5+tucnuhr1qewLs2vXXXx9btmyJI488Mt56663ang512KJFi+L666+P0047LUaMGBGfffZZ3HHHHTFgwIC4/fbbY9SoUbU9ReqYrVu3xn/+8584+eSTo1OnTtGgQYNYunRpXHrppfH000/HnDlzanuK1FHbt2+Piy++OIqLi+PDDz+s7elQxw0YMCDOPffcCmO9evWqpdlQl61bty6OOeaYiIgYN25ctG/fPt58883417/+Vcszoy467rjj4s4779xp/MYbb4zly5fHCSecUAuzoq7avn17DBgwIFauXBkXXXRRdOvWLV555ZWYMWNGLF68OP773//GPvvsU9vTpA7ZvHlzHHvssbFhw4aYMGFCtG3bNu69994oKSmJ0tLSOPvss2t7iuSxynaZ27dvj1NOOSWWL18eEydOjFatWsWMGTPi+OOPj2eeeSa6du1ag7OuPCV6nnriiSfKX7lp2rRpbU+HOqxfv36xdu3aaNWqVfnYuHHjomfPnvHzn/9ciU6VtWjRIp566qkKY+PGjYtmzZrFTTfdFDfccEO0bdu2lmZHXfaHP/wh1q1bF+edd15Mnz69tqdDHdetW7f40Y9+VNvTIAPGjh0be+21VyxbtixatmxZ29OhjuvcuXN07ty5wtjWrVvjoosuiv79+3sORZU89dRTsWzZsrjpppvixz/+cfl49+7dY/To0fHII4/E6aefXoszpK75/e9/H6+88ko8+uij0b9//4iIuPDCC+Ooo46Kyy67LIYNGxaNGjWq5VmSryrbZc6fPz+WLl0a8+bNi2HDhkVERElJSXTr1i0mTZqUt2/Mq3OHc9mVkSNHRtOmTWPt2rUxePDgaNq0abRv3z5uvvnmiIh44YUXon///lFcXBwdO3bc6cZ477334vLLL4/vfOc70bRp09h3331j0KBBsXz58p2u6/XXX48hQ4ZEcXFx7L///nHppZfG4sWLo6CgIP72t79VuOzTTz8dJ510UjRr1iyaNGkSffv2jSeffLJS+9SxY8coKCjYvQVhj2QtTz169KhQoEdEFBYWxsknnxxvvPFGbNmypYorRFVlLVNpOnXqFBGffyyL6pPVPL333nvxs5/9LK699tpo3rx5ldeF3ZfVTEV8Xkxt27atagvCHslanl566aV48MEHY+LEidGyZcvYtm2bQ5fVsKxlalfuu+++2LJlS/zwhz/cre2pvKzlafPmzRER0aZNmwrj7dq1i4iIoqKiSq8NuydrmVqyZEm0bt26vECPiGjQoEGUlJTE22+/HU888cRurBK7krXsRFS+y5w/f360adMmhg4dWj7WunXrKCkpiUWLFsXHH39cqeuraZko0SMiysrKYtCgQXHggQfGb3/72+jUqVOMHz8+Zs+eHSeddFL06dMnrr/++thnn33i3HPPjTVr1pRvu3r16li4cGEMHjw4brjhhpg4cWK88MIL0bdv33jzzTfLL/fhhx9G//7945FHHolLLrkkrr766li6dGn89Kc/3Wk+jz32WBx33HGxefPmmDRpUkyePDk++OCD6N+/v49+1gH1IU9vv/12NGnSJJo0abJb21M1WczUJ598Ehs3box169bFggULYurUqdGxY8f45je/uecLxlfKYp6uueaaaNu2bYwdO3bPF4gqy2KmZs+eHcXFxVFUVBQHH3xw3r6jJYuylKcd55Bp06ZNnHDCCVFUVBRFRUUxaNCgeO2113KzYHytLGVqV0pLS6OoqKhCmUD1yVKe+vTpE8XFxXHNNdfEY489FuvXr48nnngirrjiijjiiCPie9/7Xu4WjlRZytTHH3+8yxdfdvQGzzzzzO4uE7uQpexUxXPPPRe9e/eOBg0q1tJHHnlkfPTRR/Hyyy/n7LpyKqljZs2alUREsmzZsvKxESNGJBGRTJ48uXzs/fffT4qKipKCgoLk7rvvLh9/6aWXkohIJk2aVD62bdu2pKysrML1rFmzJiksLEyuvfba8rHf/e53SUQkCxcuLB/bunVr8q1vfSuJiOTxxx9PkiRJtm/fnnTt2jUZOHBgsn379vLLfvTRR8lBBx2UDBgwoEr7XFxcnIwYMaJK21A59TFPSZIkq1atSho3bpycc845Vd6Wr1afMjV37twkIsq/+vTpk6xYsaJS21I59SVPy5cvTxo2bJgsXrw4SZIkmTRpUhIRyTvvvPO121I19SVTRx99dDJt2rRk0aJFyS233JIccsghSUQkM2bM+PpFotLqQ54uueSSJCKSli1bJieddFJyzz33JFOmTEmaNm2adOnSJfnwww8rt1hUSn3I1Je9++67SaNGjZKSkpIqbcfXqy95uv/++5N27dpVeF4+cODAZMuWLV+/SFRJfcjUxRdfnDRo0CB57bXXKoyfeeaZSUQk48eP/8rt2bX6kJ0v+6ous7i4OBk9evRO4w888EASEclDDz1UpeuqKZl5J3pExHnnnVf+7+bNm0f37t2juLg4SkpKyse7d+8ezZs3j9WrV5ePFRYWlr/6UVZWFu+++240bdo0unfvXuHMsA899FC0b98+hgwZUj7WuHHjOP/88yvM4/nnn49Vq1bF2WefHe+++25s3LgxNm7cGB9++GGccMIJ8fe//z22b9+e8/0nt7Kap48++iiGDx8eRUVFcd1111V+QdhjWctUv3794uGHH4558+bFuHHjYu+993YyyBqUpTxdcsklMWjQoDjxxBN3bzHIiSxl6sknn4wJEybEkCFDYty4cfHMM8/EIYccEldddVVs3bp19xaIKslKnv73v/9FRETbtm3jgQceiJKSkrj88svjtttui1dffdUnHGpQVjL1ZfPnz49PPvnEoVxqWJby1Lp16+jVq1f8+te/joULF8b//d//xZIlS5z7qoZlJVPnnXdeNGzYMEpKSmLp0qXx6quvxm9+85tYsGBBRITnUdUgK9mpiq1bt0ZhYeFO440bNy7//3yUmROLNm7cOFq3bl1hrFmzZvGNb3xjp+PxNGvWLN5///3y77dv3x7Tp0+PGTNmxJo1a6KsrKz8/7548qDXX389unTpstPP+/KhC1atWhURESNGjEid76ZNm2K//far5N5R07Kap7KysjjzzDNj5cqV8eCDD8YBBxzwtduQG1nMVJs2bcqPvzhs2LCYPHlyDBgwIFatWuWkWNUsS3m65557YunSpfHiiy+mbk/1y1KmdqVRo0Yxfvz48kL92GOPrfS2VF2W8rTjI+0lJSUVPnI8fPjwOOecc2Lp0qUV/vilemQpU19WWloaLVq0iEGDBlXq8uy5LOVp9erV0a9fv7jjjjviBz/4QUREfP/7349OnTrFyJEj48EHH5StGpClTB166KExZ86cGDduXBxzzDER8fkLydOmTYsLL7zwK08WSdVlKTtVUVRUtMvjnu84l1G+ns8hMyV6w4YNqzSeJEn5vydPnhzXXHNNjB49On75y19GixYtokGDBvGTn/xkt15l2bHNlClTomfPnru8jAee/JbVPJ1//vlx//33R2lpaYUThVD9spqpLxo2bFhcffXVsWjRIse1rmZZytPEiRNj+PDh0ahRo/LjC+84Oe26devik08+8YJfDchSptIceOCBEfH5SZioXlnK047Hny+ftK9hw4bRsmXLCn/MUn2ylKkvWrt2bSxZsiQuuOCC2Hvvvas8F3ZPlvI0e/bs2LZtWwwePLjC+I53nD755JNK9BqQpUxFfP533ZAhQ2L58uVRVlYWvXv3Lj/5ZLdu3ao8J9JlLTuV1a5du3jrrbd2Gt8xlq9//2WmRN8T8+fPj379+sUf//jHCuMffPBBtGrVqvz7jh07xsqVKyNJkgqv4LzyyisVtuvSpUtEROy7775O5FEP5WueJk6cGLNmzYpp06bFWWedtds/h5qXr5n6sh0fudq0aVPOfia5l295WrduXcyZM2eXh0To3bt3HHbYYfH8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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_7'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "ZyfvGYSZg3Je",
        "outputId": "d6f0ed65-3073-4ffd-ab83-053d88d86732"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaE0lEQVR4nO3de3BU5f0H4G9AE0JQkIuAVEAo0IpVQHQctSLYiChSpRAvrXJTQYtSR7GO1vKrbakWqjCjaCsVRg2o0AJVR6m3WirVUi+gpY4oKIjKiBegCF6S8/vDIWOAo0lYks3meWYyQ172JO9595OT7Gd3z8lLkiQJAAAAAABgF43qegIAAAAAAJCtlOgAAAAAAJBCiQ4AAAAAACmU6AAAAAAAkEKJDgAAAAAAKZToAAAAAACQQokOAAAAAAAplOgAAAAAAJBCiQ4AAAAAACmU6AAAAAAAkKLeleizZ8+OvLy8+Pe//13XU9mrbrvtthg+fHh07Ngx8vLyYuTIkXU9pZzUEPK0bt26+MUvfhFHH310HHDAAdG6des48cQT47HHHqvrqeWkhpCpbdu2xZgxY+Kwww6L5s2bR7NmzeKII46I6dOnx2effVbX08spDSFPO/vHP/4ReXl5kZeXFxs3bqzr6eSchpKpHRna+eOGG26o66nllIaSp4iIDRs2xNixY6NDhw7RpEmT6Ny5c4wZM6aup5VzGkKmduxj2kdpaWldTzFnNIQ8RURs2rQprrrqqujWrVsUFhZGp06dYsyYMbF27dq6nlrOaSiZ2rBhQ4waNSoOPPDAKCwsjD59+sS8efPqelr1WkPJTnW6zI8++iguuuiiaNOmTRQVFUX//v3j+eefr73J1sA+dT0Bdu/GG2+MLVu2xNFHHx3vvPNOXU+HemzRokVx4403xhlnnBEjRoyIzz//PO66664oLi6OO++8M0aNGlXXU6Se2bZtW/znP/+JU089NTp37hyNGjWKpUuXxuWXXx7PPvtszJkzp66nSD1VXl4el156aRQVFcXWrVvrejrUc8XFxXH++edXGuvdu3cdzYb6bN26dXHcccdFRMS4ceOiQ4cO8fbbb8e//vWvOp4Z9dEJJ5wQd9999y7jN998cyxfvjxOOumkOpgV9VV5eXkUFxfHypUr45JLLonu3bvHa6+9FjNmzIjFixfHf//739hvv/3qeprUI5s3b47jjz8+NmzYEBMmTIh27drF/fffHyUlJVFaWhrnnntuXU+RLFbVLrO8vDxOO+20WL58eUycODFat24dM2bMiBNPPDGee+656NatWy3OuuqU6FnqqaeeqnjmplmzZnU9Heqx/v37x9q1a6N169YVY+PGjYtevXrFz3/+cyU61dayZct45plnKo2NGzcumjdvHrfcckvcdNNN0a5duzqaHfXZH/7wh1i3bl1ccMEFMX369LqeDvVc9+7d40c/+lFdT4McMHbs2Nhnn31i2bJl0apVq7qeDvVcly5dokuXLpXGtm3bFpdcckkMGDDA31BUyzPPPBPLli2LW265JX784x9XjPfo0SNGjx4djz32WJx55pl1OEPqm9///vfx2muvxeOPPx4DBgyIiIiLL744jjnmmLjiiiti2LBhkZ+fX8ezJFtVtcucP39+LF26NObNmxfDhg2LiIiSkpLo3r17TJo0KWtfmFfvTueyOyNHjoxmzZrF2rVrY/DgwdGsWbPo0KFD3HrrrRER8dJLL8WAAQOiqKgoOnXqtMud8cEHH8SVV14Z3/nOd6JZs2ax//77x6BBg2L58uW7fK8333wzhgwZEkVFRXHggQfG5ZdfHosXL468vLz429/+Vum2zz77bJxyyinRvHnzaNq0afTr1y+efvrpKu1Tp06dIi8vr2YLwh7JtTz17NmzUoEeEVFQUBCnnnpqvPXWW7Fly5ZqrhDVlWuZStO5c+eI+OJtWew9uZqnDz74IH72s5/F9ddfHy1atKj2ulBzuZqpiC+Kqe3bt1dvQdgjuZanV155JR5++OGYOHFitGrVKrZv3+7UZbUs1zK1Ow888EBs2bIlfvjDH9Zoe6ou1/K0efPmiIho27ZtpfH27dtHRERhYWGV14aaybVMLVmyJNq0aVNRoEdENGrUKEpKSuLdd9+Np556qgarxO7kWnYiqt5lzp8/P9q2bRtDhw6tGGvTpk2UlJTEokWL4pNPPqnS96ttOVGiR0SUlZXFoEGD4uCDD47f/va30blz5xg/fnzMnj07TjnllOjbt2/ceOONsd9++8X5558fa9asqdh29erVsXDhwhg8eHDcdNNNMXHixHjppZeiX79+8fbbb1fcbuvWrTFgwIB47LHH4rLLLotrr702li5dGj/96U93mc8TTzwRJ5xwQmzevDkmTZoUkydPjo8++igG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F6v9dak92ZapNDve/rrzq33ILtmWpyOPPDIiItavX19pfMfFteUp+2Vbpr5s7ty5kSSJU7nUI9mWpw0bNkSSJJVegRoR8dlnn0VExOeff17tr0ntyrZM7ZCfnx9HHXVUxec7LrSt48oe2ZqdqujVq1csWbIkysvLK73T79lnn42mTZtm7ZM1OXVO9Jpq3LhxpWdzIiLmzZu3yx/LAwcOjPXr18df/vKXirHt27fHHXfcUel2Rx55ZHTt2jWmTp1acR7FL3vvvfcyOHuyTTbmacqUKTF16tS45pprYsKECdXZHbJAtmVq48aNu8wnImLmzJkREdG3b9+v3iHqVLblacGCBbt8nHXWWRERcdddd8XNN99crf2j9mVbpnb3/1u2bIlp06ZF69atK0pRslO25enEE0+MAw88MEpLSyveYhzxxas/y8rKori4uMr7Rt3Itkx92Zw5c6Jjx45OMVWPZFueunfvHkmSxP33319pfO7cuRER0bt376/fKepUtmVqd1atWhW33357DB48OGvLzYaoPmQnzbBhw2LDhg3x5z//uWJs48aNMW/evDj99NN3e770bOCV6BExePDguP7662PUqFFx7LHHxksvvRSlpaXRpUuXSrcbO3Zs3HLLLXHOOefEhAkTon379lFaWlpx4vsdz+g0atQoZs6cGYMGDYqePXvGqFGjokOHDrF+/fp48sknY//9948HHnjgK+f0wAMPxPLlyyPii2eRV6xYEb/61a8i4ou3Zh1++OGZXgYyJNvytGDBgrjqqquiW7du8e1vfzvuueeeSv9fXFy8y1uUyS7Zlql77rknbr/99jjjjDOiS5cusWXLlli8eHE8+uijcfrppztVUJbLtjydccYZu4zteOX5oEGDKr2KguyUbZm69dZbY+HChXH66adHx44d45133ok777wz1q5dG3fffXfk5+fvvcVgj2VbngoKCmLKlCkxYsSIOOGEE+K8886LtWvXxvTp0+O73/1uDB06dO8tBhmRbZna4eWXX44VK1bE1Vdfvct5asle2ZankSNHxtSpU2Ps2LHxwgsvRM+ePeP555+PmTNnRs+ePePMM8/ce4tBRmRbpiIiDj300Bg+fHh07Ngx1qxZE7fddlu0bNkybr/99r2zCNRINmanql3msGHD4phjjolRo0bFypUro3Xr1jFjxowoKyuLX/ziFxld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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_8'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "MbouYPILg6JZ",
        "outputId": "f82d7bdd-40b0-4227-daf7-b8158ecc1344"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACvCAYAAAASRZccAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAaCUlEQVR4nO3de3BU5f0H4G9AE0JQkIuAVEAo0IpVQHQctSLYiChSpRAvrXJTQYtSR7GO1vKrbakWqjCjaCsVRg2o0AJVR6m3WirVUi+gpY6oKIjKiBegCF7C+f3hkDGSowks2c3meWYyQ172ZN9989mzm8/unlOQJEkSAAAAAADAThplewIAAAAAAJCrlOgAAAAAAJBCiQ4AAAAAACmU6AAAAAAAkEKJDgAAAAAAKZToAAAAAACQQokOAAAAAAAplOgAAAAAAJBCiQ4AAAAAACmU6AAAAAAAkKLeleizZ8+OgoKC+Pe//53tqexRt9xySwwfPjw6duwYBQUFMXLkyGxPKS81hDytXbs2fvGLX8SRRx4Z++23X7Ru3TqOP/74eOSRR7I9tbzUEDK1devWGDNmTBxyyCHRvHnzaNasWRx22GExffr0+PTTT7M9vbzSEPL0Zf/4xz+ioKAgCgoKYsOGDdmeTt5pKJnakaEvf1133XXZnlpeaSh5iohYv359jB07Njp06BBNmjSJzp07x5gxY7I9rbzTEDK14zamfZWXl2d7inmjIeQpImLjxo1xxRVXRLdu3aK4uDg6deoUY8aMiTVr1mR7anmnoWRq/fr1MWrUqNh///2juLg4+vTpE/Pmzcv2tOq1hpKd2nSZH374YVxwwQXRpk2bKCkpif79+8ezzz5bd5PdBXtlewJU7/rrr4/NmzfHkUceGW+//Xa2p0M9tmjRorj++uvjtNNOixEjRsRnn30Wd9xxR5SWlsbtt98eo0aNyvYUqWe2bt0a//nPf+Lkk0+Ozp07R6NGjWLp0qVx6aWXxtNPPx1z5szJ9hSpp7Zv3x4XX3xxlJSUxJYtW7I9Heq50tLSOPfcc6uM9e7dO0uzoT5bu3ZtHHPMMRERMW7cuOjQoUO89dZb8a9//SvLM6M+Ou644+LOO+/cafzGG2+M5cuXxwknnJCFWVFfbd++PUpLS2PlypVx0UUXRffu3eOVV16JGTNmxOLFi+O///1v7LPPPtmeJvXIpk2b4thjj43169fHhAkTol27dnHvvfdGWVlZlJeXx9lnn53tKZLDatplbt++PU455ZRYvnx5TJw4MVq3bh0zZsyI448/Pp555pno1q1bHc665pToOeqJJ56ofOWmWbNm2Z4O9Vj//v1jzZo10bp168qxcePGRa9eveLnP/+5Ep1aa9myZTz11FNVxsaNGxfNmzePm266KW644YZo165dlmZHffaHP/wh1q5dG+edd15Mnz4929OhnuvevXv86Ec/yvY0yANjx46NvfbaK5YtWxatWrXK9nSo57p06RJdunSpMrZ169a46KKLYsCAAZ5DUStPPfVULFu2LG666ab48Y9/XDneo0ePGD16dDzyyCNx+umnZ3GG1De///3v45VXXolHH300BgwYEBERF154YRx11FFx2WWXxbBhw6KwsDDLsyRX1bTLnD9/fixdujTmzZsXw4YNi4iIsrKy6N69e0yaNCln35hX7w7nUp2RI0dGs2bNYs2aNTF48OBo1qxZdOjQIW6++eaIiHjhhRdiwIABUVJSEp06ddrpl/H+++/H5ZdfHt/5zneiWbNmse+++8agQYNi+fLlO13XG2+8EUOGDImSkpLYf//949JLL43FixdHQUFB/O1vf6ty2aeffjpOOumkaN68eTRt2jT69esXTz75ZI1uU6dOnaKgoGDXFoTdkm956tmzZ5UCPSKiqKgoTj755HjzzTdj8+bNtVwhaivfMpWmc+fOEfH5x7LYc/I1T++//3787Gc/i2uvvTZatGhR63Vh1+VrpiI+L6a2bdtWuwVht+Rbnl566aV48MEHY+LEidGqVavYtm2bQ5fVsXzLVHXuu+++2Lx5c/zwhz/cpe2puXzL06ZNmyIiom3btlXG27dvHxERxcXFNV4bdk2+ZWrJkiXRpk2bygI9IqJRo0ZRVlYW77zzTjzxxBO7sEpUJ9+yE1HzLnP+/PnRtm3bGDp0aOVYmzZtoqysLBYtWhQff/xxja6vruVFiR4RUVFREYMGDYoDDzwwfvvb30bnzp1j/PjxMXv27DjppJOib9++cf3118c+++wT5557bqxevbpy29deey0WLlwYgwcPjhtuuCEmTpwYL7zwQvTr1y/eeuutystt2bIlBgwYEI888khccsklcfXVV8fSpUvjpz/96U7zeeyxx+K4446LTZs2xaRJk2Ly5Mnx4YcfxoABA3z0sx5oCHl65513omnTptG0adNd2p7aycdMffLJJ7Fhw4ZYu3ZtLFiwIKZOnRqdOnWKb37zm7u/YHylfMzTNddcE+3atYuxY8fu/gJRa/mYqdmzZ0dJSUkUFxfHwQcfnLPvaMlH+ZSnHeeQadu2bZxwwglRXFwcxcXFMWjQoHj99dczs2B8rXzKVHXKy8ujuLi4SpnAnpNPeerbt2+UlJTENddcE4899lisW7cunnjiibjiiiviiCOOiO9973uZWzhS5VOmPv7442pffNnRGzzzzDO7ukxUI5+yUxvPPfdc9OnTJxo1qlpLH3nkkfHRRx/Fyy+/nLHryqiknpk1a1YSEcmyZcsqx0aMGJFERDJ58uTKsQ8++CApLi5OCgoKkrvvvrty/KWXXkoiIpk0aVLl2LZt25KKiooq17N69eqkqKgoufbaayvHfve73yURkSxcuLBybOvWrcm3vvWtJCKSxx9/PEmSJNm+fXvSrVu3ZODAgcn27dsrL/vRRx8lBx10UFJaWlqr21xSUpKMGDGiVttQMw0xT0mSJKtWrUqaNGmSnHPOObXelq/WkDI1d+7cJCIqv/r27ZusWLGiRttSMw0lT8uXL08aN26cLF68OEmSJJk0aVISEcm77777tdtSOw0lU0cffXQybdq0ZNGiRcktt9ySHHLIIUlEJDNmzPj6RaLGGkKeLrnkkiQiklatWiUnnXRScs899yRTpkxJmjVrlnTt2jXZsmVLzRaLGmkImfqy9957LyksLEzKyspqtR1fr6Hk6f7770/at29f5Xn5wIEDk82bN3/9IlErDSFTF198cdKoUaPk9ddfrzJ+5plnJhGRjB8//iu3p3oNITtf9lVdZklJSTJ69Oidxh944IEkIpKHHnqoVtdVV/LmnegREeedd17lv1u0aBE9evSIkpKSKCsrqxzv0aNHtGjRIl577bXKsaKiospXPyoqKuK9996LZs2aRY8ePaqcGfahhx6KDh06xJAhQyrHmjRpEueff36VeTz//POxatWqOPvss+O9996LDRs2xIYNG2LLli1xwgknxN///vfYvn17xm8/mZWvefroo49i+PDhUVxcHNddd13NF4Tdlm+Z6t+/fzz88MMxb968GDduXOy9995OBlmH8ilPl1xySQwaNChOPPHEXVsMMiKfMvXkk0/GhAkTYsiQITFu3Lh45pln4pBDDomrrroqtm7dumsLRK3kS57+97//RUREu3bt4oEHHoiysrK4/PLL47bbbotXX33VJxzqUL5k6svmz58fn3zyiUO51LF8ylObNm2id+/e8etf/zoWLlwY//d//xdLlixx7qs6li+ZOu+886Jx48ZRVlYWS5cujVdffTV+85vfxIIFCyIiPI/aA/IlO7WxdevWKCoq2mm8SZMmlf+fi/LmxKJNmjSJNm3aVBlr3rx5fOMb39jpeDzNmzePDz74oPL77du3x/Tp02PGjBmxevXqqKioqPy/L5486I033oiuXbvu9PO+fOiCVatWRUTEiBEjUue7cePG2G+//Wp466hr+ZqnioqKOPPMM2PlypXx4IMPxgEHHPC125AZ+Ziptm3bVh5/cdiwYTF58uQoLS2NVatWOSnWHpZPebrnnnti6dKl8eKLL6Zuz56XT5mqTmFhYYwfP76yUD/22GNrvC21l0952vGR9rKysiofOR4+fHicc845sXTp0ip//LJn5FOmvqy8vDxatmwZgwYNqtHl2X35lKfXXnst+vfvH3fccUf84Ac/iIiI73//+9G5c+cYOXJkPPjgg7JVB/IpU4ceemjMmTMnxo0bF8ccc0xEfP5C8rRp0+LCCy/8ypNFUnv5lJ3aKC4urva45zvOZZSr53PImxK9cePGtRpPkqTy35MnT45rrrkmRo8eHb/85S+jZcuW0ahRo/jJT36yS6+y7NhmypQp0atXr2ovY8eT2/I1T+eff37cf//9UV5eXuVEIex5+ZqpLxo2bFhcffXVsWjRIse13sPyKU8TJ06M4cOHR2FhYeXxhXecnHbt2rXxySefeMGvDuRTptIceOCBEfH5SZjYs/IpTzv2P18+aV/jxo2jVatWVf6YZc/Jp0x90Zo1a2LJkiVxwQUXxN57713rubBr8ilPs2fPjm3btsXgwYOrjO94x+mTTz6pRK8D+ZSpiM//rhsyZEgsX748Kioqok+fPpUnn+zevXut50S6fMtOTbVv3z7efvvtncZ3jOXq3395U6Lvjvnz50f//v3jj3/8Y5XxDz/8MFq3bl35fadOnWLlypWRJEmVV3BeeeWVKtt17do1IiL23XdfJ/JogHI1TxMnToxZs2bFtGnT4qyzztrln0Pdy9VMfdmOj1xt3LgxYz+TzMu1PK1duzbmzJlT7SER+vTpE4cddlg8//zztf651J1cy1SaHR9//fK7fcgtuZanww8/PCIi1q1bV2V8x8m15Sn35Vqmvmju3LmRJIlDudQjuZan9evXR5IkVd6BGhHx6aefRkTEZ599VuufSd3KtUztUFhYGEcccUTl9ztOtK3jyh25mp2a6NWrVyxZsiS2b99e5ZN+Tz/9dDRt2jRnX6zJq2Oi76rGjRtXeTUnImLevHk7PVkeOHBgrFu3Lv7yl79Ujm3bti1uu+22Kpc7/PDDo2vXrjF16tTK4yh+0bvvvpvB2ZNrcjFPU6ZMialTp8ZVV10VEyZMqM3NIQfkWqY2bNiw03wiImbOnBkREX379v3qG0RW5VqeFixYsNPXGWecERERd9xxR9x44421un3UvVzLVHX/v3nz5pg2bVq0bt26shQlN+Vano4//vjYf//9o7y8vPIjxhGfv/uzoqIiSktLa3zbyI5cy9QXzZkzJzp27OgQU/VIruWpe/fukSRJ3HvvvVXG586dGxERvXv3/vobRVblWqaqs2rVqrj11ltj8ODBOVtuNkT1ITtphg0bFuvXr48///nPlWMbNmyIefPmxamnnlrt8dJzgXeiR8TgwYPj2muvjVGjRsXRRx8dL7zwQpSXl0eXLl2qXG7s2LFx0003xVlnnRUTJkyI9u3bR3l5eeWB73e8otOoUaOYOXNmDBo0KHr27BmjRo2KDh06xLp16+Lxxx+PfffdN+67776vnNN9990Xy5cvj4jPX0VesWJF/OpXv4qIzz+adeihh2Z6GciQXMvTggUL4oorrohu3brFt7/97bjrrruq/H9paelOH1Emt+Rapu6666649dZb47TTTosuXbrE5s2bY/HixfHwww/Hqaee6lBBOS7X8nTaaaftNLbjneeDBg2q8i4KclOuZermm2+OhQsXxqmnnhodO3aMt99+O26//fZYs2ZN3HnnnVFYWLjnFoPdlmt5KioqiilTpsSIESPiuOOOi3POOSfWrFkT06dPj+9+97sxdOjQPbcYZESuZWqHF198MVasWBFXXnnlTsepJXflWp5GjhwZU6dOjbFjx8Zzzz0XPXv2jGeffTZmzpwZPXv2jNNPP33PLQYZkWuZiog4+OCDY/jw4dGxY8dYvXp13HLLLdGyZcu49dZb98wisEtyMTs17TKHDRsWRx11VIwaNSpWrlwZrVu3jhkzZkRFRUX84he/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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "image_folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_9'\n",
        "visualize_images(image_folder_path)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 172
        },
        "id": "VAvKVIlgg87P",
        "outputId": "24ac5ccb-fc85-4dba-c492-10a744f9c4e8"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1500x300 with 10 Axes>"
            ],
            "image/png": "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QYMGeetnA9AY8vT2229H8+bNo3nz5jXanurJxUx98sknsXnz5tiwYUMsWrQopk+fHl26dIlvfvObtV8wvlIu5umaa66JDh06xPjx42u/QFRbLmZq7ty5UVRUFIWFhXHwwQdn7StaclEu5WnnOWTat28fJ5xwQhQWFkZhYWEMGTIkXnvttcwsGF8rlzK1O6WlpVFYWFipTGDPyaU89e/fP4qKiuKaa66Jxx57LDZu3BhPPPFEXHHFFXHEEUfE9773vcwtHKlyKVMff/zxbp982dkbPPPMMzVdJnYjl7JTHc8991z069cvmjSpXEsfeeSR8dFHH8XLL7+csevKqKSBmTNnThIRyYoVKyrGRo0alUREMnXq1Iqx999/PyksLEzy8vKSu+++u2L8pZdeSiIimTJlSsXYjh07krKyskrXs27duqSgoCC59tprK8Z+97vfJRGRLF68uGJs+/btybe+9a0kIpLHH388SZIkKS8vT3r06JEMHjw4KS8vr7jsRx99lBx00EFJcXFxtW5zUVFRMmrUqGptQ9U0xjwlSZKsWbMmadasWXLOOedUe1u+WmPK1Pz585OIqPjo379/smrVqiptS9U0ljytXLkyadq0abJ06dIkSZJkypQpSUQk77zzztduS/U0lkwdffTRyYwZM5IlS5Ykt9xyS3LIIYckEZHMmjXr6xeJKmsMebrkkkuSiEjatGmTnHTSSck999yTTJs2LWnRokXSvXv35MMPP6zaYlEljSFTX/buu+8m+fn5SUlJSbW24+s1ljzdf//9SceOHSs9Lh88eHCybdu2r18kqqUxZOriiy9OmjRpkrz22muVxs8888wkIpKJEyd+5fbsXmPIzpd9VZdZVFSUjB07dpfxBx54IImI5KGHHqrWddWVnHklekTEeeedV/F5q1atolevXlFUVBQlJSUV47169YpWrVrF2rVrK8YKCgoqnv0oKyuLd999N1q0aBG9evWqdGbYhx56KDp16hTDhg2rGGvWrFmcf/75lebx/PPPx5o1a+Lss8+Od999NzZv3hybN2+ODz/8ME444YT4+9//HuXl5Rm//WRWrubpo48+ipEjR0ZhYWFcd911VV8Qai3XMjVw4MB4+OGHY8GCBTFhwoTYe++9nQyyDuVSni655JIYMmRInHjiiTVbDDIilzL15JNPxqRJk2LYsGExYcKEeOaZZ+KQQw6Jq666KrZv316zBaJaciVP//vf/yIiokOHDvHAAw9ESUlJXH755XHbbbfFq6++6h0OdShXMvVlCxcujE8++cShXOpYLuWpXbt20bdv3/j1r38dixcvjv/7v/+LZcuWOfdVHcuVTJ133nnRtGnTKCkpieXLl8err74av/nNb2LRokURER5H7QG5kp3q2L59exQUFOwy3qxZs4rvZ6OcObFos2bNol27dpXGWrZsGd/4xjd2OR5Py5Yt4/3336/4ury8PGbOnBmzZs2KdevWRVlZWcX3vnjyoNdffz26d+++y8/78qEL1qxZExERo0aNSp3vli1bYr/99qviraOu5WqeysrK4swzz4zVq1fHgw8+GAcccMDXbkNm5GKm2rdvX3H8xREjRsTUqVOjuLg41qxZ46RYe1gu5emee+6J5cuXx4svvpi6PXteLmVqd/Lz82PixIkVhfqxxx5b5W2pvlzK0863tJeUlFR6y/HIkSPjnHPOieXLl1f655c9I5cy9WWlpaXRunXrGDJkSJUuT+3lUp7Wrl0bAwcOjDvuuCN+8IMfRETE97///ejatWuMHj06HnzwQdmqA7mUqUMPPTTmzZsXEyZMiGOOOSYiPn8iecaMGXHhhRd+5ckiqb5cyk51FBYW7va45zvPZZSt53PImRK9adOm1RpPkqTi86lTp8Y111wTY8eOjV/+8pfRunXraNKkSfzkJz+p0bMsO7eZNm1a9OnTZ7eXsePJbrmap/PPPz/uv//+KC0trXSiEPa8XM3UF40YMSKuvvrqWLJkieNa72G5lKfJkyfHyJEjIz8/v+L4wjtPTrthw4b45JNPPOFXB3IpU2kOPPDAiPj8JEzsWbmUp537ny+ftK9p06bRpk2bSv/MsufkUqa+aP369bFs2bK44IILYu+99672XKiZXMrT3LlzY8eOHTF06NBK4ztfcfrkk08q0etALmUq4vP/64YNGxYrV66MsrKy6NevX8XJJ3v27FntOZEu17JTVR07doy33nprl/GdY9n6/1/OlOi1sXDhwhg4cGD88Y9/rDT+wQcfRNu2bSu+7tKlS6xevTqSJKn0DM4rr7xSabvu3btHRMS+++7rRB6NULbmafLkyTFnzpyYMWNGnHXWWTX+OdS9bM3Ul+18y9WWLVsy9jPJvGzL04YNG2LevHm7PSRCv3794rDDDovnn3++2j+XupNtmUqz8+2vX361D9kl2/J0+OGHR0TExo0bK43vPLm2PGW/bMvUF82fPz+SJHEolwYk2/K0adOmSJKk0itQIyI+/fTTiIj47LPPqv0zqVvZlqmd8vPz44gjjqj4eueJtnVc2SNbs1MVffr0iWXLlkV5eXmld/o9/fTT0bx586x9sianjoleU02bNq30bE5ExIIFC3Z5sDx48ODYuHFj/OUvf6kY27FjR9x2222VLnf44YdH9+7dY/r06RXHUfyid955J4OzJ9tkY56mTZsW06dPj6uuuiomTZpUnZtDFsi2TG3evHmX+UREzJ49OyIi+vfv/9U3iHqVbXlatGjRLh9nnHFGRETccccdceONN1br9lH3si1Tu/v+tm3bYsaMGdG2bduKUpTslG15Ov7442P//feP0tLSircYR3z+6s+ysrIoLi6u8m2jfmRbpr5o3rx50blzZ4eYakCyLU89e/aMJEni3nvvrTQ+f/78iIjo27fv198o6lW2ZWp31qxZE7feemsMHTo0a8vNxqghZCfNiBEjYtOmTfHnP/+5Ymzz5s2xYMGCOPXUU3d7vPRs4JXoETF06NC49tprY8yYMXH00UfHCy+8EKWlpdGtW7dKlxs/fnzcdNNNcdZZZ8WkSZOiY8eOUVpaWnHg+53P6DRp0iRmz54dQ4YMid69e8eYMWOiU6dOsXHjxnj88cdj3333jfvuu+8r53TffffFypUrI+LzZ5FXrVoVv/rVryLi87dmHXrooZleBjIk2/K0aNGiuOKKK6JHjx7x7W9/O+66665K3y8uLt7lLcpkl2zL1F133RW33nprnHbaadGtW7fYtm1bLF26NB5++OE49dRTHSooy2Vbnk477bRdxna+8nzIkCGVXkVBdsq2TN18882xePHiOPXUU6Nz587x1ltvxe233x7r16+PO++8M/Lz8/fcYlBr2ZangoKCmDZtWowaNSqOO+64OOecc2L9+vUxc+bM+O53vxvDhw/fc4tBRmRbpnZ68cUXY9WqVXHllVfucpxasle25Wn06NExffr0GD9+fDz33HPRu3fvePbZZ2P27NnRu3fvOP300/fcYpAR2ZapiIiDDz44Ro4cGZ07d45169bFLbfcEq1bt45bb711zywCNZKN2alqlzlixIg46qijYsyYMbF69epo27ZtzJo1K8rKyuIXv/hF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\n"
          },
          "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": "1785c5f3-157e-4c45-e844-be22f537727a"
      },
      "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"
          ]
        }
      ],
      "source": [
        "\n",
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_0'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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",
      "source": [
        "from google.colab import drive\n",
        "drive.mount('/content/drive')"
      ],
      "metadata": {
        "id": "TlaYmvEg6-gl",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "e57d6ce4-e503-4c32-e5a5-c905c39394db"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Mounted at /content/drive\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wHOlJmhh9d3A",
        "outputId": "acb15e34-e945-43cf-ac31-512d6f09edfc"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_1'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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": "0b96bb85-efbe-473d-e4c1-fb4d7961f7b9"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_2'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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": "7620830d-9103-461b-9e8d-68b3a8dad5d9"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_3'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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": "ec5aa123-6caf-4d48-aaa1-c1c2a6101a76"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_4'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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": "a2c57d81-daa3-4405-d761-81230f985800"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_5'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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": "56c3aaf7-aa59-402a-cd4b-2b8c8ec9ddad"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_6'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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": "a57a89d1-d8f3-4b39-c899-23dd3117abf5"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_7'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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",
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_8'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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}\")"
      ],
      "metadata": {
        "id": "Agia_QlwUiEH",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "5578823a-791b-47c1-b694-4c100495224a"
      },
      "execution_count": null,
      "outputs": [
        {
          "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"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "F3OAaSXBM625",
        "outputId": "1ecac8a7-27ae-4f25-cfb4-738024464753"
      },
      "outputs": [
        {
          "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"
          ]
        }
      ],
      "source": [
        "folder_path = '/content/drive/MyDrive/25-50-10/Images/25-50-10_9'  # Path to the folder containing the images\n",
        "\n",
        "for i in range(1, 11):\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
}