{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset</th>\n",
       "      <th>fpr_msp</th>\n",
       "      <th>fpr_odin</th>\n",
       "      <th>fpr_ebo</th>\n",
       "      <th>fpr_mds</th>\n",
       "      <th>fpr_gmm1</th>\n",
       "      <th>fpr_gmm4</th>\n",
       "      <th>auroc_msp</th>\n",
       "      <th>auroc_odin</th>\n",
       "      <th>auroc_ebo</th>\n",
       "      <th>auroc_mds</th>\n",
       "      <th>auroc_gmm1</th>\n",
       "      <th>auroc_gmm4</th>\n",
       "      <th>aupr_msp</th>\n",
       "      <th>aupr_odin</th>\n",
       "      <th>aupr_ebo</th>\n",
       "      <th>aupr_mds</th>\n",
       "      <th>aupr_gmm1</th>\n",
       "      <th>aupr_gmm4</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>notmnist</td>\n",
       "      <td>43.09</td>\n",
       "      <td>37.70</td>\n",
       "      <td>44.06</td>\n",
       "      <td>1.77</td>\n",
       "      <td>2.64</td>\n",
       "      <td>0.78</td>\n",
       "      <td>88.77</td>\n",
       "      <td>89.85</td>\n",
       "      <td>88.44</td>\n",
       "      <td>99.67</td>\n",
       "      <td>99.50</td>\n",
       "      <td>99.79</td>\n",
       "      <td>75.72</td>\n",
       "      <td>77.83</td>\n",
       "      <td>75.97</td>\n",
       "      <td>99.36</td>\n",
       "      <td>99.09</td>\n",
       "      <td>99.57</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>fashionmnist</td>\n",
       "      <td>24.36</td>\n",
       "      <td>12.95</td>\n",
       "      <td>13.37</td>\n",
       "      <td>5.79</td>\n",
       "      <td>26.20</td>\n",
       "      <td>0.61</td>\n",
       "      <td>94.62</td>\n",
       "      <td>96.55</td>\n",
       "      <td>96.95</td>\n",
       "      <td>98.88</td>\n",
       "      <td>95.86</td>\n",
       "      <td>99.80</td>\n",
       "      <td>93.72</td>\n",
       "      <td>95.86</td>\n",
       "      <td>96.34</td>\n",
       "      <td>98.85</td>\n",
       "      <td>96.28</td>\n",
       "      <td>99.79</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>nearood</td>\n",
       "      <td>33.73</td>\n",
       "      <td>25.33</td>\n",
       "      <td>28.71</td>\n",
       "      <td>3.78</td>\n",
       "      <td>14.42</td>\n",
       "      <td>0.69</td>\n",
       "      <td>91.69</td>\n",
       "      <td>93.20</td>\n",
       "      <td>92.69</td>\n",
       "      <td>99.28</td>\n",
       "      <td>97.68</td>\n",
       "      <td>99.80</td>\n",
       "      <td>84.72</td>\n",
       "      <td>86.84</td>\n",
       "      <td>86.15</td>\n",
       "      <td>99.10</td>\n",
       "      <td>97.68</td>\n",
       "      <td>99.68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>texture</td>\n",
       "      <td>2.54</td>\n",
       "      <td>1.08</td>\n",
       "      <td>1.05</td>\n",
       "      <td>0.27</td>\n",
       "      <td>40.09</td>\n",
       "      <td>0.00</td>\n",
       "      <td>99.44</td>\n",
       "      <td>99.70</td>\n",
       "      <td>99.72</td>\n",
       "      <td>99.90</td>\n",
       "      <td>95.02</td>\n",
       "      <td>99.94</td>\n",
       "      <td>99.64</td>\n",
       "      <td>99.77</td>\n",
       "      <td>99.76</td>\n",
       "      <td>99.94</td>\n",
       "      <td>97.63</td>\n",
       "      <td>99.97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>7.05</td>\n",
       "      <td>3.06</td>\n",
       "      <td>3.18</td>\n",
       "      <td>0.18</td>\n",
       "      <td>54.43</td>\n",
       "      <td>0.00</td>\n",
       "      <td>98.68</td>\n",
       "      <td>99.31</td>\n",
       "      <td>99.30</td>\n",
       "      <td>99.88</td>\n",
       "      <td>94.19</td>\n",
       "      <td>99.97</td>\n",
       "      <td>98.72</td>\n",
       "      <td>99.27</td>\n",
       "      <td>99.12</td>\n",
       "      <td>99.88</td>\n",
       "      <td>95.86</td>\n",
       "      <td>99.97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>tin</td>\n",
       "      <td>6.28</td>\n",
       "      <td>2.93</td>\n",
       "      <td>3.13</td>\n",
       "      <td>0.55</td>\n",
       "      <td>59.52</td>\n",
       "      <td>0.00</td>\n",
       "      <td>98.78</td>\n",
       "      <td>99.36</td>\n",
       "      <td>99.37</td>\n",
       "      <td>99.79</td>\n",
       "      <td>93.70</td>\n",
       "      <td>99.96</td>\n",
       "      <td>98.78</td>\n",
       "      <td>99.33</td>\n",
       "      <td>99.25</td>\n",
       "      <td>99.79</td>\n",
       "      <td>95.54</td>\n",
       "      <td>99.96</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>places365</td>\n",
       "      <td>9.92</td>\n",
       "      <td>4.59</td>\n",
       "      <td>4.12</td>\n",
       "      <td>0.45</td>\n",
       "      <td>58.07</td>\n",
       "      <td>0.00</td>\n",
       "      <td>98.19</td>\n",
       "      <td>99.06</td>\n",
       "      <td>99.17</td>\n",
       "      <td>99.81</td>\n",
       "      <td>93.82</td>\n",
       "      <td>99.96</td>\n",
       "      <td>94.87</td>\n",
       "      <td>97.01</td>\n",
       "      <td>96.84</td>\n",
       "      <td>99.42</td>\n",
       "      <td>91.32</td>\n",
       "      <td>99.88</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>farood</td>\n",
       "      <td>6.45</td>\n",
       "      <td>2.92</td>\n",
       "      <td>2.87</td>\n",
       "      <td>0.36</td>\n",
       "      <td>53.03</td>\n",
       "      <td>0.00</td>\n",
       "      <td>98.77</td>\n",
       "      <td>99.36</td>\n",
       "      <td>99.39</td>\n",
       "      <td>99.84</td>\n",
       "      <td>94.18</td>\n",
       "      <td>99.96</td>\n",
       "      <td>98.00</td>\n",
       "      <td>98.84</td>\n",
       "      <td>98.74</td>\n",
       "      <td>99.76</td>\n",
       "      <td>95.09</td>\n",
       "      <td>99.94</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        dataset  fpr_msp  fpr_odin  fpr_ebo  fpr_mds  fpr_gmm1  fpr_gmm4  \\\n",
       "0      notmnist    43.09     37.70    44.06     1.77      2.64      0.78   \n",
       "1  fashionmnist    24.36     12.95    13.37     5.79     26.20      0.61   \n",
       "2       nearood    33.73     25.33    28.71     3.78     14.42      0.69   \n",
       "3       texture     2.54      1.08     1.05     0.27     40.09      0.00   \n",
       "4       cifar10     7.05      3.06     3.18     0.18     54.43      0.00   \n",
       "5           tin     6.28      2.93     3.13     0.55     59.52      0.00   \n",
       "6     places365     9.92      4.59     4.12     0.45     58.07      0.00   \n",
       "7        farood     6.45      2.92     2.87     0.36     53.03      0.00   \n",
       "\n",
       "   auroc_msp  auroc_odin  auroc_ebo  auroc_mds  auroc_gmm1  auroc_gmm4  \\\n",
       "0      88.77       89.85      88.44      99.67       99.50       99.79   \n",
       "1      94.62       96.55      96.95      98.88       95.86       99.80   \n",
       "2      91.69       93.20      92.69      99.28       97.68       99.80   \n",
       "3      99.44       99.70      99.72      99.90       95.02       99.94   \n",
       "4      98.68       99.31      99.30      99.88       94.19       99.97   \n",
       "5      98.78       99.36      99.37      99.79       93.70       99.96   \n",
       "6      98.19       99.06      99.17      99.81       93.82       99.96   \n",
       "7      98.77       99.36      99.39      99.84       94.18       99.96   \n",
       "\n",
       "   aupr_msp  aupr_odin  aupr_ebo  aupr_mds  aupr_gmm1  aupr_gmm4  \n",
       "0     75.72      77.83     75.97     99.36      99.09      99.57  \n",
       "1     93.72      95.86     96.34     98.85      96.28      99.79  \n",
       "2     84.72      86.84     86.15     99.10      97.68      99.68  \n",
       "3     99.64      99.77     99.76     99.94      97.63      99.97  \n",
       "4     98.72      99.27     99.12     99.88      95.86      99.97  \n",
       "5     98.78      99.33     99.25     99.79      95.54      99.96  \n",
       "6     94.87      97.01     96.84     99.42      91.32      99.88  \n",
       "7     98.00      98.84     98.74     99.76      95.09      99.94  "
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "# create an empty dataframe\n",
    "df = pd.DataFrame()\n",
    "\n",
    "benchmark = 'ood'\n",
    "method_list = ['msp', 'odin', 'ebo', 'mds', 'gmm1', 'gmm4']\n",
    "\n",
    "for method in method_list:\n",
    "    dirname = f'./mnist_0408_3/mnist_lenet_test_ood_{benchmark}_{method}_0408_3'\n",
    "    filename = os.path.join(dirname, 'ood.csv')\n",
    "    sub_df = pd.read_csv(filename)\n",
    "    sub_df['method'] = method\n",
    "    df = df.append(sub_df)\n",
    "\n",
    "data = []\n",
    "dataset_list = list(df['dataset'][:8])\n",
    "for dataset in dataset_list:\n",
    "    df_sub_dataset = df[df['dataset'] == dataset]\n",
    "    metric_list = [dataset]\n",
    "    metric_list.extend(list(df_sub_dataset['FPR@95']))\n",
    "    metric_list.extend(list(df_sub_dataset['AUROC']))\n",
    "    metric_list.extend(list(df_sub_dataset['AUPR_IN']))\n",
    "    data.append(metric_list)\n",
    "\n",
    "header = ['dataset'] + \\\n",
    "['fpr_'+method for method in method_list] + \\\n",
    "['auroc_'+method for method in method_list] + \\\n",
    "['aupr_'+method for method in method_list]\n",
    "df_report = pd.DataFrame(data, columns=header)\n",
    "\n",
    "df_report"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "notmnist\n",
      "& 43.09& 37.70& 44.06& 1.77& 2.64& \\textbf{0.78} \n",
      "& 88.77& 89.85& 88.44& 99.67& 99.50& \\textbf{99.79} \n",
      "& 75.72& 77.83& 75.97& 99.36& 99.09& \\textbf{99.57} \\\\\n",
      "fashionmnist\n",
      "& 24.36& 12.95& 13.37& 5.79& 26.20& \\textbf{0.61} \n",
      "& 94.62& 96.55& 96.95& 98.88& 95.86& \\textbf{99.80} \n",
      "& 93.72& 95.86& 96.34& 98.85& 96.28& \\textbf{99.79} \\\\\n",
      "nearood\n",
      "& 33.73& 25.33& 28.71& 3.78& 14.42& \\textbf{0.69} \n",
      "& 91.69& 93.20& 92.69& 99.28& 97.68& \\textbf{99.80} \n",
      "& 84.72& 86.84& 86.15& 99.10& 97.68& \\textbf{99.68} \\\\\n",
      "texture\n",
      "& 2.54& 1.08& 1.05& 0.27& 40.09& \\textbf{0.00} \n",
      "& 99.44& 99.70& 99.72& 99.90& 95.02& \\textbf{99.94} \n",
      "& 99.64& 99.77& 99.76& 99.94& 97.63& \\textbf{99.97} \\\\\n",
      "cifar10\n",
      "& 7.05& 3.06& 3.18& 0.18& 54.43& \\textbf{0.00} \n",
      "& 98.68& 99.31& 99.30& 99.88& 94.19& \\textbf{99.97} \n",
      "& 98.72& 99.27& 99.12& 99.88& 95.86& \\textbf{99.97} \\\\\n",
      "tin\n",
      "& 6.28& 2.93& 3.13& 0.55& 59.52& \\textbf{0.00} \n",
      "& 98.78& 99.36& 99.37& 99.79& 93.70& \\textbf{99.96} \n",
      "& 98.78& 99.33& 99.25& 99.79& 95.54& \\textbf{99.96} \\\\\n",
      "places365\n",
      "& 9.92& 4.59& 4.12& 0.45& 58.07& \\textbf{0.00} \n",
      "& 98.19& 99.06& 99.17& 99.81& 93.82& \\textbf{99.96} \n",
      "& 94.87& 97.01& 96.84& 99.42& 91.32& \\textbf{99.88} \\\\\n",
      "farood\n",
      "& 6.45& 2.92& 2.87& 0.36& 53.03& \\textbf{0.00} \n",
      "& 98.77& 99.36& 99.39& 99.84& 94.18& \\textbf{99.96} \n",
      "& 98.00& 98.84& 98.74& 99.76& 95.09& \\textbf{99.94} \\\\\n"
     ]
    }
   ],
   "source": [
    "for line_array in data:\n",
    "    values = ['{:.2f}'.format(line_array[i]) for i in range(1, len(line_array))]\n",
    "    print_line = line_array[0] + '\\n'\n",
    "    for i, element in enumerate(values):\n",
    "        if i % 6 == 5:\n",
    "            print_line = print_line + \"& \\\\textbf{\" + element + \"} \\n\"\n",
    "            if i == 17:\n",
    "                print_line = print_line[:-2] + \" \\\\\" + \"\\\\\"\n",
    "        else:\n",
    "            print_line = print_line + \"& \" + element\n",
    "    print(print_line)"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "f1e6686d8157a72333d6c7290e12a7b16aa121841fdb309d8a83e0abefbefaae"
  },
  "kernelspec": {
   "display_name": "Python 3.8.12 64-bit ('ood': conda)",
   "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.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
