{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Modules"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import sys\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import torch\n",
    "from sklearn import datasets\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.manifold import TSNE\n",
    "from sklearn.metrics import (ConfusionMatrixDisplay, classification_report,\n",
    "                             confusion_matrix)\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from torch.optim import Adam\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "sys.path.append(\"../\")\n",
    "\n",
    "from scarf.loss import NTXent\n",
    "from scarf.model import SCARF\n",
    "\n",
    "from example.dataset import ExampleDataset\n",
    "from example.utils import dataset_embeddings, fix_seed, train_epoch\n",
    "\n",
    "seed = 1234\n",
    "fix_seed(seed)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train set: (455, 30)\n",
      "Test set: (114, 30)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>mean radius</th>\n",
       "      <th>mean texture</th>\n",
       "      <th>mean perimeter</th>\n",
       "      <th>mean area</th>\n",
       "      <th>mean smoothness</th>\n",
       "      <th>mean compactness</th>\n",
       "      <th>mean concavity</th>\n",
       "      <th>mean concave points</th>\n",
       "      <th>mean symmetry</th>\n",
       "      <th>mean fractal dimension</th>\n",
       "      <th>...</th>\n",
       "      <th>worst radius</th>\n",
       "      <th>worst texture</th>\n",
       "      <th>worst perimeter</th>\n",
       "      <th>worst area</th>\n",
       "      <th>worst smoothness</th>\n",
       "      <th>worst compactness</th>\n",
       "      <th>worst concavity</th>\n",
       "      <th>worst concave points</th>\n",
       "      <th>worst symmetry</th>\n",
       "      <th>worst fractal dimension</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-0.880353</td>\n",
       "      <td>-1.008502</td>\n",
       "      <td>-0.851600</td>\n",
       "      <td>-0.803450</td>\n",
       "      <td>0.528820</td>\n",
       "      <td>-0.257291</td>\n",
       "      <td>-0.443192</td>\n",
       "      <td>-0.407671</td>\n",
       "      <td>-0.129007</td>\n",
       "      <td>0.896290</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.912743</td>\n",
       "      <td>-0.956058</td>\n",
       "      <td>-0.829103</td>\n",
       "      <td>-0.782999</td>\n",
       "      <td>0.427404</td>\n",
       "      <td>-0.216693</td>\n",
       "      <td>-0.214409</td>\n",
       "      <td>-0.123639</td>\n",
       "      <td>0.672669</td>\n",
       "      <td>0.366357</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.248449</td>\n",
       "      <td>1.482635</td>\n",
       "      <td>0.225824</td>\n",
       "      <td>0.152201</td>\n",
       "      <td>0.462742</td>\n",
       "      <td>-0.130230</td>\n",
       "      <td>0.414654</td>\n",
       "      <td>0.411382</td>\n",
       "      <td>-0.597113</td>\n",
       "      <td>0.266727</td>\n",
       "      <td>...</td>\n",
       "      <td>0.448496</td>\n",
       "      <td>1.198785</td>\n",
       "      <td>0.395258</td>\n",
       "      <td>0.279837</td>\n",
       "      <td>1.500623</td>\n",
       "      <td>-0.122839</td>\n",
       "      <td>0.611302</td>\n",
       "      <td>0.570670</td>\n",
       "      <td>-0.405498</td>\n",
       "      <td>0.563031</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-1.345070</td>\n",
       "      <td>0.549036</td>\n",
       "      <td>-1.334836</td>\n",
       "      <td>-1.089839</td>\n",
       "      <td>0.609582</td>\n",
       "      <td>-0.812806</td>\n",
       "      <td>-0.856507</td>\n",
       "      <td>-0.939086</td>\n",
       "      <td>0.774546</td>\n",
       "      <td>0.461423</td>\n",
       "      <td>...</td>\n",
       "      <td>-1.133763</td>\n",
       "      <td>0.878470</td>\n",
       "      <td>-1.154989</td>\n",
       "      <td>-0.923432</td>\n",
       "      <td>0.906361</td>\n",
       "      <td>-0.870453</td>\n",
       "      <td>-1.018594</td>\n",
       "      <td>-1.198201</td>\n",
       "      <td>-0.042221</td>\n",
       "      <td>-0.059954</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-0.139050</td>\n",
       "      <td>-0.389184</td>\n",
       "      <td>-0.190352</td>\n",
       "      <td>-0.253539</td>\n",
       "      <td>0.249823</td>\n",
       "      <td>-0.472841</td>\n",
       "      <td>-0.547939</td>\n",
       "      <td>-0.453825</td>\n",
       "      <td>-0.288671</td>\n",
       "      <td>-0.267620</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.284796</td>\n",
       "      <td>-0.368815</td>\n",
       "      <td>-0.355786</td>\n",
       "      <td>-0.353509</td>\n",
       "      <td>-0.543816</td>\n",
       "      <td>-0.772100</td>\n",
       "      <td>-0.480259</td>\n",
       "      <td>-0.381195</td>\n",
       "      <td>-0.632129</td>\n",
       "      <td>-0.798305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.054334</td>\n",
       "      <td>0.158496</td>\n",
       "      <td>0.884228</td>\n",
       "      <td>0.892295</td>\n",
       "      <td>-0.886724</td>\n",
       "      <td>-0.706354</td>\n",
       "      <td>-0.209267</td>\n",
       "      <td>0.167349</td>\n",
       "      <td>1.151934</td>\n",
       "      <td>-1.778288</td>\n",
       "      <td>...</td>\n",
       "      <td>0.876078</td>\n",
       "      <td>0.326818</td>\n",
       "      <td>0.631622</td>\n",
       "      <td>0.647473</td>\n",
       "      <td>-1.107034</td>\n",
       "      <td>-0.864668</td>\n",
       "      <td>-0.238274</td>\n",
       "      <td>0.045704</td>\n",
       "      <td>3.307260</td>\n",
       "      <td>-1.264719</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 30 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "   mean radius  mean texture  mean perimeter  mean area  mean smoothness  \\\n",
       "0    -0.880353     -1.008502       -0.851600  -0.803450         0.528820   \n",
       "1     0.248449      1.482635        0.225824   0.152201         0.462742   \n",
       "2    -1.345070      0.549036       -1.334836  -1.089839         0.609582   \n",
       "3    -0.139050     -0.389184       -0.190352  -0.253539         0.249823   \n",
       "4     1.054334      0.158496        0.884228   0.892295        -0.886724   \n",
       "\n",
       "   mean compactness  mean concavity  mean concave points  mean symmetry  \\\n",
       "0         -0.257291       -0.443192            -0.407671      -0.129007   \n",
       "1         -0.130230        0.414654             0.411382      -0.597113   \n",
       "2         -0.812806       -0.856507            -0.939086       0.774546   \n",
       "3         -0.472841       -0.547939            -0.453825      -0.288671   \n",
       "4         -0.706354       -0.209267             0.167349       1.151934   \n",
       "\n",
       "   mean fractal dimension  ...  worst radius  worst texture  worst perimeter  \\\n",
       "0                0.896290  ...     -0.912743      -0.956058        -0.829103   \n",
       "1                0.266727  ...      0.448496       1.198785         0.395258   \n",
       "2                0.461423  ...     -1.133763       0.878470        -1.154989   \n",
       "3               -0.267620  ...     -0.284796      -0.368815        -0.355786   \n",
       "4               -1.778288  ...      0.876078       0.326818         0.631622   \n",
       "\n",
       "   worst area  worst smoothness  worst compactness  worst concavity  \\\n",
       "0   -0.782999          0.427404          -0.216693        -0.214409   \n",
       "1    0.279837          1.500623          -0.122839         0.611302   \n",
       "2   -0.923432          0.906361          -0.870453        -1.018594   \n",
       "3   -0.353509         -0.543816          -0.772100        -0.480259   \n",
       "4    0.647473         -1.107034          -0.864668        -0.238274   \n",
       "\n",
       "   worst concave points  worst symmetry  worst fractal dimension  \n",
       "0             -0.123639        0.672669                 0.366357  \n",
       "1              0.570670       -0.405498                 0.563031  \n",
       "2             -1.198201       -0.042221                -0.059954  \n",
       "3             -0.381195       -0.632129                -0.798305  \n",
       "4              0.045704        3.307260                -1.264719  \n",
       "\n",
       "[5 rows x 30 columns]"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = datasets.load_breast_cancer(as_frame=True)\n",
    "data, target = data[\"data\"], data[\"target\"]\n",
    "train_data, test_data, train_target, test_target = train_test_split(\n",
    "    data, \n",
    "    target, \n",
    "    test_size=0.2, \n",
    "    stratify=target, \n",
    "    random_state=seed\n",
    ")\n",
    "\n",
    "# preprocess\n",
    "constant_cols = [c for c in train_data.columns if train_data[c].nunique() == 1]\n",
    "train_data.drop(columns=constant_cols, inplace=True)\n",
    "test_data.drop(columns=constant_cols, inplace=True)\n",
    "\n",
    "scaler = StandardScaler()\n",
    "train_data = pd.DataFrame(scaler.fit_transform(train_data), columns=train_data.columns)\n",
    "test_data = pd.DataFrame(scaler.transform(test_data), columns=test_data.columns)\n",
    "\n",
    "# to torch dataset\n",
    "train_ds = ExampleDataset(\n",
    "    train_data.to_numpy(), \n",
    "    train_target.to_numpy(), \n",
    "    columns=train_data.columns\n",
    ")\n",
    "test_ds = ExampleDataset(\n",
    "    test_data.to_numpy(), \n",
    "    test_data.to_numpy(), \n",
    "    columns=test_data.columns\n",
    ")\n",
    "\n",
    "print(f\"Train set: {train_ds.shape}\")\n",
    "print(f\"Test set: {test_ds.shape}\")\n",
    "train_ds.to_dataframe().head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                    \r"
     ]
    }
   ],
   "source": [
    "batch_size = 128\n",
    "epochs = 10_000\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "train_loader = DataLoader(train_ds, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "model = SCARF(\n",
    "    input_dim=train_ds.shape[1], \n",
    "    emb_dim=16,\n",
    "    corruption_rate=0.6,\n",
    ").to(device)\n",
    "optimizer = Adam(model.parameters(), lr=0.001)\n",
    "ntxent_loss = NTXent()\n",
    "\n",
    "loss_history = []\n",
    "\n",
    "for epoch in range(1, epochs + 1):\n",
    "    epoch_loss = train_epoch(model, ntxent_loss, train_loader, optimizer, device, epoch)\n",
    "    loss_history.append(epoch_loss)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'loss')"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1152x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(16, 8))\n",
    "ax.plot(loss_history)\n",
    "ax.set_xlabel(\"epoch\")\n",
    "ax.set_ylabel(\"loss\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluate embeddings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4/4 [00:00<00:00, 291.82it/s]\n",
      "100%|██████████| 1/1 [00:00<00:00, 211.23it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(455, 16)\n",
      "(114, 16)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "train_loader = DataLoader(train_ds, batch_size=batch_size, shuffle=False)\n",
    "test_loader = DataLoader(test_ds, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "# get embeddings for training and test set\n",
    "train_embeddings = dataset_embeddings(model, train_loader, device)\n",
    "test_embeddings = dataset_embeddings(model, test_loader, device)\n",
    "\n",
    "print(train_embeddings.shape)\n",
    "print(test_embeddings.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.98      0.98      0.98        42\n",
      "           1       0.99      0.99      0.99        72\n",
      "\n",
      "    accuracy                           0.98       114\n",
      "   macro avg       0.98      0.98      0.98       114\n",
      "weighted avg       0.98      0.98      0.98       114\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<sklearn.metrics._plot.confusion_matrix.ConfusionMatrixDisplay at 0x17d1c4c40>"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 576x576 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "clf = LogisticRegression()\n",
    "\n",
    "# vanilla dataset: train the classifier on the original data\n",
    "clf.fit(train_data, train_target)\n",
    "vanilla_predictions = clf.predict(test_data)\n",
    "\n",
    "print(classification_report(test_target, vanilla_predictions))\n",
    "cm = confusion_matrix(test_target, vanilla_predictions)\n",
    "disp = ConfusionMatrixDisplay(confusion_matrix=cm)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 8))\n",
    "disp.plot(ax=ax)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "           0       0.97      0.93      0.95        42\n",
      "           1       0.96      0.99      0.97        72\n",
      "\n",
      "    accuracy                           0.96       114\n",
      "   macro avg       0.97      0.96      0.96       114\n",
      "weighted avg       0.97      0.96      0.96       114\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<sklearn.metrics._plot.confusion_matrix.ConfusionMatrixDisplay at 0x17d56f8b0>"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 576x576 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# embeddings dataset: train the classifier on the embeddings\n",
    "clf.fit(train_embeddings, train_target)\n",
    "vanilla_predictions = clf.predict(test_embeddings)\n",
    "\n",
    "print(classification_report(test_target, vanilla_predictions))\n",
    "cm = confusion_matrix(test_target, vanilla_predictions)\n",
    "disp = ConfusionMatrixDisplay(confusion_matrix=cm)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 8))\n",
    "disp.plot(ax=ax)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Visualzie using t-sne "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/Caskroom/mambaforge/base/envs/scarf/lib/python3.10/site-packages/sklearn/manifold/_t_sne.py:991: FutureWarning: The PCA initialization in TSNE will change to have the standard deviation of PC1 equal to 1e-4 in 1.2. This will ensure better convergence.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x17d6c0e50>"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAegAAAHSCAYAAAAnsVjHAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAABZ8ElEQVR4nO3dfZRU1Zkv/u/uooBqjTQimYQGApnrQBQQYst4p81NhCjOGA1BhbzNz9wk47jyYnQZtM0kBl3zGzuakUwykziOMZoZVHqEtGSYXHRoZ2XJxJjugChRbjQi0miCQjPRLqC6e98/qk71qVN7n5c676e+n7VcSHW9nDrV1HP23s9+HiGlBBERESVLS9wHQERERPUYoImIiBKIAZqIiCiBGKCJiIgSiAGaiIgogRigiYiIEmhC3Adgdtppp8k5c+bEfRhERESRGRgYeF1KOd16e6IC9Jw5c9Df3x/3YRAREUVGCPGy6nZOcRMRESUQAzQREVECMUATERElUKLWoImIKNlKpRIOHDiAY8eOxX0oqTN58mTMnDkT+Xze1f0ZoImIyLUDBw7gbW97G+bMmQMhRNyHkxpSSrzxxhs4cOAA5s6d6+oxnOImIiLXjh07hmnTpjE4eySEwLRp0zzNPDBAExGRJwzOjfF63higiYio6dx111344Q9/CAC47777cPDgwerPPvvZz+JXv/pVXIdWxTVoIiJqOldffXX1/++77z4sWLAAM2bMAADcc889cR1WDY6giYgoNL07B9HZ3Ye5XVvR2d2H3p2Dvp9z3759mD9/Pq688kosWrQIl19+OYaHh7F9+3YsWbIECxcuxKc//WkcP34cANDV1YUzzjgDixYtwpe//GUAwLp16/DNb34TDz/8MPr7+/GJT3wCixcvRrFYxAc+8AH09/fje9/7Hm644Ybq695333344he/CAD4l3/5FyxduhSLFy/GX/7lX2J0dNT3+7JigCYiolD07hzETZufweBQERLA4FARN21+JpAgvXfvXlx11VXYvXs3TjnlFNx555341Kc+hY0bN+KZZ57ByMgIvve97+Hw4cP40Y9+hD179mD37t346le/WvM8l19+OTo6OrBhwwbs2rULhUKh5mebN2+u/n3jxo1Ys2YNnnvuOWzcuBE7duzArl27kMvlsGHDBt/vyYoBmoiIQnHHtr0olmpHlsXSKO7Y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",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tsne = TSNE(n_components=2, learning_rate=\"auto\", init=\"pca\", perplexity=15)\n",
    "reduced = tsne.fit_transform(train_embeddings)\n",
    "positive = train_target == 1\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 8))\n",
    "\n",
    "ax.scatter(reduced[positive, 0], reduced[positive, 1], label=\"positive\")\n",
    "ax.scatter(reduced[~positive, 0], reduced[~positive, 1], label=\"negative\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10.5 ('scarf')",
   "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.8.0"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "c6f9f5a3811a03e662921c74ed1d00f88796bf20e69187cb766d7acffcc397b8"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
