{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30120,
     "status": "ok",
     "timestamp": 1694031680088,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "UHgERHwINWD7",
    "outputId": "323784cd-b825-41d4-83aa-34d831ad58b2"
   },
   "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": 5721,
     "status": "ok",
     "timestamp": 1694031685804,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "ZcDnLKaQkdal",
    "outputId": "2f118cec-2bd1-434d-8470-310a4b99ffde"
   },
   "outputs": [],
   "source": [
    "pip install PIMS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 4400,
     "status": "ok",
     "timestamp": 1694031696919,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "IZT0LCFnkfGb",
    "outputId": "0308cf9c-04bb-4127-b258-c646e7d1efb6"
   },
   "outputs": [],
   "source": [
    "pip install fastcluster"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 5283,
     "status": "ok",
     "timestamp": 1694031702956,
     "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",
    "\n",
    "plt.rcParams['axes.facecolor'] = 'white'\n",
    "plt.rcParams['figure.figsize'] = 9, 6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 21571,
     "status": "ok",
     "timestamp": 1694031724523,
     "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": 9,
     "status": "ok",
     "timestamp": 1693537700116,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "aILiFBc-6XZb",
    "outputId": "ab19d27f-5551-462b-a07b-dc4fb362174a"
   },
   "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": 52540,
     "status": "ok",
     "timestamp": 1693537752652,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "6NftBdp9Nd5U",
    "outputId": "d422dfbb-c23a-423a-f025-1c53231bb380"
   },
   "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": 22616,
     "status": "ok",
     "timestamp": 1693537775244,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "-Lw_PhMiNd7J",
    "outputId": "0098ec5d-eaa0-4417-ddb9-ad0e140e118e"
   },
   "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": 24,
     "status": "ok",
     "timestamp": 1693537775245,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "pjGzdfeLOA-b",
    "outputId": "a3ff052c-ad6e-49af-eb8f-97d95b59609a"
   },
   "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": 8134,
     "status": "ok",
     "timestamp": 1693537783362,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "GKqaLHKjOEJS",
    "outputId": "3742c701-b6a9-4514-f711-37505a6fdb78"
   },
   "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[:10000]\n",
    "# latent_train = latent_train[:10000,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 10,
     "status": "ok",
     "timestamp": 1693537810939,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "ywFfO_eDk8Ij",
    "outputId": "dad637da-9019-4f2e-bad0-510413a4a889"
   },
   "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": 17687,
     "status": "ok",
     "timestamp": 1693537828621,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "LbEIKNxYOOW8",
    "outputId": "d81b54d3-f1e6-4b12-9880-433bdab77e74"
   },
   "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": 3728,
     "status": "ok",
     "timestamp": 1693537832336,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "Yl8zBDu1OOZS",
    "outputId": "8804aaa5-e045-4e2b-96e9-ade83e4e2d9a"
   },
   "outputs": [],
   "source": [
    "et.fit(latent_train,y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 17217,
     "status": "ok",
     "timestamp": 1693537849549,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "rhPRj8x9OObV",
    "outputId": "2f99ddaf-3aa3-4ee4-ce65-b0d352ec79f3"
   },
   "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": 29,
     "status": "ok",
     "timestamp": 1693537849550,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "xjEYJHlhjjfF",
    "outputId": "b3261375-dcb3-49af-982c-2ea273034055"
   },
   "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": 118238,
     "status": "ok",
     "timestamp": 1693537967765,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "qgiK4zhzOOdJ",
    "outputId": "47c1a87e-2a60-413c-d0bc-e39aaf505ff2"
   },
   "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": 4851,
     "status": "ok",
     "timestamp": 1693537972596,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "of_ZbBltOOfR",
    "outputId": "63264e22-f337-4ad7-f982-d6b5b4b51e47"
   },
   "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": 19251,
     "status": "ok",
     "timestamp": 1693537991833,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "0IE7QW4RTX1r",
    "outputId": "cdc3f5c4-b619-4cfb-d697-d9e26b136648"
   },
   "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": 23,
     "status": "ok",
     "timestamp": 1693537991834,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "hTQoUtj_jmGO",
    "outputId": "9ef6cff7-e459-4273-f581-be18f1b2f842"
   },
   "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": 261613,
     "status": "ok",
     "timestamp": 1693538253428,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "49wqpHD5T8aU",
    "outputId": "34400694-f09d-4d0c-f7e2-eca105f7f057"
   },
   "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": 12068,
     "status": "ok",
     "timestamp": 1693538265478,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "bj5nGoXgT8cr",
    "outputId": "27daa3b2-48d5-41c7-c227-0d142a794e1a"
   },
   "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": 18350,
     "status": "ok",
     "timestamp": 1693538283805,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "X6-qPSDtT8ee",
    "outputId": "8ca22c9c-b30b-4c59-8667-b3fdef7b92e2"
   },
   "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": 26,
     "status": "ok",
     "timestamp": 1693538283807,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "AY1XUvLjj_MS",
    "outputId": "1fbbc7cf-6495-41a1-c27c-4fd8c3812b16"
   },
   "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": 92834,
     "status": "ok",
     "timestamp": 1693538376621,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "zrwoZF6Vx2qu",
    "outputId": "27bc26f5-a91a-4f95-8a3d-956cee7c86f0"
   },
   "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": 7715,
     "status": "ok",
     "timestamp": 1693538384310,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "ULj-NLe0x-aU",
    "outputId": "4f5e24fc-f672-436a-85d1-9cd9b00791ee"
   },
   "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": 17898,
     "status": "ok",
     "timestamp": 1693538402188,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "ucyfkSd0x-cY",
    "outputId": "174d3806-3daa-448e-bf41-025e979323f0"
   },
   "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": 25,
     "status": "ok",
     "timestamp": 1693538402190,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "GXM0Kh4D5HmY",
    "outputId": "e590cfad-3415-4564-b3b1-ce0ef0872e7c"
   },
   "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": 551681,
     "status": "ok",
     "timestamp": 1693538953852,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "O_IR7dGy5-TY",
    "outputId": "2eb0b154-8a6f-4c0c-d7d6-bc9f0c63b502"
   },
   "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": 53417,
     "status": "ok",
     "timestamp": 1693539007255,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "SZNDQf_s5-Vd",
    "outputId": "490f9a39-b608-4eef-a69e-b99f43d2fcf0"
   },
   "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": 22245,
     "status": "ok",
     "timestamp": 1693539029483,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "BpWZam8J5-Y2",
    "outputId": "af2c4ec5-8526-4c87-c78b-c50e84dc16fa"
   },
   "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": 3,
     "status": "ok",
     "timestamp": 1693539029483,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "RwawMPGc5-ar",
    "outputId": "7e26c6be-0b74-440f-cb8a-40badfda5a30"
   },
   "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": 59317,
     "status": "ok",
     "timestamp": 1693539088799,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "UZAefg-pilUm",
    "outputId": "acfd6799-4f5c-4ecf-86b9-b8a89db15e27"
   },
   "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": 2112,
     "status": "ok",
     "timestamp": 1693539090892,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "rRLkpl8JilWr",
    "outputId": "bc6454fd-18ec-4b5b-b39b-0ba7202603a4"
   },
   "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": 15740,
     "status": "ok",
     "timestamp": 1693539106628,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "m93p06uEilYw",
    "outputId": "c20b924f-8fcd-4c2b-b83d-8db09a5208af"
   },
   "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": 18,
     "status": "ok",
     "timestamp": 1693539106628,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "beGos-wBoFsZ",
    "outputId": "0822ad9c-4e90-44f1-a097-6a5f6f118a33"
   },
   "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": 66451,
     "status": "ok",
     "timestamp": 1693539173067,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "tkB7jZNnmgsW",
    "outputId": "007b9cae-a1df-4591-99f3-048eddc8602a"
   },
   "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": 2433,
     "status": "ok",
     "timestamp": 1693539175486,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "QxNClsvSmguZ",
    "outputId": "a147870b-f8de-4b01-f4ae-7eb25638f134"
   },
   "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": 19522,
     "status": "ok",
     "timestamp": 1693539195006,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "c2pqFpRqmgwe",
    "outputId": "14ff5e1a-b1e7-4590-a169-c37120e65d95"
   },
   "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": 19,
     "status": "ok",
     "timestamp": 1693539195007,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "XFQoVRZDmgyT",
    "outputId": "a33693fc-56ad-4dde-ef18-18dffc84ec73"
   },
   "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": 65139,
     "status": "ok",
     "timestamp": 1693539260133,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "C0J47UdQmg0q",
    "outputId": "6c4c8414-6374-4b88-c7b3-821a241b325d"
   },
   "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": 2138,
     "status": "ok",
     "timestamp": 1693539262253,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "XseJ5T0itYjt",
    "outputId": "fface1ac-80e7-4c53-be52-613d729664fb"
   },
   "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": 15608,
     "status": "ok",
     "timestamp": 1693539277859,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "FFTCoWbltYmS",
    "outputId": "e7a4d1af-98e2-48ed-e8c6-e5341ae7f98c"
   },
   "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": 19,
     "status": "ok",
     "timestamp": 1693539277860,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "O5o8VSMQkHcH",
    "outputId": "c5234fa3-38d6-4721-c2e8-139ccea0ab85"
   },
   "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": 107616,
     "status": "ok",
     "timestamp": 1693539385461,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "U3d1TPkvzqzX",
    "outputId": "42e893c9-aa91-4fdc-8c83-50971fab4c57"
   },
   "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": 11147,
     "status": "ok",
     "timestamp": 1693539396593,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "4kZ96mhKzz7h",
    "outputId": "37e4fdfe-c21c-498f-9dc0-2ebfd512e4ce"
   },
   "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": 19694,
     "status": "ok",
     "timestamp": 1693539416272,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "FtaqPjfoz05e",
    "outputId": "12b12a91-fea9-41e6-dd9a-3e2f44c266ff"
   },
   "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": {
    "id": "eIN4-uvZ3KgM"
   },
   "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": 30,
     "status": "ok",
     "timestamp": 1693539416277,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "BxcQ41vk4qfi",
    "outputId": "266a0dc3-8ed0-4145-83a9-d8fe7d7327c7"
   },
   "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",
    "\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": 28,
     "status": "ok",
     "timestamp": 1693539416278,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "g3S-yTu64qhs",
    "outputId": "d7d74109-3e64-4476-b6ba-9cac2ad9a5af"
   },
   "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",
    "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": 26,
     "status": "ok",
     "timestamp": 1693539416278,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "J-H9UUQY8AfD",
    "outputId": "1a19178d-2edb-47d4-e111-fd9809ad3cb9"
   },
   "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",
    "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": 8,
     "status": "ok",
     "timestamp": 1693539416518,
     "user": {
      "displayName": "Zhaiming Shen",
      "userId": "12760861740580065439"
     },
     "user_tz": 240
    },
    "id": "dNXlKk1BbKMv",
    "outputId": "f7dd11fc-4aa9-414a-c6c7-6e4c0a28d49f"
   },
   "outputs": [],
   "source": [
    "print(np.mean(score_test_in), np.sqrt(np.cov(score_test_in)))\n",
    "print(np.mean(score_test_out_SVHN), np.sqrt(np.cov(score_test_out_SVHN)))\n",
    "print(np.mean(score_test_out_DTD), np.sqrt(np.cov(score_test_out_DTD)))\n",
    "print(np.mean(score_test_out_Places365), np.sqrt(np.cov(score_test_out_Places365)))\n",
    "print(np.mean(score_test_out_iSUN), np.sqrt(np.cov(score_test_out_iSUN)))\n",
    "print(np.mean(score_test_out_LSUN), np.sqrt(np.cov(score_test_out_LSUN)))\n",
    "print(np.mean(score_test_out_LSUN_resize), np.sqrt(np.cov(score_test_out_LSUN_resize)))\n",
    "print(np.mean(score_test_out_STL10), np.sqrt(np.cov(score_test_out_STL10)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Gf9BYJIxgb7L"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "V-tVNhcbSX4H"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "authorship_tag": "ABX9TyNIyJ61B3o2dqvOs+hbRNQw",
   "machine_shape": "hm",
   "provenance": []
  },
  "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
}
