{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "ROC_FM_M.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "accelerator": "GPU"
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "id": "Y7OL1QBq-s4y",
        "outputId": "ba1f80da-9208-401b-f470-2b7beccfd1f5",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 67
        }
      },
      "source": [
        "!mkdir -p data && cd data && curl -O \"http://yaroslavvb.com/upload/notMNIST/notMNIST_small.mat\""
      ],
      "execution_count": 1,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\n",
            "                                 Dload  Upload   Total   Spent    Left  Speed\n",
            "100  112M  100  112M    0     0  35.6M      0  0:00:03  0:00:03 --:--:-- 35.6M\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "hM66GgdYaIu7",
        "outputId": "06b24ba9-437b-4f1e-940a-4989cbd27ab8",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 295
        }
      },
      "source": [
        "import random\n",
        "import numpy as np\n",
        "import torch\n",
        "import torch.utils.data\n",
        "from torch.nn import functional as F\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "from utils.evaluate_ood import get_ROC_mnist\n",
        "from utils.ensemble_eval import get_ROC_mnist_ensemble\n",
        "\n",
        "from utils.cnn_duq import CNN_DUQ\n",
        "from utils.cnn_duq import SoftmaxModel as CNN\n",
        "\n",
        "from utils.datasets import all_datasets\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "if __name__ == \"__main__\":\n",
        "    input_size = 28\n",
        "    num_classes = 10\n",
        "    embedding_size = 256\n",
        "    learnable_length_scale = False\n",
        "    gamma = 0.999\n",
        "    length_scale=0.1\n",
        "    model = CNN_DUQ(\n",
        "          input_size,\n",
        "          num_classes,\n",
        "          embedding_size,\n",
        "          learnable_length_scale,\n",
        "          length_scale,\n",
        "          gamma,\n",
        "      )\n",
        "    model.load_state_dict(torch.load(\"DUQ_FM_30_FULL.pt\"))\n",
        "    model = model.cuda()\n",
        "    ensemble = [CNN(input_size, num_classes).cuda() for _ in range(5)]\n",
        "    ensemble = torch.nn.ModuleList(ensemble)\n",
        "    ensemble.load_state_dict(torch.load(\"FM_5_ensemble_30.pt\"))\n",
        "\n",
        "\n",
        "    fpr,tpr,t=get_ROC_mnist(model);\n",
        "    fpre,tpre,t=get_ROC_mnist_ensemble(ensemble)\n",
        "    plt.figure()\n",
        "    plt.plot(fpr,tpr,label='DUQ')\n",
        "    plt.plot(fpre,tpre,label='DE(5)')\n",
        "    plt.xlabel('False Positive Rate')\n",
        "    plt.ylabel('True Positive Rate')\n",
        "    plt.title('ROC on FM & M-ood')\n",
        "    plt.legend(loc=\"lower right\")\n",
        "    plt.show()\n",
        "\n",
        "            \n",
        "\n",
        "   \n"
      ],
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "tags": [],
            "needs_background": "light"
          }
        }
      ]
    }
  ]
}