{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "8c3af688-e933-4e6a-8a2b-27dc2828d305",
   "metadata": {},
   "source": [
    "## Same to t1.ipynb, but for CIFAR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "78ad58c4-956b-47ca-8518-507056efdfa1",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torchvision\n",
    "from torchvision.datasets import CIFAR10\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "03b6b2fa-277e-4bfc-9ccd-b85be97f24af",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "data_dir = \"<root_dir>\" # Change as wish\n",
    "c10_train = CIFAR10(root=data_dir, download=True, train=True, transform=None)\n",
    "c10_test = CIFAR10(root=data_dir, download=True, train=False, transform=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "4280bddd-6c9c-4f48-8ecd-300dc514525c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def pad_image(image,pad_size,left=True):\n",
    "    pad_one_end = np.random.randint(int(pad_size//4))\n",
    "    pad_other_end = int(pad_size - pad_one_end)\n",
    "    if left:\n",
    "        new_image = F.pad(image, (pad_other_end, pad_one_end, pad_other_end, pad_one_end),\"constant\", 0)\n",
    "    else: \n",
    "        new_image = F.pad(image, (pad_one_end, pad_other_end, pad_one_end, pad_other_end),\"constant\", 0)\n",
    "    return new_image\n",
    "\n",
    "def create_m1_samples(data, targets, class_size=5000, pad_size=32):\n",
    "    all_data = []\n",
    "    all_targets = []\n",
    "    for cla_idx in range(10):\n",
    "        cla_length = np.sum(targets==cla_idx).item()\n",
    "        # Some randomness\n",
    "        chosen_ones = np.random.permutation(cla_length)[:class_size]\n",
    "        cur_cla_data = data[targets==cla_idx][chosen_ones]\n",
    "        for i in range(class_size):\n",
    "            first_left = torch.rand(1) < 0.5\n",
    "            im = cur_cla_data[i]\n",
    "            cur_data = pad_image(torch.from_numpy(im).float().permute(2,0,1), pad_size, first_left)\n",
    "            all_data.append(cur_data)\n",
    "            \n",
    "            cur_target = torch.zeros(10)\n",
    "            cur_target[cla_idx] = 1.0\n",
    "            all_targets.append(cur_target)\n",
    "    return torch.stack(all_data, dim=0), torch.stack(all_targets, dim=0)\n",
    "\n",
    "def create_m2_samples(data, targets, class_size=5000, pad_size=28):\n",
    "    all_data = []\n",
    "    all_targets = []\n",
    "    for idx_1 in range(10):\n",
    "        for idx_2 in range(idx_1+1, 10):\n",
    "            cla_length_1 = np.sum(targets==idx_1).item()\n",
    "            cla_length_2 = np.sum(targets==idx_2).item()\n",
    "            # Some randomness\n",
    "            chosen_ones_1 = np.random.permutation(cla_length_1)[:class_size]\n",
    "            chosen_ones_2 = np.random.permutation(cla_length_2)[:class_size]\n",
    "            cla_data_1 = data[targets==idx_1][chosen_ones_1]\n",
    "            cla_data_2 = data[targets==idx_2][chosen_ones_2]\n",
    "        \n",
    "            for i in range(class_size):\n",
    "                first_left = torch.rand(1) < 0.5\n",
    "                cur_data_1 = pad_image(torch.from_numpy(cla_data_1[i]).float().permute(2,0,1), pad_size, left=first_left)\n",
    "                cur_data_2 = pad_image(torch.from_numpy(cla_data_2[i]).float().permute(2,0,1), pad_size, left=not first_left)\n",
    "                all_data.append(torch.maximum(cur_data_1, cur_data_2))\n",
    "\n",
    "                cur_target = torch.zeros(10)\n",
    "                cur_target[idx_1] = 0.5\n",
    "                cur_target[idx_2] = 0.5\n",
    "                all_targets.append(cur_target)\n",
    "    return torch.stack(all_data, dim=0), torch.stack(all_targets, dim=0)\n",
    "\n",
    "def create_dataset(num_samples, data, targets, pad_size=32):\n",
    "    m1_num, m2_num = num_samples\n",
    "    m1_data, m1_targets = create_m1_samples(data, targets, class_size=m1_num, pad_size=pad_size)\n",
    "    m2_data, m2_targets = create_m2_samples(data, targets, class_size=m2_num, pad_size=pad_size)\n",
    "    \n",
    "    return torch.cat([m1_data, m2_data], dim=0), torch.cat([m1_targets, m2_targets], dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "76ddbd6b-5707-4343-8c75-76a4e89e818a",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "trainset, trainlabels = create_dataset([3100, 200], c10_train.data / np.max(c10_train.data), \n",
    "                                       np.array(c10_train.targets), pad_size=32)\n",
    "testset, testlabels = create_dataset([800, 50], c10_test.data / np.max(c10_train.data), \n",
    "                                       np.array(c10_test.targets), pad_size=32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "12df7f56-70d0-4244-bbe8-5e4fad26f104",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "to_save = {\n",
    "            \"train_data\": trainset,\n",
    "            \"train_label\": trainlabels,\n",
    "            \"test_data\": testset,\n",
    "            \"test_label\": testlabels\n",
    "            }\n",
    "    \n",
    "with open(\"<root_dir>/c10_combine.pkl\", 'wb') as f: \n",
    "    pickle.dump(to_save, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "4b502e60-eb2d-48f5-99f4-542d8c7ee9e4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['airplane',\n",
       " 'automobile',\n",
       " 'bird',\n",
       " 'cat',\n",
       " 'deer',\n",
       " 'dog',\n",
       " 'frog',\n",
       " 'horse',\n",
       " 'ship',\n",
       " 'truck']"
      ]
     },
     "execution_count": 109,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "c10_train.classes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "id": "4bc6bf43-e0dd-4f33-b279-019f5cb049cf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.5000, 0.5000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000])\n"
     ]
    },
    {
     "data": {
      "image/png": "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8LzzzpNRo0bV3/7888/lyiuvTPly2sKzzz4rtbW19bfPPvvspLc1p0yZIv3796+/3fDt37b2+eefyxlnnJHUaqpfv34yfvx4GTRokOot2O3bt8vJJ58s27Ztq/9d7969Zfz48TJw4MBG54NVq1bJscceK1u3bk3dA5H2OQ825cYbb5T77ruv/nZOTo6MHDlSxo8fL0VFRY3ib7311mb7uDa0Y8cOmTp1apM9KHv37i3jxo2Tww47rNHHXEpKSmTatGl8Eagz6+iKE8neeuutRq+cVq1a1S7L3neZtle2H3/8cX3cr3/9a7NkyZImr+DU1taaF198sdFVy549e5rKysr9LmPEiBFJ9znmmGPM/Pnzm5wEUVNTYz744ANzyy23mIEDBzZ7hW/z5s0mGAwm5b3sssvMsmXLmozfs2ePeeWVV8zll19u8vLyOsUVvkcffTRpGYFAwNTU1KR8OU0ZOXKk6du3r7nuuuvM3LlzTXl5eaOYRCJhFi9ebK644grj9/uT1nX27NnWZTS8wrf3amZeXp65//77G328oaSkxCxcuDBlj3Gvd955p9Fz8bbbbkv5clJtypQpSev83nvvNYq5+eabk2LuvvvuFi2jJcd4wyt8e/dnenq6ueWWW8zmzZuT4ktLS80777yT9LuGz6t+/frV//u8884zy5cvT4rfsmWLuf766xsdfyeffHJKH1t7nAcbXuEbMGBA/b8nTZpk5syZk7TMRCJh5s2bZ4YNG5Z0v169elmvssfjcXPMMcck3a+oqMjcd999Ztu2bY1i33//fXPssccmxffu3dvs2rVrv8tBx6Dg62QefPDBpCdPdnZ2i3rutUZLTnTbt283S5YsUeeOx+Pm4osvTlrGH/7wh2bjly5d2qjYi8fj6mWtXLmyyf976KGHkvLeeuut6sdQWVlp/QxfexR8P/nJT5KWMXLkyJQvoznvvvtui0avzZkzJ+kt+YkTJ1rv07Dgk3+/XdTwj3pb2rRpkznssMOafOvqgQceaLf1aKnVq1c3Kg6aOn8sW7YsKW7o0KEtWk5rCr6957WmCtHmNHxe7f35+c9/vt/7Pf/8842KvmeffTZlj62tz4PGNC749v7813/9136fizt27DA9e/ZMus++n+VsSsPPj0+aNMls377d+pgafkTmv//7v/d7H3QMCr5O5s4772x0wm4vbV2ohMNhM2jQoPplTJgwodnYF154IWl9nn766ZSsw9VXX52Ut6SkJCV592qPgu9HP/pRo2K4M7vllluS1nfp0qX7jW+q4GvPL02sW7cu6QpSUz+2P9IdpeG2/p//+Z9mYw8//PCkWM0XnfZqbcH38MMPq5dlTNMF32mnnaa674033ph0vyOOOGK/8Z3pPGhM0wXf+PHjVV/S+uMf/5h0v8suu6zZ2OrqalNYWFgf26NHD7N7927VY4rFYmby5MlJBX1paanqvmg/fIavk9m3r5qISH5+fsesSBsIhUJy9tln19/+/PPPkz5rtK+Gv09Va4W2yrvX7bff3uZjpw62Y6Rh77cPPvigRff/1re+JSeddFIqV6lZpaWlctJJJyXNmZ0+fbrMmDEjKe6qq65S97D78MMPxfO8+p8f//jHqVzleqaJcWkNt/3+/q+9evL17dtXLrnkklbn+eUvf6mK+5//+R/Jzc2tv/3hhx/K8uXLW738A9WS82Bz7rzzTtW565xzzkm63fDz4ft68sknk84tt99+uxQWFqrWx+/3y0033VR/u6qqSt544w3VfdF+KPg6mcrKyqTbWVlZHbQmbWPAgAH1/47FYrJkyZIm43r27Jl0+6mnnkrJ8hvmnTVrVkrytqeD7RjZd5+LfPMHriUaFltt6dJLL5VVq1bV3z7xxBPl73//uzz55JNy+umn1//eGCMXXXSRPPPMM9acu3fvTro9YsSI1K3wPubNmycbN26svz1u3DgZNmxYs/EzZsxI+sLLM8880+gLUm3h3HPPbXUvunHjxqm3Y3Z2tnzve99L+t0777zTquW3lvY82JS8vDz1C6DCwsKkpuGbNm1qNvbVV1+t/3cgEJDzzjtPvU4iIscdd1zSfn3vvfdadH+0PQq+TiYnJyfpdnV1dQetiV5NTY08/fTTctlll8nkyZOlZ8+ekpOTIz6fL+nKhud5ctlllyXdd9euXU3mnDRpUtKr8tmzZ8s555wjX331VavW9YQTTki6fd1118ktt9wiJSUlrcrbnjrLMbJo0SK5+eab5dRTT5WBAwdKYWGhBIPBRvs8LS0t6X7N7fPmTJw4MZWr3aw33nhD/vGPf9Tf7tatm/ztb3+TUCgkgUBAnn32WTnuuOPq/z+RSMjMmTMbNcBuqOE3Q9uq4Gt4he773//+fuOLi4vl2GOPrb9dVlYmL774YhusWbJU7M9p06a1Kn7RokWtXoeG2uI82JTDDz+8RQVzt27d6v+97zej92WMkQULFtTfHjJkSNL5VyMrK0u6dOlSf7sjr6KiaRR8nUzDS+jNPUE7g2g0Kr/85S+luLhYZsyYIX/+859l4cKFsm3bNqmqqmrUrqApZWVlTf4+PT1dbrjhhqTfPffcc3LooYfKiBEj5JprrpEXXnihxYXakUcemVT0xWIxueuuu6RXr15y1FFHye233y5z585tdBWtM+noY+S9996TMWPGyKRJk+See+6R1157TdatWyelpaUSi8Ws929unzen4RXCtnL33Xcn3X7ggQeS/oClpaXJSy+9JEceeWT972KxmJxzzjn7ffvqww8/rP93dna2TJ48OYVr/Y2qqqqktht+v191ZbTh27oN5++2hVTsz31b5hxI/Lp161q9Dnu15XmwKfsWcBr7vgPQ3FvH27dvT3o7d9myZY2KVM3Pzp0763M0/OgJOh4FXyfT8I/5vk+gzqS2tlZOPvlkufHGG1tVHO3vLaSbbrqpyd5ty5cvl9/+9rcyffp06dGjhwwbNkyuvvpqWbhwoWqZf/vb3xr90U0kEvL+++/LHXfcIccff7wUFhbKEUccIXfddZesX7++RY+prTU8Rvad+9rW/vSnP8nUqVPlyy+/POAcLX3bsKVXGg7Eli1bkt6CKioqavT5J5Fv/ni++uqrMnbs2PrfRSIROfPMM5vtqbZv3pNOOqnRFc9UeO6555Ku9B533HFSXFxsvd/06dMlMzOz/vacOXOSetu1hVTsz30L8QOJb+mLjua0x3mwofT09ANeTnMafuwgFTrzxYr/VMzS7WQafuamsrJSvv76axk8eHAHrVHTrrzySnn77beTfldUVCTTpk2TMWPGSJ8+fSQ3N1cyMjKSPic0Z86cpIah++N5nvzpT3+S6dOny89//vNmG3quXLlSVq5cKb/73e9kypQp8pvf/EbGjx/fbN6uXbvKu+++K48++qg88MAD8vXXXzeKicVi8tFHH8lHH30kt956q5x//vnyq1/9Srp3765a97bU8BhZsWKF1NXVtckfgn3NmzdPrrjiiqQrFoFAQL71rW/JpEmTpF+/ftKtWzdJT09vVNQ0fCu9JdpjFuoHH3yQ9LhOOeWUZpebl5cnb7zxhkydOrX+bava2lo5/fTTZc6cOUkzrz/44ANZ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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "idx = 31003 # 31003\n",
    "fig = plt.figure(figsize=(8,8))\n",
    "plt.imshow(trainset[idx].permute(1,2,0))\n",
    "plt.axis(\"off\")\n",
    "plt.title(\"Class: Car & Airplane\", fontsize=30)\n",
    "fig.savefig(\"figs/c10_car_airplane.pdf\", bbox_inches='tight')\n",
    "\n",
    "print(trainlabels[idx])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5c7a088-3e05-4658-8e81-bcacca3b9d8b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
