{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "CJ8_Kzeu7Amv",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "CJ8_Kzeu7Amv",
    "outputId": "51fb3947-3642-48fe-cc29-63a0d7bcd95e"
   },
   "outputs": [],
   "source": [
    "# Install libraries if needed\n",
    "# !pip install noise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2225b337",
   "metadata": {
    "id": "2225b337"
   },
   "outputs": [],
   "source": [
    "# Import libraries, the code is built on PyTorch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import random\n",
    "import warnings\n",
    "import torch\n",
    "\n",
    "\n",
    "from torch.utils.data import DataLoader, Dataset\n",
    "from torchvision import transforms\n",
    "from torchvision.datasets import MNIST\n",
    "from noise import pnoise2\n",
    "from itertools import groupby\n",
    "\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "# plt.rcParams[\"font.family\"] = \"serif\"\n",
    "# plt.rcParams[\"font.serif\"] = \"Times New Roman\"\n",
    "# plt.rcParams[\"mathtext.fontset\"] = \"cm\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "AAzsj4OpSNNL",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "AAzsj4OpSNNL",
    "outputId": "64193c48-58e1-417d-a2f4-785203a80183"
   },
   "outputs": [],
   "source": [
    "# Load the MNIST dataset\n",
    "train_dataset = MNIST(root=\"./data\", train=True, download=True, transform=transforms.ToTensor())\n",
    "test_dataset = MNIST(root=\"./data\", train=False, download=True, transform=transforms.ToTensor())\n",
    "# Put them together to manipulate and then split to train, validation, and test at the end\n",
    "data_set = train_dataset + test_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "-fmQJ_FLqO19",
   "metadata": {
    "id": "-fmQJ_FLqO19"
   },
   "outputs": [],
   "source": [
    "# Define X transformations, we use a random rotation theta between 0 and Pi/2, and a scale factor between 0.5 and 1.5.\n",
    "theta = torch.randint(0,90,(len(data_set),), dtype=torch.float32)\n",
    "scales = torch.rand((len(data_set),), dtype=torch.float32) + 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "suhGckGAXKG2",
   "metadata": {
    "id": "suhGckGAXKG2"
   },
   "outputs": [],
   "source": [
    "# Define Y transformation, we use a random Perlin correlated noise in 2d with noise_factor between 0 and 1, then generate all the backgrounds in noise.\n",
    "noise_factor = torch.rand((len(data_set),), dtype=torch.float32)\n",
    "noise = torch.Tensor([[[pnoise2(int(j)*noise_factor[i] , int(k)*noise_factor[i] , 1) for j in range(28)] for k in range(28)] for i in range(len(data_set))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "Xu1OylWg7gUQ",
   "metadata": {
    "id": "Xu1OylWg7gUQ"
   },
   "outputs": [],
   "source": [
    "# Save the backgrounds with the factors if needed\n",
    "np.save('backgrounds', noise)\n",
    "np.save('noise_factors', noise_factor)\n",
    "\n",
    "# Upload and read the backgrounds with the factors file if you saved it before\n",
    "#bck_file = np.load('backgrounds.npy', allow_pickle=True)\n",
    "#factors_file = np.load('noise_factors.npy', allow_pickle=True)\n",
    "#noise_factor = factors_file\n",
    "#noise = bck_file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "yKjV4MzUlKfb",
   "metadata": {
    "id": "yKjV4MzUlKfb"
   },
   "outputs": [],
   "source": [
    "# Do the transformation, and assign each to its array\n",
    "X = [transforms.RandomAffine(degrees=int(theta[i]), scale=(scales[i],scales[i]))(data_set[i][0]) for i in range(len(data_set))]\n",
    "Y = [torch.clamp(data_set[i][0]+noise[i,:],0,1) for i in range(len(data_set))]\n",
    "labels = [data_set[i][1] for i in range(len(data_set))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "G30kq0B251gs",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 472
    },
    "id": "G30kq0B251gs",
    "outputId": "0ddbc497-dd63-45ff-da20-1255e4bd070c"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Calculating the correlation between all the pairs of images of X and Y\n",
    "cor_XY = [np.corrcoef(X[i].reshape(28*28),Y[i].reshape(28*28))[0][1] for i in range(len(data_set))]\n",
    "\n",
    "# Plot the correlations\n",
    "plt.hist(cor_XY, bins=200);\n",
    "plt.xlabel('Correlation')\n",
    "plt.title('Probabilty distribution of the correlation between the two views after different transformations');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "Qpp_nOPtSNUu",
   "metadata": {
    "id": "Qpp_nOPtSNUu"
   },
   "outputs": [],
   "source": [
    "# Create a function to plot X and Y pairs side by side\n",
    "def plot_samples1(dataset_X, dataset_Y, label, num_samples=5):\n",
    "    plt.figure(figsize=(num_samples*3, 5))\n",
    "    for i in range(num_samples):\n",
    "        idx = random.randint(0, len(dataset_X) - 1)\n",
    "        x = dataset_X[idx]\n",
    "        y = dataset_Y[idx]\n",
    "\n",
    "        x_np = x.numpy().squeeze(0)\n",
    "        y_np = y.numpy().squeeze(0)\n",
    "\n",
    "        plt.subplot(2, num_samples, i + 1)\n",
    "        plt.title('True = '+str(label[idx])+', Corr = '+str(np.round(np.corrcoef(x.reshape(28*28),y.reshape(28*28))[0][1],2)))\n",
    "        plt.imshow(x_np, cmap=\"gray\")\n",
    "        plt.axis(\"off\")\n",
    "\n",
    "        plt.subplot(2, num_samples, num_samples + i + 1)\n",
    "        plt.imshow(y_np, cmap=\"gray\")\n",
    "        plt.axis(\"off\")\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "zfbGOCwkUc67",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 373
    },
    "id": "zfbGOCwkUc67",
    "outputId": "fe5c829a-a022-43b9-aa8c-79dabbc3d98c"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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9v3ONse+1iLxGte2aNFCxZMnT1bx999/74w55phjIvdr+c5XtvHShg0bVGybC/r245uv9p7Btx/bUM42N/Q1VbL3NPZ9ISKyffv2yMfOdnHeox06dHC22Wuer9mZnSN2vsZpNmnvD0RETjnlFBXbJoUi7v20rymtNWnSJBX7msl98cUXKrbNeUXce1FfQzkrTkO5K664QsX2GiIi8t5770XuJ9P51h5xGpf9/PPPKvbdI5xwwgkqtnNg6dKlkY9jm8WKiNx3330qrlmzppOzZs0aFffo0SPysez9nz2nibjrKdtMzifOfPz73/+u4gcffNDJsWss2xBPxH8vkRc+WQcAAAAAIGFYrAMAAAAAkDAs1gEAAAAASJg9WrPu+zf5tv7Q1oSJiHz66acqXrduXeRj2XoEW+cuIvLoo4+quH79+k7O4YcfruK5c+eqeM6cOc6Y5557LvL4pkyZouJTTz3VybG1ova5iVOf4uOrxUR6tfu2Pl1E5NJLL1WxrQn2eeONN1R83nnnOTlnnnmmikuWLOnk2Br1unXrqtjW7YiIrF69WsVTp07N+2DFXxNkj9nWLNkaYRGRrl27qvitt96KfOzrr7/e2fbYY49Fjsskvhp1a9CgQSreuHFj5Bhb5y4isnLlShXb86uvF4GtEXvttdecHFur6+uFYPXq1UvF8+bNc3LsNt9c9PVmsGxt/jXXXKPiv/71r86YadOmqdg3p62GDRs622y9caaLU/P773//W8Vx5mubNm2cbbbG0l4XfbXmzzzzTORjWfa+Q0Skc+fOKra9PJo3b+6Mse8VX72i774nym+//ZZnLOK/jlj2d6hVq5aT46stzXb2NfHVr9r6bt98tTXqVrFixZxttkbd9koScXtA3HnnnXk+johInTp1VOw7t9t70RdffNHJsXPad022vTssX32/7X3iq0cvX768igcMGBCZkw3i9LH58ssvVRynbtzHt17amb1Oi7j3jXEep3Xr1pH7mTVrlop9PZ/sfa29Tou4z01BsXPWd49t176+/hK+825e+GQdAAAAAICEYbEOAAAAAEDCsFgHAAAAACBhWKwDAAAAAJAwQdwmW0EQ5Lsbl6/pT+3atVW8du1aJ8c2dbNskzoRkdmzZ6vY18jANsWxjVZERA455BAVf/311yq+9tprnTGXXHKJin2NSfr06aNiX7MNa/Pm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bdiwQcWXX365kxOncd7O+GQdAAAAAICEYbEOAAAAAEDCsFgHAAAAACBhgjg1DiIiQRDES8wnXx3bihUr9sRDObp06eJse+utt1R85513qrhfv35pPVatWrVUbOvPRNx6iXnz5ql4b9byhmEYRGcll52vth5NRKRt27Yq/uCDD5yck08+WcW21lxEZPjw4fk+vs6dO6v4nXfeiRxz6qmnOttsvWacPgf333+/ij/88EMnZ8yYMSpu2LChk2PrIfv06aPikSNHOmPKlSun4o8++sjJ6d69u4pt3ZOIW9OXbfO1oMTpWWDrxn3nmVmzZqm4U6dOTo7tP+I7v44ePVrFCxYscHL2Ftsj5K9//auT89BDD6nY17uhZMmSKo5Tn858TZ+ta/X1CLE16ldccYWTU6NGDRU/8cQTTo6tjSxWrFjk8W3bti3y+Czffm1PBbufrVu3Ru7X1gSLiBx99NEqHjFiROR+CuN8PeaYY5xtU6ZMKZDjsa655hoVP/74406O7cth54eIyK+//prn47Rq1crZZvtN+GqEbc16nLln2fp5Efee16d3794qtudkn0yfryLx7mEtX38v20PB1+Nj06ZNee7X15vBPpa9Doq4de033XSTk/Pwww+r+Oqrr1ax75obZw5YNWvWdLYtWbIk3/uxvSxsfb+I+56K876LmrN8sg4AAAAAQMKwWAcAAAAAIGFYrAMAAAAAkDAs1gEAAAAASJg92mDONjYQETnooINU7GtKYJtXfP311/l96MSxzUpKlSrl5GzevFnFtlmYbei1J2V6g4491QDJNkgTcee0bbRlGxmJiGzYsEHFzZs3d3LGjx+v4jp16jg5P/744y6ONCVOY4s44jSYi+PQQw9VsW2i6GOb8Ym4DfkK43ytWLGis+3nn3/O92OXKFFCxbaBiojI+vXrVeybD0cddZSKX3rppcjHtg2w7LH4xGlK53uvHHbYYSoeNWpU5H7i6Nq1q4q/+OILJ2fp0qUqLgzz1TZEmj9/vpNjX+8ffvjByalQoYKKGzdurGLbDNPnrrvucrb17ds3clzdunVV/P3330eOsWxDPBG3yaOv0ZZtXGSbajZr1swZM2PGDBWne/63c/rNN9/MqvmazrXU58ILL3S2vf322yq2TbZKly7tjLHnVx97r3zDDTc4OVENkH33GbbxW4MGDZwce7/qa4ibzv2AfS62b9/u5NjrUcuWLZ0cey184YUXMnq+ioicfPLJas6OHTu2QPZ75plnOtvs9ck2ofOtV+w9bK9evZycRx55JPJ47D31mjVrIsfUq1dPxb6m5LaB9Gmnnebk/O1vf8vzcWxTRxF3nVa2bFknp3Xr1iqO00CaBnMAAAAAAGQYFusAAAAAACQMi3UAAAAAABImds06AAAAAADYO/hkHQAAAACAhGGxDgAAAABAwrBYBwAAAAAgYVisAwAAAACQMCzWAQAAAABIGBbrAAAAAAAkzP8DMJex+VqM7v0AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1296x360 with 12 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot a few instances of X and Y pairs side by side\n",
    "plot_samples1(X, Y, labels, 6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "lZ4LqrCLUc9V",
   "metadata": {
    "id": "lZ4LqrCLUc9V"
   },
   "outputs": [],
   "source": [
    "# Split into training, validation, and testing, while maintaing the statstics\n",
    "# Flatten the data to be ready for training after\n",
    "X = [X[i].reshape(28*28) for i in range(len(data_set))]\n",
    "Y = [Y[i].reshape(28*28) for i in range(len(data_set))]\n",
    "\n",
    "# Create dictionaries to group data by labels\n",
    "data_by_label = {label: [] for label in set(labels)}\n",
    "\n",
    "# Use itertools.groupby to group by label in temp_x and temp_y\n",
    "temp_x = {label: list(group) for label, group in groupby(\n",
    "    sorted([[labels[i], theta[i], scales[i], X[i]] for i in range(len(data_set))], key=lambda x: x[0]), key=lambda x: x[0])}\n",
    "temp_y = {label: list(group) for label, group in groupby(\n",
    "    sorted([[labels[i], noise_factor[i], Y[i]] for i in range(len(data_set))], key=lambda x: x[0]), key=lambda x: x[0])}\n",
    "\n",
    "# Shuffle whithin each group with the same label\n",
    "for label, group in temp_x.items():\n",
    "    random.shuffle(group)\n",
    "\n",
    "for label, group in temp_y.items():\n",
    "    random.shuffle(group)\n",
    "\n",
    "# Concatenate the shuffled groups to get the final shuffled list for the views X and Y\n",
    "temp_x = [elem for label in range(10) for elem in temp_x[label]]\n",
    "temp_y = [elem for label in range(10) for elem in temp_y[label]]\n",
    "\n",
    "for i, label in enumerate(labels):\n",
    "    data_by_label[label].append((temp_x[i][3], temp_y[i][2], temp_x[i][0], temp_x[i][1], temp_x[i][2], temp_y[i][1]))\n",
    "    # data_by_label[label].append((X[i], Y[i], label, theta[i], scales[i], noise_factor[i]))\n",
    "\n",
    "# Define the proportion for each subset\n",
    "train_ratio = 0.8\n",
    "test_ratio = 0.1\n",
    "validation_ratio = 0.1\n",
    "\n",
    "# Initialize lists for each subset\n",
    "train_set, test_set, validation_set = [], [], []\n",
    "\n",
    "# Split data by labels into subsets\n",
    "for label, data_list in data_by_label.items():\n",
    "    random.shuffle(data_list)\n",
    "    total_samples = len(data_list)\n",
    "\n",
    "    train_size = int(total_samples * train_ratio)\n",
    "    test_size = int(total_samples * test_ratio)\n",
    "\n",
    "    train_set.extend(data_list[:train_size])\n",
    "    test_set.extend(data_list[train_size:train_size + test_size])\n",
    "    validation_set.extend(data_list[train_size + test_size:])\n",
    "\n",
    "# Shuffle the subsets to ensure randomness\n",
    "random.shuffle(train_set)\n",
    "random.shuffle(test_set)\n",
    "random.shuffle(validation_set)\n",
    "\n",
    "# Extract X, Y, labels, theta, scale and noise factor for each subset, if regenerating\n",
    "tr_X, tr_Y, tr_labels, tr_theta, tr_scale, tr_noise = zip(*train_set)\n",
    "ts_X, ts_Y, ts_labels, ts_theta, ts_scale, ts_noise = zip(*test_set)\n",
    "val_X, val_Y, val_labels, val_theta, val_scale, val_noise = zip(*validation_set)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "aaa83b66",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create a dictionary to store the datasets\n",
    "data_dict = {\n",
    "    'train_X': np.array(tr_X),\n",
    "    'train_Y': np.array(tr_Y),\n",
    "    'train_labels': np.array(tr_labels),\n",
    "    'train_theta': np.array(tr_theta),\n",
    "    'train_scale': np.array(tr_scale),\n",
    "    'train_noise': np.array(tr_noise),\n",
    "    'test_X': np.array(ts_X),\n",
    "    'test_Y': np.array(ts_Y),\n",
    "    'test_labels': np.array(ts_labels),\n",
    "    'test_theta': np.array(ts_theta),\n",
    "    'test_scale': np.array(ts_scale),\n",
    "    'test_noise': np.array(ts_noise),\n",
    "    'validation_X': np.array(val_X),\n",
    "    'validation_Y': np.array(val_Y),\n",
    "    'validation_labels': np.array(val_labels),\n",
    "    'validation_theta': np.array(val_theta),\n",
    "    'validation_scale': np.array(val_scale),\n",
    "    'validation_noise': np.array(val_noise)\n",
    "}\n",
    "\n",
    "# Save the dictionary to a file\n",
    "np.savez('data.npz', **data_dict)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "e143004b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create a dictionary to store the datasets\n",
    "data_dict_params = {\n",
    "    'theta': theta,\n",
    "    'scales': scales,\n",
    "    'noise_factor': noise_factor,\n",
    "}\n",
    "\n",
    "# Save the dictionary to a file\n",
    "np.savez('noisy_params.npz', **data_dict_params)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "ecb1e13d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Load the dictionary from the file\n",
    "# loaded_data = np.load('data.npz', allow_pickle=True)\n",
    "\n",
    "# # Assign datasets to variables\n",
    "# tr_X = loaded_data['train_X']\n",
    "# tr_Y = loaded_data['train_Y']\n",
    "# tr_labels = loaded_data['train_labels']\n",
    "# tr_theta = loaded_data['train_theta']\n",
    "# tr_scale = loaded_data['train_scale']\n",
    "# tr_noise = loaded_data['train_noise']\n",
    "\n",
    "# ts_X = loaded_data['test_X']\n",
    "# ts_Y = loaded_data['test_Y']\n",
    "# ts_labels = loaded_data['test_labels']\n",
    "# ts_theta = loaded_data['test_theta']\n",
    "# ts_scale = loaded_data['test_scale']\n",
    "# ts_noise = loaded_data['test_noise']\n",
    "\n",
    "# val_X = loaded_data['validation_X']\n",
    "# val_Y = loaded_data['validation_Y']\n",
    "# val_labels = loaded_data['validation_labels']\n",
    "# val_theta = loaded_data['validation_theta']\n",
    "# val_scale = loaded_data['validation_scale']\n",
    "# val_noise = loaded_data['validation_noise']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25fa03e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Load the dictionary from the file\n",
    "# loaded_data_params = np.load('noisy_params.npz', allow_pickle=True)\n",
    "\n",
    "# # Assign datasets to variables\n",
    "# theta = loaded_data_params['theta']\n",
    "# scales = loaded_data_params['scales']\n",
    "# noise_factor = loaded_data_params['noise_factor']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "76V-9Ig5NCML",
   "metadata": {
    "id": "76V-9Ig5NCML"
   },
   "outputs": [],
   "source": [
    "# Create a function to plot X and Y pairs side by side\n",
    "def plot_samples2(dataset_X, dataset_Y, label, num_samples=5):\n",
    "    plt.figure(figsize=(num_samples*3, 5))\n",
    "    for i in range(num_samples):\n",
    "        idx = random.randint(0, len(dataset_X) - 1)\n",
    "        x = dataset_X[idx]\n",
    "        y = dataset_Y[idx]\n",
    "\n",
    "        x_np = x.reshape(28,28)\n",
    "        y_np = y.reshape(28,28)\n",
    "\n",
    "        plt.subplot(2, num_samples, i + 1)\n",
    "        plt.title('True = '+str(label[idx])+', Corr = '+str(np.round(np.corrcoef(x.reshape(28*28),y.reshape(28*28))[0][1],2)))\n",
    "        plt.imshow(x_np.reshape(28,28), cmap=\"gray\")\n",
    "        plt.axis(\"off\")\n",
    "\n",
    "        plt.subplot(2, num_samples, num_samples + i + 1)\n",
    "        plt.imshow(y_np.reshape(28,28), cmap=\"gray\")\n",
    "        plt.axis(\"off\")\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "eyxvtQvgMyyE",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 372
    },
    "id": "eyxvtQvgMyyE",
    "outputId": "dba431b2-4c16-4fa5-dc86-afc3b5fb3047"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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Oii3p07Zu+++q+LTTz8918fw1aSPGzcu5TGl2/PPPx+a869//Wu/m68+xYsXV7HvOli1alUV/+1vf1Px8uXLUzp3w4YNVdytWzcnp1+/fjkew45FROTbb79Vse99Wr16dRU/99xzTs7JJ5+c47l99fC+bemwP15fU1WyZEkVFyqkv1sYNGiQs8+ll16a6/MMHTrU2da7d28Vb9u2TcW2Pt7Hd79ir2m+e5GyZcuqOD/rbjN9vopInszXKPXcUep777zzThXXqVPHyenZs2f0ge1BlSpVQnNWrlzpbLM1yz72syZKf5xUPPDAA842e29cAOZrnl1jfZ9pF1xwgYqHDRuWF6f2euihh1Rs59GECROcfcqXL6/iTz/91Mlp0KBB6LltLwh73+u7Z9i+fXvocVOxpznLN+kAAAAAAMQEi3QAAAAAAGKCRToAAAAAADGRkb+TXrhwYWebrybBsr/Juy/dcccdKi5atKiTY+ssbB1QXtWfI8nWOopEq1O39Tu2xubGG2/cu4HlwgcffKDiKDXql112Weg2W7OUl2xt88MPP+zkTJo0aV8NJ6PY+t0ov/1sa76fffZZJ8f+PrSvrm3WrFlRhqjY+sfx48fn+hgibr8RFBx//vlnjn+eSv25j++3qe29xv3335/r4zZp0sTZVqNGDRX7Pmf47ed965133lFx8+bNQ/fx9TGYP3/+Xo/l559/3utjpJPtl/T666/vs3P7atCRuq5duzrbXnrpJRVH7VWWDjfccIOK7f1yqmOx+23dutXJeeqpp1R8/fXXp3SuvMQ36QAAAAAAxASLdAAAAAAAYoJFOgAAAAAAMcEiHQAAAACAmMjIxnE+tpHRmjVrnJwiRfLv4d5zzz0q7t+/f+g+11xzTV4NB2l03XXXqXjmzJn77Nxnnnmmit99991cH+Of//yns802a/roo4+cnAcffDDH41auXNnZ9uabb4aOZ86cOSpesmSJk2MbpCEpleaYtWrVUvHll1/u5EybNk3FvvkQhW1A98wzz6R0nDC+hom2uWjbtm1V7GtQY7f5GuahYBg8eLCzbeTIkSr+5Zdfcn3cSpUqOdtsk9KdO3fm+riIrnHjxiqO8hl9yimnhOako0mciMjw4cNVPHv27LQc16pbt66zLdVmndavv/6q4latWqXluEivk08+Ob+HkC989zUvv/xyPowkd/gm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fWydta01FHE/p333B7bm2NY5+uaDrc196aWXnJxOnTqp2PYSERGZMGGCim+77TYnx+rWrZuK33nnHSfnggsuULHvOm1r5guaG264wdlme3X06dPHybHXp7vvvtvJsfevdk5HqT/39TX6+OOPVey7r0gkEqHHtubPn69iX48CW/Pru684+uijczzPo48+GjoW3/jtOsLX46cgsvd7EydOdHJ865Gw4zRq1MjJsesw21/G3pOJuJ+Na9eudXJWr16tYl/vHfsYvvnmGxX76uFtzynfnLCfE6nwfW7Ye+FU+izlBt+kAwAAAAAQEyzSAQAAAACICRbpAAAAAADERMo16bZmQcT9rb369es7Ofa36ny/kz5ixAgV+2rOrGLFioXm2LoF329chtW72BplEbdGwVfTY2vDfL9VbOsW7e9D+tjfRff9duby5ctVbGuxRfy/c5vJ7O+Op/o75FHYeW5r0n3s7zg/+eSTTo4ds2++WrZOzdYfioiUK1dOxb560vfffz/0XHautWnTRsVvvfWWs8/ixYtV7KvF9G2zovzmakHnq4e111fbJ0BEZObMmSq2v3nuq2M//vjjVWznkIhbW3bYYYc5OX/7299UbGs8FyxY4Oxja3EnTZrk5Owrp556qrPN1inbzy8RkTVr1uTZmPKDff/5fiPZfs74Phft9cr3W7a2lrV37945HkPErZeMUsd62WWXOds6duyoYlvPaeeziMjkyZNDc+x7xVeLa/ss2NpH3/vfV4NuvfLKKyq2vxUsIrJq1arQ42Qy+/nr43sOhg4dqmJfTfq8efNyPM4ll1zi7GN/39xXD297cQwaNMjJsb+DfuSRR6rYV0t+xRVXONvCtGvXztlme8fYx/ndd985+9j3k33ufFL9vfBMY38fvEaNGk7OokWLVFy8eHEnx96n+fph2WPbc/uun7b3yvfff+/k2Dnhu6+09ygNGjRQsb1fERH54YcfVOz77ffp06ereMiQIU6O7znNzq6dRPxrrLzEN+kAAAAAAMQEi3QAAAAAAGKCRToAAAAAADHBIh0AAAAAgJgIfA1LvIlBEC0xl/79738725577jkV2yYfxx13nLOPbWR0xBFHODlPPfWUii+//HInxzZDaNy4sYo3btzo7GObCX3zzTdOjm3W4GuQ0aJFCxXbhiNdunRx9rGNTHxNSZ599llnW5hEIhGE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\n",
      "text/plain": [
       "<Figure size 1296x360 with 12 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot a few instances of X and Y pairs side by side\n",
    "plot_samples2(tr_X, tr_Y, tr_labels, 6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1df5a37b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python [conda env:torchEnv]",
   "language": "python",
   "name": "conda-env-torchEnv-py"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
