{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 16926,
     "status": "ok",
     "timestamp": 1694033684034,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "UHgERHwINWD7",
    "outputId": "6b696a0a-f31c-4a99-8233-961a74849867"
   },
   "outputs": [],
   "source": [
    "from google.colab import drive\n",
    "drive.mount('/content/gdrive')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 5801,
     "status": "ok",
     "timestamp": 1694033689832,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "ZcDnLKaQkdal",
    "outputId": "46f95660-f1f6-4716-ea81-afc83038829e"
   },
   "outputs": [],
   "source": [
    "pip install PIMS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 4919,
     "status": "ok",
     "timestamp": 1694033702200,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "IZT0LCFnkfGb",
    "outputId": "12ec87de-e4ff-4592-96f5-d987898c0b31"
   },
   "outputs": [],
   "source": [
    "pip install fastcluster"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 5810,
     "status": "ok",
     "timestamp": 1694033708007,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "i5BqMQY2Nd1e"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "from torchvision import datasets\n",
    "import torchvision.transforms as transforms\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torchvision\n",
    "import torch\n",
    "from torchvision import transforms\n",
    "from torchvision.io import read_image\n",
    "\n",
    "plt.rcParams['axes.facecolor'] = 'white'\n",
    "plt.rcParams['figure.figsize'] = 9, 6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 20542,
     "status": "ok",
     "timestamp": 1694033897935,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "UYDqJHiAkjKN"
   },
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "# importing relevant libraries\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy as sp\n",
    "import matplotlib.pyplot as plt\n",
    "import sklearn\n",
    "from sklearn.ensemble import RandomForestClassifier, ExtraTreesClassifier\n",
    "from sklearn.preprocessing import OneHotEncoder, StandardScaler\n",
    "from sklearn.model_selection import cross_val_predict, StratifiedKFold\n",
    "from sklearn.metrics import roc_auc_score, average_precision_score, precision_recall_curve, auc#plot_precision_recall_curve\n",
    "from sklearn.datasets import make_classification\n",
    "from sklearn.preprocessing import MinMaxScaler\n",
    "from tqdm import tqdm\n",
    "from umap import UMAP\n",
    "from pynndescent import NNDescent\n",
    "from fastcluster import single\n",
    "from scipy.cluster.hierarchy import cut_tree, fcluster, dendrogram\n",
    "from scipy.spatial.distance import squareform\n",
    "from sklearn.tree import DecisionTreeClassifier, ExtraTreeClassifier\n",
    "from pims import ImageSequence\n",
    "from PIL import Image\n",
    "from scipy.spatial.distance import hamming\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "# turning off automatic plot showing, and setting style\n",
    "plt.style.use('bmh')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 22,
     "status": "ok",
     "timestamp": 1693197062306,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "aILiFBc-6XZb",
    "outputId": "208108a2-136c-47cf-d4c6-56e2a7cc6f5c"
   },
   "outputs": [],
   "source": [
    "if torch.cuda.is_available():\n",
    "    device = torch.device('cuda')\n",
    "else:\n",
    "    device = torch.device('cpu')\n",
    "\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "oEIBbUweNd3P"
   },
   "outputs": [],
   "source": [
    "# define the NN architecture\n",
    "class ConvAutoencoder(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(ConvAutoencoder, self).__init__()\n",
    "        self.encoder = nn.Sequential(\n",
    "            nn.Conv2d(3, 16, kernel_size=3, stride=2, padding=1),\n",
    "            nn.ReLU(),\n",
    "            nn.Conv2d(16, 32, kernel_size=3, stride=2, padding=1),\n",
    "            nn.ReLU(),\n",
    "            nn.Conv2d(32, 64, kernel_size=3, stride=2, padding=1),\n",
    "            nn.ReLU(),\n",
    "            # nn.Conv2d(64, 128, kernel_size=3, stride=2, padding=1),\n",
    "            # nn.ReLU(),\n",
    "        )\n",
    "        self.decoder = nn.Sequential(\n",
    "            # nn.ConvTranspose2d(128, 64, kernel_size=3, stride=2, padding=1, output_padding=1),\n",
    "            # nn.ReLU(),\n",
    "            nn.ConvTranspose2d(64, 32, kernel_size=3, stride=2, padding=1, output_padding=1),\n",
    "            nn.ReLU(),\n",
    "            nn.ConvTranspose2d(32, 16, kernel_size=3, stride=2, padding=1, output_padding=1),\n",
    "            nn.ReLU(),\n",
    "            nn.ConvTranspose2d(16, 3, kernel_size=4, stride=2, padding=1),\n",
    "            nn.Sigmoid(),  # Ensures outputs are in the range [0, 1]\n",
    "        )\n",
    "\n",
    "\n",
    "    def forward(self, x):\n",
    "        encoded = self.encoder(x)\n",
    "        decoded = self.decoder(encoded)\n",
    "        return decoded\n",
    "\n",
    "        return x\n",
    "\n",
    "    def forward_encoder(self, x):\n",
    "\n",
    "        encoded = self.encoder(x)\n",
    "\n",
    "        return encoded\n",
    "\n",
    "# Training function\n",
    "def train(model, train_loader, criterion, optimizer, num_epochs=10, online = False):\n",
    "    model.train()\n",
    "    for epoch in range(num_epochs):\n",
    "        running_loss = 0.0\n",
    "        if not online:\n",
    "            for images, _ in train_loader:\n",
    "                transformer = torchvision.transforms.Resize((32,32))\n",
    "                images = transformer(images)\n",
    "                #images.requires_grad = True\n",
    "               # gradient = images.grad.data.sign()\n",
    "                noisy_images = images #+ torch.randn(images.size()) * 0.1  # Adding Gaussian noise\n",
    "                #noisy_images = images + 0.1*gradient\n",
    "\n",
    "                optimizer.zero_grad()\n",
    "                outputs = model(noisy_images)\n",
    "                loss = criterion(outputs, images)\n",
    "                loss.backward()\n",
    "                optimizer.step()\n",
    "                running_loss += loss.item()\n",
    "        else:\n",
    "            for images in train_loader:\n",
    "                transformer = torchvision.transforms.Resize((32,32))\n",
    "                images = transformer(images)\n",
    "                #images.requires_grad = True\n",
    "                #gradient = images.grad.data.sign()\n",
    "                noisy_images = images #+ torch.randn(images.size()) * 0.1  # Adding Gaussian noise\n",
    "                #noisy_images = images + 0.1*gradient\n",
    "\n",
    "                optimizer.zero_grad()\n",
    "                outputs = model(noisy_images)\n",
    "                loss = criterion(outputs, images)\n",
    "                loss.backward()\n",
    "                optimizer.step()\n",
    "                running_loss += loss.item()\n",
    "        print(f\"Epoch [{epoch + 1}/{num_epochs}], Loss: {running_loss / len(train_loader)}\")\n",
    "\n",
    "# Data preprocessing\n",
    "transform = torchvision.transforms.Compose([\n",
    "    torchvision.transforms.ToTensor(),\n",
    "])\n",
    "\n",
    "# Initialize the model, criterion, and optimizer\n",
    "model = ConvAutoencoder()\n",
    "criterion = nn.MSELoss()\n",
    "optimizer = torch.optim.Adam(model.parameters(), lr=0.001)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "o1qJVzGViPtF"
   },
   "outputs": [],
   "source": [
    "# model_Conv_AE_OOD_Cifar10_Color_train = 'classifier.pt'\n",
    "# path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train}\"\n",
    "# model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 50080,
     "status": "ok",
     "timestamp": 1693197112378,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "6NftBdp9Nd5U",
    "outputId": "6e6795ac-866b-4031-9834-23784f6a5eb4"
   },
   "outputs": [],
   "source": [
    "# Load CIFAR-10 data\n",
    "train_dataset = torchvision.datasets.CIFAR10(root='./data', train=True, download=True, transform=transform)\n",
    "train_loader = torch.utils.data.DataLoader(train_dataset, batch_size=64, shuffle=True, num_workers=4)\n",
    "\n",
    "# Training the model\n",
    "train(model, train_loader, criterion, optimizer, num_epochs=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 22727,
     "status": "ok",
     "timestamp": 1693197135100,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "-Lw_PhMiNd7J",
    "outputId": "6e34abec-1a47-477e-f1c3-59b37309d25e"
   },
   "outputs": [],
   "source": [
    "train_dataset_Cifar10 = torchvision.datasets.CIFAR10(root='./data', train=True, download=True, transform=transform)\n",
    "train_loader_Cifar10 = torch.utils.data.DataLoader(train_dataset_Cifar10, batch_size = 50000, shuffle=True)\n",
    "\n",
    "for batch in train_loader_Cifar10:\n",
    "    img, labels = batch\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "    #img = img.reshape(-1, 28*28)\n",
    "\n",
    "    # Generating output\n",
    "    out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "    latent_train = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "X_train = img.detach().numpy()\n",
    "latent_train = latent_train.detach().numpy()\n",
    "y = labels.detach().numpy()\n",
    "print(y)\n",
    "# np.random.shuffle(y)\n",
    "# print(y)\n",
    "print(X_train.shape)\n",
    "print(latent_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 26,
     "status": "ok",
     "timestamp": 1693197135101,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "pjGzdfeLOA-b",
    "outputId": "73ccc953-0b5f-4405-9358-c6e8063be3b1"
   },
   "outputs": [],
   "source": [
    "X_train = X_train.reshape(-1,3*32*32)\n",
    "latent_train = latent_train.reshape(-1,64*4*4)\n",
    "print(X_train.shape)\n",
    "print(latent_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 6222,
     "status": "ok",
     "timestamp": 1693197141302,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "GKqaLHKjOEJS",
    "outputId": "b94a40dd-4188-4312-8151-e0271632ae0c"
   },
   "outputs": [],
   "source": [
    "print(np.mean(np.cov(X_train.T)))\n",
    "print(np.mean(np.cov(latent_train.T)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "9wDPfIurF8Pv"
   },
   "outputs": [],
   "source": [
    "# y = y[:2000]\n",
    "# latent_train = latent_train[:2000,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ywFfO_eDk8Ij"
   },
   "outputs": [],
   "source": [
    "# np.random.shuffle(y)\n",
    "# print(y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "_rh0xMVs5ZlY"
   },
   "source": [
    "# Tree Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 63804,
     "status": "ok",
     "timestamp": 1693197231627,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "LbEIKNxYOOW8",
    "outputId": "773768cd-bc39-4605-e99b-c6b1e82526a7"
   },
   "outputs": [],
   "source": [
    "et = ExtraTreesClassifier(n_estimators=500, min_samples_leaf=100,\n",
    "                          max_features=\"sqrt\", bootstrap=True, class_weight='balanced', n_jobs=-1)\n",
    "\n",
    "# et = RandomForestClassifier(n_estimators=500, min_samples_leaf=100,\n",
    "#                           max_features=\"sqrt\", bootstrap=True, class_weight='balanced', n_jobs=-1)\n",
    "\n",
    "# validation instance\n",
    "skf = StratifiedKFold(n_splits=5, shuffle=True)\n",
    "\n",
    "# getting the model validation predictions\n",
    "preds = cross_val_predict(et, latent_train, y, cv=skf, method='predict_proba')\n",
    "\n",
    "# evaluating the model\n",
    "print('Area under the ROC Curve:', roc_auc_score(y, preds, multi_class='ovo'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 92
    },
    "executionInfo": {
     "elapsed": 25770,
     "status": "ok",
     "timestamp": 1693197257377,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "Yl8zBDu1OOZS",
    "outputId": "b5ef2afa-9893-459e-d539-3efb29515240"
   },
   "outputs": [],
   "source": [
    "et.fit(latent_train,y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 16086,
     "status": "ok",
     "timestamp": 1693197273459,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "rhPRj8x9OObV",
    "outputId": "057736f4-42e7-4768-ffbf-a5773fe29914"
   },
   "outputs": [],
   "source": [
    "leaves_train = et.apply(latent_train)\n",
    "print(leaves_train.shape)\n",
    "print(leaves_train)\n",
    "\n",
    "distances_train = np.zeros((1000,1000))\n",
    "\n",
    "\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_train[i,j] = hamming(leaves_train[i,:], leaves_train[j,:])\n",
    "\n",
    "score_train = sum(distances_train)/999\n",
    "\n",
    "print(np.mean(score_train))\n",
    "print(np.cov(score_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ABZtYxACjjJa"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "yoIPrBqFqXT8"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "torch.save(model.state_dict(), path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 37,
     "status": "ok",
     "timestamp": 1693197273460,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "xjEYJHlhjjfF",
    "outputId": "19344aef-9c49-49fe-ce0d-5817f0cc03c8"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "K534l0C15dOs"
   },
   "source": [
    "# Testing on ID Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "VWwIw7NDjATd"
   },
   "outputs": [],
   "source": [
    "num_epoch = 30"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 117073,
     "status": "ok",
     "timestamp": 1693197390503,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "qgiK4zhzOOdJ",
    "outputId": "c0f649d9-68c2-47f7-f9f0-5209ee84e38e"
   },
   "outputs": [],
   "source": [
    "test_dataset_Cifar10 = torchvision.datasets.CIFAR10(root='./data', train=False, download=True, transform=transform)\n",
    "test_loader_Cifar10 = torch.utils.data.DataLoader(test_dataset_Cifar10, batch_size = 64, shuffle=True)\n",
    "\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, test_loader_Cifar10, criterion, optimizer, num_epochs=num_epoch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 4842,
     "status": "ok",
     "timestamp": 1693197395328,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "of_ZbBltOOfR",
    "outputId": "a51a196d-50dc-429b-b4e1-f7992adeaa61"
   },
   "outputs": [],
   "source": [
    "test_dataset_Cifar10 = torchvision.datasets.CIFAR10(root='./data', train=False, download=True, transform=transform)\n",
    "test_loader_Cifar10 = torch.utils.data.DataLoader(test_dataset_Cifar10, batch_size = 10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_Cifar10:\n",
    "    img, _ = batch\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "    #img = img.reshape(-1, 28*28)\n",
    "\n",
    "    # Generating output\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "\n",
    "latent_test = latent_test.detach().numpy()\n",
    "X_test = img.detach().numpy()\n",
    "print(X_test.shape)\n",
    "print(latent_test.shape)\n",
    "X_test = X_test.reshape(-1,3*32*32)\n",
    "latent_test = latent_test.reshape(-1,64*4*4)\n",
    "print(X_test.shape)\n",
    "print(latent_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 16694,
     "status": "ok",
     "timestamp": 1693197412000,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "0IE7QW4RTX1r",
    "outputId": "ee085a47-57de-4c50-d96c-bb01b2d26576"
   },
   "outputs": [],
   "source": [
    "latent_test_in = latent_test\n",
    "\n",
    "leaves_test_in = et.apply(latent_test_in)\n",
    "print(leaves_test_in.shape)\n",
    "print(leaves_test_in)\n",
    "\n",
    "distances_test_in = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_in[i,j] = hamming(leaves_test_in[i,:], leaves_test_in[j,:])\n",
    "\n",
    "score_test_in = sum(distances_test_in)/999\n",
    "\n",
    "print(np.mean(score_test_in))\n",
    "print(np.cov(score_test_in))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "xNTHQMtVT8Wb"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "0dOaVz-G5h-n"
   },
   "source": [
    "# Testing on OOD Data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "R0dTYN6B5k2t"
   },
   "source": [
    "## SVHN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 29,
     "status": "ok",
     "timestamp": 1693197412000,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "hTQoUtj_jmGO",
    "outputId": "cd38263b-793e-43b5-b058-d8ac1af43e0d"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 251243,
     "status": "ok",
     "timestamp": 1693197663220,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "49wqpHD5T8aU",
    "outputId": "504191eb-3796-4198-b6fb-e43bb59219b3"
   },
   "outputs": [],
   "source": [
    "transform = torchvision.transforms.Compose(\n",
    "    [torchvision.transforms.Resize((32, 32)),  # Resize images to match the size of MNIST\n",
    "     torchvision.transforms.ToTensor()])\n",
    "\n",
    "train_dataset_SVHN = torchvision.datasets.SVHN(root='./data', split='test', download=True, transform=transform)\n",
    "train_loader_SVHN = torch.utils.data.DataLoader(train_dataset_SVHN, batch_size=64, shuffle=True, num_workers=4)\n",
    "\n",
    "# # Training the model\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, train_loader_SVHN, criterion, optimizer, num_epochs=num_epoch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 12613,
     "status": "ok",
     "timestamp": 1693197675808,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "bj5nGoXgT8cr",
    "outputId": "321f51ec-5789-4db5-e57d-29a213f284a6"
   },
   "outputs": [],
   "source": [
    "test_dataset_SVHN = torchvision.datasets.SVHN(root='./data', split='test', download=True, transform=transform)\n",
    "test_loader_SVHN = torch.utils.data.DataLoader(test_dataset_SVHN, batch_size=10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_SVHN:\n",
    "    img, _ = batch\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "\n",
    "    # Generating output\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test_out = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test_out = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "latent_test_out_SVHN = latent_test_out.detach().numpy()\n",
    "latent_test_out_SVHN = latent_test_out_SVHN.reshape(-1,64*4*4)\n",
    "print(latent_test_out_SVHN.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 14466,
     "status": "ok",
     "timestamp": 1693197690247,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "X6-qPSDtT8ee",
    "outputId": "383a28c4-03d8-4e92-94bd-e027b7bc8ab3"
   },
   "outputs": [],
   "source": [
    "leaves_test_out_SVHN = et.apply(latent_test_out_SVHN)\n",
    "\n",
    "print(leaves_test_out_SVHN.shape)\n",
    "print(leaves_test_out_SVHN)\n",
    "\n",
    "distances_test_out_SVHN = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_out_SVHN[i,j] = hamming(leaves_test_out_SVHN[i,:], leaves_test_out_SVHN[j,:])\n",
    "\n",
    "\n",
    "score_test_out_SVHN = sum(distances_test_out_SVHN)/999\n",
    "\n",
    "print(np.mean(score_test_out_SVHN))\n",
    "print(np.cov(score_test_out_SVHN))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "9sHeycAMT8i8"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "T3e1IFik5vo6"
   },
   "source": [
    "## DTD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 34,
     "status": "ok",
     "timestamp": 1693197690256,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "AY1XUvLjj_MS",
    "outputId": "9fc7a792-c9c0-4e9a-bb15-8c5585ae3d12"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 106448,
     "status": "ok",
     "timestamp": 1693197796676,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "zrwoZF6Vx2qu",
    "outputId": "57cff7fc-b31a-42ed-9caf-069c6de30c58"
   },
   "outputs": [],
   "source": [
    "# fine tuning the AE\n",
    "transform = torchvision.transforms.Compose(\n",
    "    [torchvision.transforms.Resize((32, 32)),  # Resize images to match the size of MNIST\n",
    "     torchvision.transforms.ToTensor()])\n",
    "\n",
    "train_dataset_DTD = torchvision.datasets.DTD(root='./data', split='test', download=True, transform=transform)\n",
    "train_loader_DTD = torch.utils.data.DataLoader(train_dataset_DTD, batch_size=64, shuffle=True, num_workers=4)\n",
    "\n",
    "# # Training the model\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, train_loader_DTD, criterion, optimizer, num_epochs=num_epoch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 7513,
     "status": "ok",
     "timestamp": 1693197804164,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "ULj-NLe0x-aU",
    "outputId": "aa997cd0-a8de-4c1b-9ed3-bcc0419c45b8"
   },
   "outputs": [],
   "source": [
    "test_dataset_DTD = torchvision.datasets.DTD(root='./data', split='test', download=True, transform=transform)\n",
    "test_loader_DTD = torch.utils.data.DataLoader(test_dataset_DTD, batch_size=10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_DTD:\n",
    "    img, _ = batch\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "\n",
    "    # Generating output\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test_out = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test_out = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "\n",
    "latent_test_out_DTD = latent_test_out.detach().numpy()\n",
    "latent_test_out_DTD = latent_test_out_DTD.reshape(-1,64*4*4)\n",
    "print(latent_test_out_DTD.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 17184,
     "status": "ok",
     "timestamp": 1693197821324,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "ucyfkSd0x-cY",
    "outputId": "056eaa84-72e3-48b8-fdd1-483201421374"
   },
   "outputs": [],
   "source": [
    "leaves_test_out_DTD = et.apply(latent_test_out_DTD)\n",
    "\n",
    "print(leaves_test_out_DTD.shape)\n",
    "print(leaves_test_out_DTD)\n",
    "\n",
    "distances_test_out_DTD = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_out_DTD[i,j] = hamming(leaves_test_out_DTD[i,:], leaves_test_out_DTD[j,:])\n",
    "\n",
    "\n",
    "score_test_out_DTD = sum(distances_test_out_DTD)/999\n",
    "\n",
    "print(np.mean(score_test_out_DTD))\n",
    "print(np.cov(score_test_out_DTD))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "fEdczdqI74Le"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "lUTb_pX158SO"
   },
   "source": [
    "## Places365"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27,
     "status": "ok",
     "timestamp": 1693197821325,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "GXM0Kh4D5HmY",
    "outputId": "5eef2d1a-a98d-4f3e-be7e-585ac56d4518"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 499661,
     "status": "ok",
     "timestamp": 1693198320965,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "O_IR7dGy5-TY",
    "outputId": "9cb1a75d-32a2-43ba-ce06-dbc26b3a24d8"
   },
   "outputs": [],
   "source": [
    "# fine tuning the AE\n",
    "transform = torchvision.transforms.Compose(\n",
    "    [torchvision.transforms.Resize((32, 32)),  # Resize images to match the size of MNIST\n",
    "     torchvision.transforms.ToTensor()])\n",
    "\n",
    "train_dataset_Places365 = torchvision.datasets.Places365(root='./data', split='val', small=True, download=False, transform=transform)\n",
    "train_loader_Places365 = torch.utils.data.DataLoader(train_dataset_Places365, batch_size=64, shuffle=True, num_workers=4)\n",
    "\n",
    "# # Training the model\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, train_loader_Places365, criterion, optimizer, num_epochs=num_epoch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 51442,
     "status": "ok",
     "timestamp": 1693198372404,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "SZNDQf_s5-Vd",
    "outputId": "08cd4e8a-90eb-4fc2-ddb7-99e32f2f3c99"
   },
   "outputs": [],
   "source": [
    "test_dataset_Places365 = torchvision.datasets.Places365(root='./data', split='val', small=True, download=False, transform=transform)\n",
    "test_loader_Places365 = torch.utils.data.DataLoader(test_dataset_Places365, batch_size=10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_Places365:\n",
    "    img, _ = batch\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "    #img = img.reshape(-1,1,28,28)\n",
    "\n",
    "    # Generating output\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test_out = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test_out = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "\n",
    "latent_test_out_Places365 = latent_test_out.detach().numpy()\n",
    "latent_test_out_Places365 = latent_test_out_Places365.reshape(-1,64*4*4)\n",
    "print(latent_test_out_Places365.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 19712,
     "status": "ok",
     "timestamp": 1693198392093,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "BpWZam8J5-Y2",
    "outputId": "b3649cbb-65b5-406a-9c6b-3281377c19f1"
   },
   "outputs": [],
   "source": [
    "leaves_test_out_Places365 = et.apply(latent_test_out_Places365)\n",
    "\n",
    "print(leaves_test_out_Places365.shape)\n",
    "print(leaves_test_out_Places365)\n",
    "\n",
    "distances_test_out_Places365 = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_out_Places365[i,j] = hamming(leaves_test_out_Places365[i,:], leaves_test_out_Places365[j,:])\n",
    "\n",
    "\n",
    "score_test_out_Places365 = sum(distances_test_out_Places365)/999\n",
    "\n",
    "print(np.mean(score_test_out_Places365))\n",
    "print(np.cov(score_test_out_Places365))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "kh8zbKA2ij_b"
   },
   "source": [
    "## iSUN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27,
     "status": "ok",
     "timestamp": 1693198392094,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "RwawMPGc5-ar",
    "outputId": "693651b2-0285-4b39-d55d-c262eaa5f3ef"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 56261,
     "status": "ok",
     "timestamp": 1693198448334,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "UZAefg-pilUm",
    "outputId": "4faa1cab-6992-4b86-a643-b1bd1580181b"
   },
   "outputs": [],
   "source": [
    "# images = torch.zeros((8924,3,32,32))\n",
    "\n",
    "# for i in range(8924):\n",
    "#     print(i)\n",
    "#     images[i,:,:,:] = read_image('/content/gdrive/MyDrive/OODdata/iSUN/iSUN_patches/' + str(i) + '.jpeg')\n",
    "\n",
    "# torch.save(images, '/content/gdrive/MyDrive/images_iSUN.t')\n",
    "images = torch.load('/content/gdrive/MyDrive/TOOD/datasets/images_iSUN.t')\n",
    "\n",
    "test_dataset_iSUN = images/255\n",
    "train_loader_iSUN = torch.utils.data.DataLoader(test_dataset_iSUN, batch_size = 64, shuffle=True)\n",
    "\n",
    "# # Training the model\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, train_loader_iSUN, criterion, optimizer, num_epochs=num_epoch, online=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 2610,
     "status": "ok",
     "timestamp": 1693198450941,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "rRLkpl8JilWr",
    "outputId": "43677d01-fd0d-45a8-abd8-7ddd23fee0bf"
   },
   "outputs": [],
   "source": [
    "test_loader_iSUN = torch.utils.data.DataLoader(test_dataset_iSUN, batch_size = 10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_iSUN:\n",
    "    img = batch\n",
    "    transforms = torchvision.transforms.Resize((32,32))\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "    #img = img.reshape(-1, 28*28)\n",
    "\n",
    "    # Generating output\n",
    "    img = transforms(img)\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test_out = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test_out = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "\n",
    "latent_test_out_iSUN = latent_test_out.detach().numpy()\n",
    "print(latent_test_out_iSUN.shape)\n",
    "latent_test_out_iSUN = latent_test_out_iSUN.reshape(-1,64*4*4)\n",
    "print(latent_test_out_iSUN.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 14434,
     "status": "ok",
     "timestamp": 1693198465367,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "m93p06uEilYw",
    "outputId": "b84eeaad-811c-46e6-c63f-8db7a7a9a7b1"
   },
   "outputs": [],
   "source": [
    "leaves_test_out_iSUN = et.apply(latent_test_out_iSUN)\n",
    "\n",
    "print(leaves_test_out_iSUN.shape)\n",
    "print(leaves_test_out_iSUN)\n",
    "\n",
    "distances_test_out_iSUN = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_out_iSUN[i,j] = hamming(leaves_test_out_iSUN[i,:], leaves_test_out_iSUN[j,:])\n",
    "\n",
    "\n",
    "score_test_out_iSUN = sum(distances_test_out_iSUN)/999\n",
    "\n",
    "print(np.mean(score_test_out_iSUN))\n",
    "print(np.cov(score_test_out_iSUN))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "PXpiSYbGilai"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "w0A_R-VPme3h"
   },
   "source": [
    "## LSUN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 26,
     "status": "ok",
     "timestamp": 1693198465369,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "beGos-wBoFsZ",
    "outputId": "db4714b0-682d-4b0c-ccf0-306a25ff8a2a"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 62857,
     "status": "ok",
     "timestamp": 1693198528204,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "tkB7jZNnmgsW",
    "outputId": "feeb5eaf-43a5-4270-ed1c-66e4b9b06909"
   },
   "outputs": [],
   "source": [
    "# images = torch.zeros((10000,3,36,36))\n",
    "\n",
    "# for i in range(10000):\n",
    "#     print(i)\n",
    "#     images[i,:,:,:] = read_image('/content/gdrive/MyDrive/OODdata/LSUN/test/' + str(i) + '.png')\n",
    "\n",
    "# torch.save(images, '/content/gdrive/MyDrive/images_LSUN.t')\n",
    "images = torch.load('/content/gdrive/MyDrive/TOOD/datasets/images_LSUN.t')\n",
    "\n",
    "test_dataset_LSUN = images/255\n",
    "train_loader_LSUN = torch.utils.data.DataLoader(test_dataset_LSUN, batch_size = 64, shuffle=True)\n",
    "\n",
    "# # Training the model\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, train_loader_LSUN, criterion, optimizer, num_epochs=num_epoch, online=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 2753,
     "status": "ok",
     "timestamp": 1693198530936,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "QxNClsvSmguZ",
    "outputId": "b74f093b-e134-42c3-d521-229b778aa3a6"
   },
   "outputs": [],
   "source": [
    "test_loader_LSUN = torch.utils.data.DataLoader(test_dataset_LSUN, batch_size = 10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_LSUN:\n",
    "    img = batch\n",
    "    transforms = torchvision.transforms.Resize((32,32))\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "    #img = img.reshape(-1, 28*28)\n",
    "\n",
    "    # Generating output\n",
    "    img = transforms(img)\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test_out = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test_out = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "\n",
    "latent_test_out_LSUN = latent_test_out.detach().numpy()\n",
    "print(latent_test_out_LSUN.shape)\n",
    "latent_test_out_LSUN = latent_test_out_LSUN.reshape(-1,64*4*4)\n",
    "print(latent_test_out_LSUN.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 14776,
     "status": "ok",
     "timestamp": 1693198545708,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "c2pqFpRqmgwe",
    "outputId": "b8e9b5d4-a63a-4c51-8320-c23a342e4e1b"
   },
   "outputs": [],
   "source": [
    "leaves_test_out_LSUN = et.apply(latent_test_out_LSUN)\n",
    "\n",
    "print(leaves_test_out_LSUN.shape)\n",
    "print(leaves_test_out_LSUN)\n",
    "\n",
    "distances_test_out_LSUN = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_out_LSUN[i,j] = hamming(leaves_test_out_LSUN[i,:], leaves_test_out_LSUN[j,:])\n",
    "\n",
    "\n",
    "score_test_out_LSUN = sum(distances_test_out_LSUN)/999\n",
    "\n",
    "print(np.mean(score_test_out_LSUN))\n",
    "print(np.cov(score_test_out_LSUN))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "kKC5XvehtTcI"
   },
   "source": [
    "## LSUN-resize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 23,
     "status": "ok",
     "timestamp": 1693198545709,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "XFQoVRZDmgyT",
    "outputId": "efd6c1c3-b67f-4b7f-de34-ebf98063ba25"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 62834,
     "status": "ok",
     "timestamp": 1693198608523,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "C0J47UdQmg0q",
    "outputId": "f226183e-76a4-4292-fc40-39d7c605e810"
   },
   "outputs": [],
   "source": [
    "# images = torch.zeros((10000,3,32,32))\n",
    "\n",
    "# for i in range(10000):\n",
    "#     print(i)\n",
    "#     images[i,:,:,:] = read_image('/content/gdrive/MyDrive/OODdata/LSUN_resize/test/' + str(i) + '.jpg')\n",
    "\n",
    "# torch.save(images, '/content/gdrive/MyDrive/images_LSUN_resize.t')\n",
    "images = torch.load('/content/gdrive/MyDrive/TOOD/datasets/images_LSUN_resize.t')\n",
    "\n",
    "test_dataset_LSUN_resize = images/255\n",
    "train_loader_LSUN_resize = torch.utils.data.DataLoader(test_dataset_LSUN_resize, batch_size = 64, shuffle=True)\n",
    "\n",
    "# # Training the model\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, train_loader_LSUN_resize, criterion, optimizer, num_epochs=num_epoch, online=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 2923,
     "status": "ok",
     "timestamp": 1693198611423,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "XseJ5T0itYjt",
    "outputId": "9cab6eb0-6227-428d-a41b-72fee4b56bc0"
   },
   "outputs": [],
   "source": [
    "test_loader_LSUN_resize = torch.utils.data.DataLoader(test_dataset_LSUN_resize, batch_size = 10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_LSUN_resize:\n",
    "    img = batch\n",
    "    transforms = torchvision.transforms.Resize((32,32))\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "    #img = img.reshape(-1, 28*28)\n",
    "\n",
    "    # Generating output\n",
    "    img = transforms(img)\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test_out = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test_out = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "\n",
    "latent_test_out_LSUN_resize = latent_test_out.detach().numpy()\n",
    "print(latent_test_out_LSUN_resize.shape)\n",
    "latent_test_out_LSUN_resize = latent_test_out_LSUN_resize.reshape(-1,64*4*4)\n",
    "print(latent_test_out_LSUN_resize.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 14878,
     "status": "ok",
     "timestamp": 1693198626298,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "FFTCoWbltYmS",
    "outputId": "41d41b60-343f-47ae-f4f7-b70c9493dc36"
   },
   "outputs": [],
   "source": [
    "leaves_test_out_LSUN_resize = et.apply(latent_test_out_LSUN_resize)\n",
    "\n",
    "print(leaves_test_out_LSUN_resize.shape)\n",
    "print(leaves_test_out_LSUN_resize)\n",
    "\n",
    "distances_test_out_LSUN_resize = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_out_LSUN_resize[i,j] = hamming(leaves_test_out_LSUN_resize[i,:], leaves_test_out_LSUN_resize[j,:])\n",
    "\n",
    "\n",
    "score_test_out_LSUN_resize = sum(distances_test_out_LSUN_resize)/999\n",
    "\n",
    "print(np.mean(score_test_out_LSUN_resize))\n",
    "print(np.cov(score_test_out_LSUN_resize))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "F3ZeGXM-tYyk"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "GHsCOBn651NY"
   },
   "source": [
    "## STL10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 31,
     "status": "ok",
     "timestamp": 1693198626300,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "O5o8VSMQkHcH",
    "outputId": "9be87115-1797-4b09-bf74-554b0308c915"
   },
   "outputs": [],
   "source": [
    "model_Conv_AE_OOD_Cifar10_Color_train_30 = 'classifier.pt'\n",
    "path = \"/content/gdrive/My Drive/{model_Conv_AE_OOD_Cifar10_Color_train_30}\"\n",
    "model.load_state_dict(torch.load(path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 112248,
     "status": "ok",
     "timestamp": 1693198738522,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "U3d1TPkvzqzX",
    "outputId": "08e3fe0e-4f9e-44f6-ffd4-82e1211c2053"
   },
   "outputs": [],
   "source": [
    "# fine tuning the AE\n",
    "transform = torchvision.transforms.Compose(\n",
    "    [torchvision.transforms.Resize((32, 32)),  # Resize images to match the size of MNIST\n",
    "     torchvision.transforms.ToTensor()])\n",
    "\n",
    "train_dataset_STL10 = torchvision.datasets.STL10(root='./data', split='test', download=True, transform=transform)\n",
    "train_loader_STL10 = torch.utils.data.DataLoader(train_dataset_STL10, batch_size=64, shuffle=True, num_workers=4)\n",
    "\n",
    "# # Training the model\n",
    "# model = ConvAutoencoder()\n",
    "# criterion = nn.MSELoss()\n",
    "# optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "train(model, train_loader_STL10, criterion, optimizer, num_epochs=num_epoch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 12808,
     "status": "ok",
     "timestamp": 1693198751308,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "4kZ96mhKzz7h",
    "outputId": "b0395a98-e4f9-4f17-a981-907cc7178617"
   },
   "outputs": [],
   "source": [
    "test_dataset_STL10 = torchvision.datasets.STL10(root='./data', split='test', download=True, transform=transform)\n",
    "test_loader_STL10 = torch.utils.data.DataLoader(test_dataset_STL10, batch_size=10000, shuffle=True)\n",
    "\n",
    "for batch in test_loader_STL10:\n",
    "    img, _ = batch\n",
    "    #img = torchvision.transforms.Grayscale(num_output_channels=1)(img)\n",
    "\n",
    "    # Generating output\n",
    "    ## out = model.forward(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "    out = model.forward(img)\n",
    "    img.requires_grad = True\n",
    "    loss = criterion(out, img)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    gradient = img.grad.data.sign()\n",
    "    img = img + 0.1 * gradient\n",
    "    latent_test_out = model.forward_encoder(img)\n",
    "\n",
    "    ## latent_test_out = model.forward_encoder(img + torch.randn(img.size()) * 0.0)\n",
    "\n",
    "latent_test_out_STL10 = latent_test_out.detach().numpy()\n",
    "latent_test_out_STL10 = latent_test_out_STL10.reshape(-1,64*4*4)\n",
    "print(latent_test_out_STL10.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 19218,
     "status": "ok",
     "timestamp": 1693198770504,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "FtaqPjfoz05e",
    "outputId": "0378542e-5b72-466d-e52c-b98beb103c4a"
   },
   "outputs": [],
   "source": [
    "leaves_test_out_STL10 = et.apply(latent_test_out_STL10)\n",
    "\n",
    "print(leaves_test_out_STL10.shape)\n",
    "print(leaves_test_out_STL10)\n",
    "\n",
    "distances_test_out_STL10 = np.zeros((1000,1000))\n",
    "for i in range(1000):\n",
    "    for j in range(1000):\n",
    "        distances_test_out_STL10[i,j] = hamming(leaves_test_out_STL10[i,:], leaves_test_out_STL10[j,:])\n",
    "\n",
    "\n",
    "score_test_out_STL10 = sum(distances_test_out_STL10)/999\n",
    "\n",
    "print(np.mean(score_test_out_STL10))\n",
    "print(np.cov(score_test_out_STL10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "N8mvccjO3KjF"
   },
   "source": [
    "## Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "VSjc6SZP4lRv"
   },
   "outputs": [],
   "source": [
    "my_dict = {'Cifar10': score_test_in, 'SVHN': score_test_out_SVHN, 'DTD': score_test_out_DTD,\n",
    "           'Places365': score_test_out_Places365, 'iSUN': score_test_out_iSUN, 'LSUN': score_test_out_LSUN, \n",
    "           'LSUN-resize': score_test_out_LSUN_resize,'STL10': score_test_out_STL10}\n",
    "\n",
    "plt.figure(figsize=(10,6))\n",
    "plt.boxplot(my_dict.values(), labels=my_dict.keys());\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 45,
     "status": "ok",
     "timestamp": 1693198770508,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "BxcQ41vk4qfi",
    "outputId": "90650aea-3aad-4b2c-b230-8b25380bf3bd"
   },
   "outputs": [],
   "source": [
    "score_pred_STL10 = np.concatenate([score_test_in, score_test_out_STL10])\n",
    "score_pred_Places365 = np.concatenate([score_test_in, score_test_out_Places365])\n",
    "score_pred_iSUN = np.concatenate([score_test_in, score_test_out_iSUN])\n",
    "score_pred_LSUN = np.concatenate([score_test_in, score_test_out_LSUN])\n",
    "score_pred_LSUN_resize = np.concatenate([score_test_in, score_test_out_LSUN_resize])\n",
    "score_pred_SVHN = np.concatenate([score_test_in, score_test_out_SVHN])\n",
    "score_pred_DTD = np.concatenate([score_test_in, score_test_out_DTD])\n",
    "score_true = np.concatenate([np.ones(1000), np.zeros(1000)])\n",
    "\n",
    "print(roc_auc_score(score_true, score_pred_SVHN))\n",
    "print(roc_auc_score(score_true, score_pred_DTD))\n",
    "print(roc_auc_score(score_true, score_pred_Places365))\n",
    "print(roc_auc_score(score_true, score_pred_iSUN))\n",
    "print(roc_auc_score(score_true, score_pred_LSUN))\n",
    "print(roc_auc_score(score_true, score_pred_LSUN_resize))\n",
    "print(roc_auc_score(score_true, score_pred_STL10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 41,
     "status": "ok",
     "timestamp": 1693198770508,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "g3S-yTu64qhs",
    "outputId": "483dd141-2961-4b05-9582-8db92bc114e6"
   },
   "outputs": [],
   "source": [
    "precision_STL10, recall_STL10, thresholds_STL10 = precision_recall_curve(score_true, score_pred_STL10)\n",
    "precision_Places365, recall_Places365, thresholds_Places365 = precision_recall_curve(score_true, score_pred_Places365)\n",
    "precision_SVHN, recall_SVHN, thresholds_SVHN = precision_recall_curve(score_true, score_pred_SVHN)\n",
    "precision_DTD, recall_DTD, thresholds_DTD = precision_recall_curve(score_true, score_pred_DTD)\n",
    "precision_iSUN, recall_iSUN, thresholds_iSUN = precision_recall_curve(score_true, score_pred_iSUN)\n",
    "precision_LSUN, recall_LSUN, thresholds_LSUN = precision_recall_curve(score_true, score_pred_LSUN)\n",
    "precision_LSUN_resize, recall_LSUN_resize, thresholds_LSUN_resize = precision_recall_curve(score_true, score_pred_LSUN_resize)\n",
    "\n",
    "\n",
    "auc_precision_recall_STL10= auc(recall_STL10, precision_STL10)\n",
    "auc_precision_recall_Places365 = auc(recall_Places365, precision_Places365)\n",
    "auc_precision_recall_SVHN = auc(recall_SVHN, precision_SVHN)\n",
    "auc_precision_recall_DTD = auc(recall_DTD, precision_DTD)\n",
    "auc_precision_recall_iSUN = auc(recall_iSUN, precision_iSUN)\n",
    "auc_precision_recall_LSUN = auc(recall_LSUN, precision_LSUN)\n",
    "auc_precision_recall_LSUN_resize = auc(recall_LSUN_resize, precision_LSUN_resize)\n",
    "\n",
    "print(auc_precision_recall_SVHN)\n",
    "print(auc_precision_recall_DTD)\n",
    "print(auc_precision_recall_Places365)\n",
    "print(auc_precision_recall_iSUN)\n",
    "print(auc_precision_recall_LSUN)\n",
    "print(auc_precision_recall_LSUN_resize)\n",
    "print(auc_precision_recall_STL10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 44,
     "status": "ok",
     "timestamp": 1693198770513,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "J-H9UUQY8AfD",
    "outputId": "b799b745-830b-4a3d-b873-941c3d374d63"
   },
   "outputs": [],
   "source": [
    "def compute_fpr95(y_true, y_pred_probs):\n",
    "    fpr, tpr, thresholds = sklearn.metrics.roc_curve(y_true, y_pred_probs)\n",
    "    idx = np.abs(tpr - 0.95).argmin()\n",
    "    fpr95 = fpr[idx]\n",
    "    return fpr95\n",
    "\n",
    "# Example usage\n",
    "# Assuming you have y_true (true labels) and y_pred_probs (predicted probabilities)\n",
    "fpr95_score_SVHN = compute_fpr95(score_true, score_pred_SVHN)\n",
    "fpr95_score_DTD = compute_fpr95(score_true, score_pred_DTD)\n",
    "fpr95_score_Places365 = compute_fpr95(score_true, score_pred_Places365)\n",
    "fpr95_score_iSUN = compute_fpr95(score_true, score_pred_iSUN)\n",
    "fpr95_score_LSUN = compute_fpr95(score_true, score_pred_LSUN)\n",
    "fpr95_score_LSUN_resize = compute_fpr95(score_true, score_pred_LSUN_resize)\n",
    "fpr95_score_STL10 = compute_fpr95(score_true, score_pred_STL10)\n",
    "\n",
    "print(fpr95_score_SVHN)\n",
    "print(fpr95_score_DTD)\n",
    "print(fpr95_score_Places365)\n",
    "print(fpr95_score_iSUN)\n",
    "print(fpr95_score_LSUN)\n",
    "print(fpr95_score_LSUN_resize)\n",
    "print(fpr95_score_STL10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "4Uw_2RZ74qjt"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 42,
     "status": "ok",
     "timestamp": 1693198770513,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "dNXlKk1BbKMv",
    "outputId": "96f65d10-5e87-4b6d-97c2-88f7cfa47181"
   },
   "outputs": [],
   "source": [
    "print(np.mean(score_test_in), np.cov(score_test_in))\n",
    "print(np.mean(score_test_out_SVHN), np.cov(score_test_out_SVHN))\n",
    "print(np.mean(score_test_out_DTD), np.cov(score_test_out_DTD))\n",
    "print(np.mean(score_test_out_Places365), np.cov(score_test_out_Places365))\n",
    "print(np.mean(score_test_out_iSUN), np.cov(score_test_out_iSUN))\n",
    "print(np.mean(score_test_out_LSUN), np.cov(score_test_out_LSUN))\n",
    "print(np.mean(score_test_out_LSUN_resize), np.cov(score_test_out_LSUN_resize))\n",
    "print(np.mean(score_test_out_STL10), np.cov(score_test_out_STL10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Ouw1BySBSQQn"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "V-tVNhcbSX4H"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "authorship_tag": "ABX9TyPaGcJVB4N6S3dEY17Fla/1",
   "machine_shape": "hm",
   "provenance": [
    {
     "file_id": "1D8EBZnGmbgBZITfM1GANy_77Ve0WxLY6",
     "timestamp": 1692716439297
    }
   ]
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
