{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "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_gmm0</th>\n",
       "      <th>fpr_gmm1</th>\n",
       "      <th>fpr_gmm2</th>\n",
       "      <th>auroc_gmm0</th>\n",
       "      <th>auroc_gmm1</th>\n",
       "      <th>auroc_gmm2</th>\n",
       "      <th>aupr_gmm0</th>\n",
       "      <th>aupr_gmm1</th>\n",
       "      <th>aupr_gmm2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>notmnist</td>\n",
       "      <td>10.30</td>\n",
       "      <td>10.52</td>\n",
       "      <td>11.67</td>\n",
       "      <td>96.48</td>\n",
       "      <td>96.20</td>\n",
       "      <td>96.51</td>\n",
       "      <td>98.38</td>\n",
       "      <td>98.17</td>\n",
       "      <td>98.44</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>fashionmnist</td>\n",
       "      <td>68.05</td>\n",
       "      <td>64.95</td>\n",
       "      <td>66.04</td>\n",
       "      <td>78.53</td>\n",
       "      <td>78.30</td>\n",
       "      <td>81.90</td>\n",
       "      <td>93.61</td>\n",
       "      <td>93.55</td>\n",
       "      <td>94.86</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>nearood</td>\n",
       "      <td>39.18</td>\n",
       "      <td>37.74</td>\n",
       "      <td>38.86</td>\n",
       "      <td>87.50</td>\n",
       "      <td>87.25</td>\n",
       "      <td>89.21</td>\n",
       "      <td>95.99</td>\n",
       "      <td>95.86</td>\n",
       "      <td>96.65</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>texture</td>\n",
       "      <td>90.14</td>\n",
       "      <td>91.63</td>\n",
       "      <td>91.38</td>\n",
       "      <td>71.50</td>\n",
       "      <td>65.91</td>\n",
       "      <td>73.02</td>\n",
       "      <td>95.56</td>\n",
       "      <td>94.57</td>\n",
       "      <td>95.89</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>90.19</td>\n",
       "      <td>90.75</td>\n",
       "      <td>91.39</td>\n",
       "      <td>67.35</td>\n",
       "      <td>60.54</td>\n",
       "      <td>68.33</td>\n",
       "      <td>91.11</td>\n",
       "      <td>89.26</td>\n",
       "      <td>91.76</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>tin</td>\n",
       "      <td>92.44</td>\n",
       "      <td>92.84</td>\n",
       "      <td>93.38</td>\n",
       "      <td>64.96</td>\n",
       "      <td>58.20</td>\n",
       "      <td>66.27</td>\n",
       "      <td>90.47</td>\n",
       "      <td>88.63</td>\n",
       "      <td>91.18</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>places365</td>\n",
       "      <td>92.81</td>\n",
       "      <td>93.15</td>\n",
       "      <td>94.24</td>\n",
       "      <td>65.39</td>\n",
       "      <td>58.57</td>\n",
       "      <td>66.43</td>\n",
       "      <td>75.06</td>\n",
       "      <td>71.60</td>\n",
       "      <td>76.87</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>farood</td>\n",
       "      <td>91.40</td>\n",
       "      <td>92.09</td>\n",
       "      <td>92.60</td>\n",
       "      <td>67.30</td>\n",
       "      <td>60.81</td>\n",
       "      <td>68.51</td>\n",
       "      <td>88.05</td>\n",
       "      <td>86.01</td>\n",
       "      <td>88.93</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        dataset  fpr_gmm0  fpr_gmm1  fpr_gmm2  auroc_gmm0  auroc_gmm1  \\\n",
       "0      notmnist     10.30     10.52     11.67       96.48       96.20   \n",
       "1  fashionmnist     68.05     64.95     66.04       78.53       78.30   \n",
       "2       nearood     39.18     37.74     38.86       87.50       87.25   \n",
       "3       texture     90.14     91.63     91.38       71.50       65.91   \n",
       "4       cifar10     90.19     90.75     91.39       67.35       60.54   \n",
       "5           tin     92.44     92.84     93.38       64.96       58.20   \n",
       "6     places365     92.81     93.15     94.24       65.39       58.57   \n",
       "7        farood     91.40     92.09     92.60       67.30       60.81   \n",
       "\n",
       "   auroc_gmm2  aupr_gmm0  aupr_gmm1  aupr_gmm2  \n",
       "0       96.51      98.38      98.17      98.44  \n",
       "1       81.90      93.61      93.55      94.86  \n",
       "2       89.21      95.99      95.86      96.65  \n",
       "3       73.02      95.56      94.57      95.89  \n",
       "4       68.33      91.11      89.26      91.76  \n",
       "5       66.27      90.47      88.63      91.18  \n",
       "6       66.43      75.06      71.60      76.87  \n",
       "7       68.51      88.05      86.01      88.93  "
      ]
     },
     "execution_count": 4,
     "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 = 'fsood'\n",
    "method_list = ['gmm0', 'gmm1', 'gmm2']\n",
    "\n",
    "for method in method_list:\n",
    "    dirname = f'./mnist_0408_3/mnist_lenet_test_ood_{benchmark}_{method}_0408_3_fl'\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",
    "\n",
    "df_report = pd.DataFrame(data, columns=header)\n",
    "\n",
    "df_report"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "notmnist\n",
      "& 23.66& 21.00& 32.42& 0.87& 6.16& \\textbf{0.33} \n",
      "& 94.82& 95.29& 93.21& 99.84& 98.56& \\textbf{99.89} \n",
      "& 90.52& 90.67& 86.82& 99.68& 97.28& \\textbf{99.77} \\\\\n",
      "fashionmnist\n",
      "& 16.44& 5.96& 8.66& 4.48& 49.54& \\textbf{0.59} \n",
      "& 97.30& 98.65& 98.48& 99.15& 89.15& \\textbf{99.68} \n",
      "& 97.62& 98.78& 98.50& 99.12& 89.19& \\textbf{99.68} \\\\\n",
      "nearood\n",
      "& 20.05& 13.48& 20.54& 2.68& 27.85& \\textbf{0.46} \n",
      "& 96.06& 96.97& 95.85& 99.49& 93.85& \\textbf{99.78} \n",
      "& 94.07& 94.72& 92.66& 99.40& 93.23& \\textbf{99.73} \\\\\n",
      "texture\n",
      "& 2.43& 0.94& 0.67& 0.23& 90.69& \\textbf{0.02} \n",
      "& 99.34& 99.75& 99.81& 99.93& 77.26& \\textbf{99.91} \n",
      "& 99.58& 99.84& 99.84& 99.96& 87.56& \\textbf{99.95} \\\\\n",
      "cifar10\n",
      "& 2.04& 0.72& 1.31& 0.15& 81.71& \\textbf{0.00} \n",
      "& 99.31& 99.72& 99.68& 99.90& 79.83& \\textbf{99.90} \n",
      "& 99.35& 99.73& 99.67& 99.90& 83.07& \\textbf{99.90} \\\\\n",
      "tin\n",
      "& 2.08& 0.70& 1.57& 0.48& 82.94& \\textbf{0.00} \n",
      "& 99.34& 99.73& 99.67& 99.83& 79.85& \\textbf{99.87} \n",
      "& 99.37& 99.73& 99.65& 99.83& 83.36& \\textbf{99.87} \\\\\n",
      "places365\n",
      "& 3.03& 1.24& 2.74& 0.47& 78.37& \\textbf{0.04} \n",
      "& 99.18& 99.63& 99.51& 99.84& 81.65& \\textbf{99.86} \n",
      "& 97.89& 98.92& 98.39& 99.50& 69.40& \\textbf{99.61} \\\\\n",
      "farood\n",
      "& 2.40& 0.90& 1.57& 0.33& 83.43& \\textbf{0.01} \n",
      "& 99.29& 99.71& 99.67& 99.88& 79.65& \\textbf{99.88} \n",
      "& 99.05& 99.55& 99.38& 99.80& 80.84& \\textbf{99.83} \\\\\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
}
