{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "import json\n",
    "\n",
    "def display_results(output_dir, title):\n",
    "    frames = []\n",
    "    for run_dir in sorted(Path(output_dir).iterdir()):\n",
    "        with open(run_dir / \"results.json\", \"r\") as f:\n",
    "            results = json.load(f)\n",
    "        model = results[\"config\"][\"model\"]\n",
    "        if model == 'naive_ensemble':\n",
    "            pass\n",
    "        frames.append(pd.DataFrame(results[\"metrics\"]['All'], index=[model]))\n",
    "    df = pd.concat(frames).T\n",
    "\n",
    "    print(f\"Detection Performance (AP) on the {title}\")\n",
    "    display(df.iloc[:, :].reindex(sorted(df.columns), axis=1).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Detection Performance (AP) on the ELSA Test Dataset\n"
     ]
    },
    {
     "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>f1</th>\n",
       "      <th>acc</th>\n",
       "      <th>auc</th>\n",
       "      <th>ap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>cavia2024</th>\n",
       "      <td>0.380281</td>\n",
       "      <td>0.385211</td>\n",
       "      <td>0.560870</td>\n",
       "      <td>0.848699</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>chen2024</th>\n",
       "      <td>0.866842</td>\n",
       "      <td>0.805541</td>\n",
       "      <td>0.901635</td>\n",
       "      <td>0.975325</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>corvi2023</th>\n",
       "      <td>0.888889</td>\n",
       "      <td>0.800000</td>\n",
       "      <td>0.865214</td>\n",
       "      <td>0.967304</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>koutlis2024</th>\n",
       "      <td>0.739208</td>\n",
       "      <td>0.660237</td>\n",
       "      <td>0.839469</td>\n",
       "      <td>0.954421</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ojha2023</th>\n",
       "      <td>0.377379</td>\n",
       "      <td>0.379921</td>\n",
       "      <td>0.717528</td>\n",
       "      <td>0.908433</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>tan2023</th>\n",
       "      <td>0.355916</td>\n",
       "      <td>0.370673</td>\n",
       "      <td>0.573831</td>\n",
       "      <td>0.847477</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>wang2020</th>\n",
       "      <td>0.013638</td>\n",
       "      <td>0.204582</td>\n",
       "      <td>0.441674</td>\n",
       "      <td>0.780228</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   f1       acc       auc        ap\n",
       "cavia2024    0.380281  0.385211  0.560870  0.848699\n",
       "chen2024     0.866842  0.805541  0.901635  0.975325\n",
       "corvi2023    0.888889  0.800000  0.865214  0.967304\n",
       "koutlis2024  0.739208  0.660237  0.839469  0.954421\n",
       "ojha2023     0.377379  0.379921  0.717528  0.908433\n",
       "tan2023      0.355916  0.370673  0.573831  0.847477\n",
       "wang2020     0.013638  0.204582  0.441674  0.780228"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Detection Performance (AP) on the Adversarial ELSA Test Dataset - Attack on Chen2024\n"
     ]
    },
    {
     "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>f1</th>\n",
       "      <th>acc</th>\n",
       "      <th>auc</th>\n",
       "      <th>ap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>cavia2024</th>\n",
       "      <td>0.525411</td>\n",
       "      <td>0.404416</td>\n",
       "      <td>0.337416</td>\n",
       "      <td>0.715941</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>chen2024</th>\n",
       "      <td>0.000586</td>\n",
       "      <td>0.004999</td>\n",
       "      <td>0.000224</td>\n",
       "      <td>0.598613</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>corvi2023</th>\n",
       "      <td>0.888889</td>\n",
       "      <td>0.800000</td>\n",
       "      <td>0.846732</td>\n",
       "      <td>0.961795</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>koutlis2024</th>\n",
       "      <td>0.863116</td>\n",
       "      <td>0.770881</td>\n",
       "      <td>0.657831</td>\n",
       "      <td>0.881252</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ojha2023</th>\n",
       "      <td>0.388118</td>\n",
       "      <td>0.381337</td>\n",
       "      <td>0.680306</td>\n",
       "      <td>0.890904</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>tan2023</th>\n",
       "      <td>0.376872</td>\n",
       "      <td>0.309977</td>\n",
       "      <td>0.369339</td>\n",
       "      <td>0.740828</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>wang2020</th>\n",
       "      <td>0.013173</td>\n",
       "      <td>0.188627</td>\n",
       "      <td>0.377795</td>\n",
       "      <td>0.734031</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   f1       acc       auc        ap\n",
       "cavia2024    0.525411  0.404416  0.337416  0.715941\n",
       "chen2024     0.000586  0.004999  0.000224  0.598613\n",
       "corvi2023    0.888889  0.800000  0.846732  0.961795\n",
       "koutlis2024  0.863116  0.770881  0.657831  0.881252\n",
       "ojha2023     0.388118  0.381337  0.680306  0.890904\n",
       "tan2023      0.376872  0.309977  0.369339  0.740828\n",
       "wang2020     0.013173  0.188627  0.377795  0.734031"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Detection Performance (AP) on the Adversarial ELSA Test Dataset - Attack on Chen2024/Koutlis2023\n"
     ]
    },
    {
     "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>f1</th>\n",
       "      <th>acc</th>\n",
       "      <th>auc</th>\n",
       "      <th>ap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>cavia2024</th>\n",
       "      <td>0.580312</td>\n",
       "      <td>0.451198</td>\n",
       "      <td>0.360444</td>\n",
       "      <td>0.723513</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>chen2024</th>\n",
       "      <td>0.046156</td>\n",
       "      <td>0.032368</td>\n",
       "      <td>0.007903</td>\n",
       "      <td>0.598746</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>corvi2023</th>\n",
       "      <td>0.888889</td>\n",
       "      <td>0.800000</td>\n",
       "      <td>0.835199</td>\n",
       "      <td>0.958471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>koutlis2024</th>\n",
       "      <td>0.024036</td>\n",
       "      <td>0.012164</td>\n",
       "      <td>0.008561</td>\n",
       "      <td>0.598516</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>naive_ensemble</th>\n",
       "      <td>0.025987</td>\n",
       "      <td>0.013206</td>\n",
       "      <td>0.000137</td>\n",
       "      <td>0.597763</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ojha2023</th>\n",
       "      <td>0.071610</td>\n",
       "      <td>0.190960</td>\n",
       "      <td>0.257210</td>\n",
       "      <td>0.677748</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>tan2023</th>\n",
       "      <td>0.367135</td>\n",
       "      <td>0.304020</td>\n",
       "      <td>0.369958</td>\n",
       "      <td>0.739615</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>wang2020</th>\n",
       "      <td>0.011168</td>\n",
       "      <td>0.188544</td>\n",
       "      <td>0.367741</td>\n",
       "      <td>0.732618</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      f1       acc       auc        ap\n",
       "cavia2024       0.580312  0.451198  0.360444  0.723513\n",
       "chen2024        0.046156  0.032368  0.007903  0.598746\n",
       "corvi2023       0.888889  0.800000  0.835199  0.958471\n",
       "koutlis2024     0.024036  0.012164  0.008561  0.598516\n",
       "naive_ensemble  0.025987  0.013206  0.000137  0.597763\n",
       "ojha2023        0.071610  0.190960  0.257210  0.677748\n",
       "tan2023         0.367135  0.304020  0.369958  0.739615\n",
       "wang2020        0.011168  0.188544  0.367741  0.732618"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#output_dir = \"output/evaluate_detector/CNN_synth_testset\"\n",
    "output_dir = \"output/evaluate_detector/ELSA_TEST\"\n",
    "output_dir_adv_chen = \"output/evaluate_detector/ELSA_TEST_ADV_8_chen\"\n",
    "output_dir_adv_ck = \"output/evaluate_detector/ELSA_TEST_ADV_8_chen_koutlis\"\n",
    "\n",
    "display_results(output_dir, \"ELSA Test Dataset\")\n",
    "display_results(output_dir_adv_chen, \"Adversarial ELSA Test Dataset - Attack on Chen2024\")\n",
    "display_results(output_dir_adv_ck, \"Adversarial ELSA Test Dataset - Attack on Chen2024/Koutlis2023\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Detection Performance (AP) on the ELSA Test Dataset evaluation for chen transformation change TF\n"
     ]
    },
    {
     "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>f1</th>\n",
       "      <th>acc</th>\n",
       "      <th>auc</th>\n",
       "      <th>ap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>chen2024</th>\n",
       "      <td>0.866842</td>\n",
       "      <td>0.805541</td>\n",
       "      <td>0.901635</td>\n",
       "      <td>0.975325</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                f1       acc       auc        ap\n",
       "chen2024  0.866842  0.805541  0.901635  0.975325"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Detection Performance (AP) on the ELSA Test Dataset evaluation for chen transformation change A\n"
     ]
    },
    {
     "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>f1</th>\n",
       "      <th>acc</th>\n",
       "      <th>auc</th>\n",
       "      <th>ap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>chen2024</th>\n",
       "      <td>0.866842</td>\n",
       "      <td>0.805541</td>\n",
       "      <td>0.901635</td>\n",
       "      <td>0.975325</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                f1       acc       auc        ap\n",
       "chen2024  0.866842  0.805541  0.901635  0.975325"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display_results(\"output/evaluate_detector/chen_tf\", \"ELSA Test Dataset evaluation for chen transformation change TF\")\n",
    "display_results(\"output/evaluate_detector/chen_a\", \"ELSA Test Dataset evaluation for chen transformation change A\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Detection Performance (AP) on the Adversarial ELSA Test Dataset - Attack on Cavia2024\n"
     ]
    },
    {
     "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>f1</th>\n",
       "      <th>acc</th>\n",
       "      <th>auc</th>\n",
       "      <th>ap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>cavia2024</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.5000</td>\n",
       "      <td>0.800000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>chen2024_convnext</th>\n",
       "      <td>0.776119</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.7750</td>\n",
       "      <td>0.905926</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>corvi2023</th>\n",
       "      <td>0.880000</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.8125</td>\n",
       "      <td>0.917857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>koutlis2024</th>\n",
       "      <td>0.868421</td>\n",
       "      <td>0.80</td>\n",
       "      <td>0.7625</td>\n",
       "      <td>0.896250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ojha2023</th>\n",
       "      <td>0.845070</td>\n",
       "      <td>0.78</td>\n",
       "      <td>0.8250</td>\n",
       "      <td>0.925806</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>wang2020</th>\n",
       "      <td>0.730159</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.7875</td>\n",
       "      <td>0.915000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                         f1   acc     auc        ap\n",
       "cavia2024          0.000000  0.20  0.5000  0.800000\n",
       "chen2024_convnext  0.776119  0.70  0.7750  0.905926\n",
       "corvi2023          0.880000  0.82  0.8125  0.917857\n",
       "koutlis2024        0.868421  0.80  0.7625  0.896250\n",
       "ojha2023           0.845070  0.78  0.8250  0.925806\n",
       "wang2020           0.730159  0.66  0.7875  0.915000"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "output_dir = \"output/evaluate_detector/ADV/val/adv_raw_['cavia2024']_32_255_10_0.05\"\n",
    "\n",
    "display_results(output_dir, \"Adversarial ELSA Test Dataset - Attack on Cavia2024\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "raid",
   "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.10.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
