{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "679ae2e9",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/nkotelevskii/github/uncertainty-measures-variance/.venv/lib/python3.12/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "\n",
    "sys.path.insert(0, \"../\")\n",
    "\n",
    "from torch.utils.data import DataLoader\n",
    "from datasets.mosaic_datasets import build_id_and_ood\n",
    "from source.models.resnet import get_resnet18\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch\n",
    "from tqdm.auto import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a9be0f47",
   "metadata": {},
   "outputs": [],
   "source": [
    "class SimpleCNN(nn.Module):\n",
    "    def __init__(self, in_channels=1, num_classes=1):\n",
    "        super(SimpleCNN, self).__init__()\n",
    "\n",
    "        self.conv1 = nn.Conv2d(in_channels, 4, kernel_size=5, padding=2)\n",
    "        self.pool1 = nn.MaxPool2d(kernel_size=4, stride=4)\n",
    "        self.conv2 = nn.Conv2d(4, 8, kernel_size=3, padding=1)\n",
    "        self.pool2 = nn.MaxPool2d(kernel_size=4, stride=4)\n",
    "\n",
    "        self.fc1 = nn.Linear(8 * 4 * 4, 16)\n",
    "        self.fc2 = nn.Linear(16, num_classes)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = torch.relu(self.conv1(x))\n",
    "        x = self.pool1(x)\n",
    "        x = torch.relu(self.conv2(x))\n",
    "        x = self.pool2(x)\n",
    "\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        x = self.fc2(x)\n",
    "\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "babe72e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Using downloaded and verified file: ../data/test_32x32.mat\n",
      "ID sample: torch.Size([1, 64, 64]) 1472.0\n",
      "OOD sample: torch.Size([1, 64, 64]) nan\n",
      "Batch ID: torch.Size([128, 1, 64, 64]) torch.Size([128])\n"
     ]
    }
   ],
   "source": [
    "id_train, id_test, ood_fashion, ood_cifar10, ood_svhn, ood_mix = build_id_and_ood(\n",
    "    root=\"../data\",\n",
    "    tile_size=32,\n",
    "    seed=42,\n",
    "    n_id_train=10000,\n",
    "    n_id_test=3000,\n",
    "    n_ood_each=3000,\n",
    "    download=True,\n",
    ")\n",
    "\n",
    "x, y = id_train[0]\n",
    "print(\"ID sample:\", x.shape, y.item())\n",
    "x_ood, y_ood = ood_fashion[0]\n",
    "print(\"OOD sample:\", x_ood.shape, y_ood.item())\n",
    "\n",
    "loader_id = DataLoader(id_train, batch_size=128, shuffle=True, num_workers=16)\n",
    "loader_ood = DataLoader(ood_fashion, batch_size=128, shuffle=False, num_workers=16)\n",
    "\n",
    "bx, by = next(iter(loader_id))\n",
    "print(\"Batch ID:\", bx.shape, by.shape)  # [64, 1, 64, 64], [64]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "430dbe10",
   "metadata": {},
   "outputs": [],
   "source": [
    "batch_ind = next(iter(loader_id))\n",
    "batch_ood = next(iter(loader_ood))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e44f1e93",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1, 64, 64])\n",
      "torch.Size([1, 64, 64])\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA7sAAAH6CAYAAADGAVsWAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAaFNJREFUeJzt3Xd8VHXa//8rCaSTQgoJLUAokc6iFJGigBEFpKgLWEDsKLfo6uruugKiy9pFUOyoCOhXVMS9FYQV0aW4CkoR6YReEkgCIZXk/P7wl9yE5LoSDoRyeD0fDx67nvecmTNnTplPZua8fRzHcQQAAAAAAA/xPdsLAAAAAADA6cZgFwAAAADgOQx2AQAAAACew2AXAAAAAOA5DHYBAAAAAJ7DYBcAAAAA4DkMdgEAAAAAnsNgFwAAAADgOQx2AQAAAACew2AXEBEfHx8ZN27cab3PrKwsiY2NlRkzZpzW+0XVGDdunPj4+Jz0fJ06dZI///nPVbBEAHD+adCggYwYMeK03mdRUZG0bNlSnnrqqdN6v5U1YsQICQ0NrdRtq+L9BM5/bvaLdevWSbVq1WTt2rVVs1AXCAa7F5B3331XfHx85KeffiqZVvwGv/hfcHCw1K9fX/r16yfTpk2TvLy8St//mjVr5LrrrpOEhAQJDAyUOnXqSO/evWXy5MlV8XTOeZMmTZIaNWrIkCFDSqYVr29fX1/ZuXNnmXkOHz4sQUFB4uPjI/fdd1/J9JSUlJLX6JNPPikzX/H9pqWllUwr7+RcVFQk77//vnTs2FFq1qwpNWrUkKZNm8ott9wiy5cvF5HfD8jHbxPav3ffffdUV5EnPPLII/LKK6/Ivn37zvaiADD8+uuvctNNN0mdOnUkICBAateuLTfeeKP8+uuvp2We4nNs8b/AwECpXbu2JCcny8svvyxHjhyp9LKmpKTIrbfeKomJiRIYGChxcXHSrVs3GTt2rKvnfr6bNWuW7Ny5s9R58cT1ffy/Rx999Cwu7dlTfP7u1atXufmbb75Zso7Key9Yq1Ytyc7OLvd++/btW2raie9TRERSU1Pl/vvvl6SkJAkKCpLY2Fjp0KGDPPLII5KVlSXffvttpd5fuPnDsxc1b95crrnmGnn88cfP9qKc16qd7QXAuWHq1KkSGhoqeXl5snv3bpk/f76MHDlSXnrpJfnXv/4l9erVM+dfunSpXH755VK/fn254447JC4uTnbu3CnLly+XSZMmyejRo8/QMzk3FBQUyKRJk+SBBx4QPz+/MnlAQIDMmjWrzCeCn376aYX3/cQTT8igQYNcnQz+53/+R1555RW59tpr5cYbb5Rq1arJhg0b5KuvvpJGjRpJp06d5KWXXpKsrKySeb788kuZNWuWvPjiixIdHV0y/dJLLz3pxz+XPfbYY67eIF177bUSFhYmr776qjzxxBNVsGQATtWnn34qQ4cOlZo1a8ptt90mDRs2lJSUFHn77bdl9uzZ8uGHH8rAgQNPeR6R34/RDRs2lIKCAtm3b598++23MmbMGHnhhRdk7ty50rp1a3NZN2/eLJdccokEBQXJyJEjpUGDBrJ3715ZuXKlPP300zJ+/PjTum7OB88++6wMGTJEwsPDy2TF6/t4LVu2PFOLVkZOTo5Uq3b23l4HBgbKokWLZN++fRIXF1cqmzFjhgQGBkpubm658x44cECmTp0qf/rTn076cQ8dOiQXX3yxHD58WEaOHClJSUly8OBBWb16tUydOlXuueceueiii2T69Oml5vvLX/4ioaGh8re//e2kH/N8smHDBvH1PfnPGO+++265+uqrZcuWLZKYmFgFS3YBcHDBmDZtmiMizo8//lgybezYsY6IOKmpqWVu/8EHHzi+vr5Ox44dK7zvq6++2omJiXHS09PLZPv37z+l5T4TRMQZO3bsabu/Tz/91BERZ/PmzaWmF6/vQYMGOW3bti0zX+/evZ3Bgwc7IuLce++9JdO3bdvmiIjTtm1bR0ScTz75pNz7Pf51HD58uBMSElLy3/v27XN8fHycO+64o8zjFhUVqa/Ts88+64iIs23btko99wvRfffd5yQkJDhFRUVne1EAnGDz5s1OcHCwk5SU5Bw4cKBUlpqa6iQlJTkhISHOli1bTmme8s6xxf797387QUFBTkJCgpOdnW0u76hRo5xq1ao5KSkpZbLz4XyakJDgDB8+/LTd38qVKx0RcRYuXFhqurW+T7cTz6fnqoSEBKdnz55OWFiY89JLL5XKdu7c6fj6+pa8xyjvvWDbtm2dWrVqldlGExISnGuuuabUtBPfpzzzzDOOiDhLliwps1yZmZlOTk5OucvcokULp3v37if7VC8Y+fn5TmRkpPP3v//9bC/KeYuvMUN14403yu233y4//PCDLFiw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vvz73/8u92s9Z0N8fLy0bdtW3nvvvVJvStauXStff/21XH311SLy+2+hTvyaUGxsrNSuXbvka0blbW+O48ikSZMqXI4BAwaIr6+vPPHEE2U+ITlxW1+xYoWIiFx66aWVfJYAzpSHH35YgoKC5K677pKDBw+Wyg4dOiR33323BAcHy8MPP3xK81i++eYbmTBhgjRs2FBuvPFG87bff/99ub8RrMz5ND8/X1599dVKLZMbJ7YmTJ48WURE+vTpo85zww03yLJly2T+/PllsoyMjJLfUmo6d+4sa9euLfP10Yr4+fmVOVZPnjy5TFXQia9vaGioNG7c+KQfT1uGK6+8Uj7//PNSX/Xev3+/zJw5Uy677LJKfzOgWPPmzUt9Zbu4DaA8t99+u4wdO7bUgL+yunfvLj169JCnn366UvVSP/zwQ8lPjI733//+Vw4ePFjuV7nPhuL3ECc2a7zwwgsiIiWNGOnp6WW2n+I/GBz/HsPHx6fUNpWSklKp66kMHjxYbdYo7z1GixYtSr6qjZPDJ7sQkd//AhoaGir5+fmye/dumT9/vixZskTatGkjH3/8cYXzjx49WrKzs2XgwIGSlJQk+fn5snTpUvnoo4+kQYMGJb91vfLKK8Xf31/69esnd911l2RlZcmbb74psbGxVfJXv8DAQJk3b54MHz5cOnbsKF999ZX87//+r/z1r38t89ub4/3zn/+URYsWSceOHeWOO+6Q5s2by6FDh2TlypWycOFC9Tcyxa699lqZPn26bNy4scK/xN1///2unpvI77/dnTBhQqX6XXft2iUdOnSQK664Qnr27ClxcXFy4MABmTVrlqxatUrGjBlzznxF5tlnn5U+ffpI586d5bbbbpOcnByZPHmyhIeHl/QXHjlyROrWrSvXXXedtGnTRkJDQ2XhwoXy448/lpzYk5KSJDExUR566CHZvXu3hIWFySeffFKpr8Q1btxY/va3v8mECROka9euMmjQIAkICJAff/xRateuLRMnTiy57YIFC6R+/frSrl27KlkfANxr0qSJvPfee3LjjTdKq1at5LbbbpOGDRtKSkqKvP3225KWliazZs0q1YvuZp5iX331laxfv16OHTsm+/fvl2+++UYWLFggCQkJMnfu3Ar7Rp9++mlZsWKFDBo0qOQnMytXrpT3339fatasKWPGjBGR3/+4FhkZKcOH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v5cvXy4LFiwoM90Nx3EkNzdXgoKCTvm+qkJcXJysWbNGWrRoUTLtrrvukpEjR8q0adPk73//uzRu3FhERObOnSvbt2+Xf/3rX3LNNdeU3L5mzZryxBNPyKpVq6Rdu3Yl06tVq1apdbht2zZp0KCBpKWlSUxMzGl8dgCAC8GFfB4HUDX4GjMuKNOmTZMrrrhCYmNjJSAgQJo3by5Tp04tc7sGDRpI3759Zf78+XLxxRdLUFCQvP766yIisn37dunfv7+EhIRIbGysPPDAAzJ//vxyv1r1ww8/yFVXXSXh4eESHBws3bt3lyVLlpTk48aNk4cfflhERBo2bFjyFa2UlBQREUlLS5P169dLdna2+byio6NLDXSLDRw4UEREfvvtt5Jphw8fFhGRWrVqlbptfHy8iEi5bwQKCwtL5tM0aNDAzAEAOFVePY+L/P417vvuu0/mzJkjLVu2lICAAGnRooXMmzev1O22b98uo0aNkmbNmklQUJBERUXJ9ddfX/KYxd59913x8fGRJUuWyIMPPigxMTESEhIiAwcOlNTU1AqXB/ACPtnFBWXq1KnSokUL6d+/v1SrVk2++OILGTVqlBQVFcm9995b6rYbNmyQoUOHyl133SV33HGHNGvWTI4ePSpXXHGF7N27V+6//36Ji4uTmTNnyqJFi8o81jfffCN9+vSR9u3by9ixY8XX17fkJP39999Lhw4dZNCgQbJx40aZNWuWvPjiixIdHS0iUvLJ6JQpU2T8+PGyaNEi6dGjx0k/33379omIlNyviEi3bt3E19dX7r//fnn++eelbt26snr1annqqadkwIABZX6Pm52dLWFhYZKdnS2RkZEydOhQefrppyU0NPSklwcAgFPh9fP4f/7zH/n0009l1KhRUqNGDXn55Zdl8ODBsmPHDomKihIRkR9//FGWLl0qQ4YMkbp160pKSopMnTpVevToIevWrZPg4OBS9zl69GiJjIyUsWPHSkpKirz00kty3333yUcffeTmJQDOLw7gUffee69z4iaenZ1d5nbJyclOo0aNSk1LSEhwRMSZN29eqenPP/+8IyLOnDlzSqbl5OQ4SUlJjog4ixYtchzHcYqKipwmTZo4ycnJTlFRUanHb9iwodO7d++Sac8++6wjIs62bdvKLNvYsWNL3e/JyMvLc5o3b+40bNjQKSgoKJW99dZbTkRE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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(batch_ind[0][0].shape)\n",
    "print(batch_ood[0][0].shape)\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(10, 5))\n",
    "\n",
    "id_img = batch_ind[0][0].squeeze().cpu()\n",
    "ax1.imshow(id_img, cmap=\"gray\")\n",
    "ax1.set_title(f\"ID Sample (MNIST mosaic)\\nTarget: {batch_ind[1][0].item():.0f}\")\n",
    "ax1.axis(\"off\")\n",
    "\n",
    "\n",
    "ood_img = batch_ood[0][0].squeeze().cpu()\n",
    "ax2.imshow(ood_img, cmap=\"gray\")\n",
    "ax2.set_title(f\"OOD Sample (Fashion-MNIST mosaic)\\nTarget: {batch_ood[1][0].item()}\")\n",
    "ax2.axis(\"off\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a76ab28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd6e0060",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c403426",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39a8da01",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d9a778f",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": "python3"
  },
  "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.12.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
