{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ca391d00",
   "metadata": {},
   "source": [
    "## Preliminaries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "67ac3232",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import os, sys\n",
    "from pathlib import Path\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7846136b",
   "metadata": {},
   "outputs": [],
   "source": [
    "attacks = ['ifgsm', 'pgd-ifgsm', 'korhonen-et-al', 'madc','ssah', 'cadv', 'random-noise', 'ftda', 'ftda-randn-init', 'madc-randn-init', 'ssah-randn-init', 'madc-linf', 'madc-norm','ftda-linf','mad-mix']\n",
    "jpegai_codecs = ['jpegai-v61-hop', 'jpegai-v61-bop', 'jpegai-v51-hop', 'jpegai-v51-bop', 'jpegai-v41-hop', 'jpegai-v41-bop', 'jpegai-v71-hop', 'jpegai-v71-bop']\n",
    "base_codecs = ['bmshj2018-hyperprior-vbr',\n",
    " 'jpegai-v51-bop',\n",
    " 'jpegai-v71-hop',\n",
    " 'jpegai-v51-hop',\n",
    " 'jpegai-v41-bop',\n",
    " 'jpegai-v71-bop',\n",
    " 'jpegai-v41-hop',\n",
    " 'mbt2018',\n",
    " 'jpegai-v61-hop',\n",
    " 'bmshj2018-hyperprior',\n",
    " 'cheng2020-attn',\n",
    " 'jpegai-v61-bop',\n",
    " 'evc',\n",
    " 'cheng2020-anchor',\n",
    " 'bmshj2018-factorized',\n",
    " 'mbt2018-mean',\n",
    " 'qres-vae',\n",
    " 'cdc-xparam',\n",
    " 'elic',\n",
    " 'lic-tcm',\n",
    " 'hific']\n",
    "\n",
    "codec_variants = {'bmshj2018-hyperprior-vbr': ['1', '2', '4', '6'],\n",
    " 'jpegai-v51-bop': ['b0002', 'b0012', 'b0075', 'b05'],\n",
    " 'jpegai-v71-hop': ['b0002', 'b0012', 'b0075', 'b05'],\n",
    " 'jpegai-v51-hop': ['b0002', 'b0012', 'b0075', 'b05'],\n",
    " 'jpegai-v41-bop': ['b0002', 'b0007', 'b0015', 'b005'],\n",
    " 'jpegai-v71-bop': ['b0002', 'b0012', 'b0075', 'b05'],\n",
    " 'jpegai-v41-hop': ['b0002', 'b0007', 'b0015', 'b005'],\n",
    " 'mbt2018': ['1', '2', '4', '6'],\n",
    " 'jpegai-v61-hop': ['b0002', 'b0012', 'b0075', 'b05'],\n",
    " 'bmshj2018-hyperprior': ['1', '2', '4', '6'],\n",
    " 'cheng2020-attn': ['1', '2', '4', '6'],\n",
    " 'jpegai-v61-bop': ['b0002', 'b0012', 'b0075', 'b05'],\n",
    " 'evc': ['1', '2', '4', '6'],\n",
    " 'cheng2020-anchor': ['1', '2', '4', '6'],\n",
    " 'bmshj2018-factorized': ['1', '2', '4', '6'],\n",
    " 'mbt2018-mean': ['1', '2', '4', '6'],\n",
    " 'qres-vae': ['16', '256', '2048'],\n",
    " 'cdc-xparam': ['b00032', 'b01024', 'b02048'],\n",
    " 'elic': ['0004', '0016', '0450'],\n",
    " 'lic-tcm': ['005', '0013', '00025'],\n",
    " 'hific': ['014', '030', '045']}\n",
    "\n",
    "better_loss_names = {\n",
    "    'added_noises_loss':'Added Noises (YCbCr)',\n",
    "    'added_noises_loss_Y':'Added Noises (Y)',\n",
    "    'ftda_default_loss':'FTDA Loss (YCbCr)',\n",
    "    'ftda_default_loss_Y':'FTDA Loss (Y)',\n",
    "    'bpp_increase_loss':'Increase BPP (YCbCr)',\n",
    "    'reconstr_loss':'Reconstruction Loss (YCbCr, $L_2$)',\n",
    "    'reconstr_loss_Y':'Reconstruction Loss (Y, $L_2$)',\n",
    "    'reconstruction_msssim_loss':'Reconstruction Loss (YCbCr, MS-SSIM)',\n",
    "    'ftda_msssim_loss':'FTDA Loss (YCbCr, MS-SSIM)',\n",
    "    'src_reconstr_loss_Y':'Source Reconstruction (Y, $L_2$)'\n",
    "}\n",
    "defense_2_name = {\n",
    "    'diffpure':'DiffPure',\n",
    "    'no_defence':'W/o defense',\n",
    "    'reversible_ensemble':'Rand. Ensemble',\n",
    "    'reversible_flip':'Flip',\n",
    "    'reversible_random_color_order':'Color Reorder',\n",
    "    'reversible_random_rotate':'Rotate',\n",
    "    'reversible_random_roll':'Roll',\n",
    "    'self_ensemble':'Self-Ensemble'\n",
    "}\n",
    "\n",
    "codec_2_name = {\n",
    "    'mbt2018':'MBT-2018',\n",
    "    'bmshj2018-factorized':'Balle et al.\\n(factorized)',\n",
    "    'bmshj2018-hyperprior':'Balle et al.\\n(hyperprior)',\n",
    "    'cheng2020-attn':'Cheng et al.\\n(attn)',\n",
    "    'cheng2020-anchor':'Cheng et al.\\n(anchor)',\n",
    "    'hific':'HiFiC',\n",
    "    'lic-tcm':'LIC-TCM',\n",
    "    'qres-vae':'QRes-VAE',\n",
    "    'elic':'ELIC',\n",
    "    'evc':'EVC',\n",
    "    'cdc-xparam':'CDC',\n",
    "    'mbt2018-mean':'MBT-2018\\n(mean)',\n",
    "    'jpegai-v71-hop':'JPEG-AI v7.1, HOP',\n",
    "    'jpegai-v71-bop':'JPEG-AI v7.1, BOP',\n",
    "    'jpegai-v61-hop':'JPEG-AI v6.1, HOP',\n",
    "    'jpegai-v61-bop':'JPEG-AI v6.1, BOP',\n",
    "    'jpegai-v51-hop':'JPEG-AI v5.1, HOP',\n",
    "    'jpegai-v51-bop':'JPEG-AI v5.1, BOP',\n",
    "    'jpegai-v41-hop':'JPEG-AI v4.1, HOP',\n",
    "    'jpegai-v41-bop':'JPEG-AI v4.1, BOP',\n",
    "\n",
    "    'jpegai-v71-hop-tools-on':'JPEG-AI v7.1, HOP',\n",
    "    'jpegai-v71-bop-tools-on':'JPEG-AI v7.1, BOP',\n",
    "    'jpegai-v61-hop-tools-on':'JPEG-AI v6.1, HOP',\n",
    "    'jpegai-v61-bop-tools-on':'JPEG-AI v6.1, BOP',\n",
    "    'jpegai-v51-hop-tools-on':'JPEG-AI v5.1, HOP',\n",
    "    'jpegai-v51-bop-tools-on':'JPEG-AI v5.1, BOP',\n",
    "    'jpegai-v41-hop-tools-on':'JPEG-AI v4.1, HOP',\n",
    "    'jpegai-v41-bop-tools-on':'JPEG-AI v4.1, BOP',\n",
    "}\n",
    "\n",
    "codec_order = ['mbt2018', 'mbt2018-mean', 'bmshj2018-factorized', 'bmshj2018-hyperprior', 'cheng2020-attn', 'cheng2020-anchor', 'hific',  'qres-vae', 'lic-tcm', 'elic', 'cdc-xparam'] + \\\n",
    "    ['jpegai-v71-bop', 'jpegai-v71-hop', 'jpegai-v61-bop','jpegai-v61-hop','jpegai-v51-bop','jpegai-v51-hop','jpegai-v41-bop', 'jpegai-v41-hop']\n",
    "defense_order = ['diffpure', 'no_defence', 'reversible_ensemble', 'reversible_flip',\n",
    "       'reversible_random_color_order', 'reversible_random_roll',\n",
    "       'reversible_random_rotate', 'self_ensemble']\n",
    "\n",
    "atk_2_name = {\n",
    "    'ifgsm':'I-FGSM',\n",
    "    'ftda':'FTDA',\n",
    "    'ftda-linf':'FTDA-$L_{{\\\\infty}}$',\n",
    "    'madc':'MADC',\n",
    "    'madc-norm':'MADC-norm',\n",
    "    'madc-linf':'MADC-$L_{{\\\\infty}}$',\n",
    "    'pgd-ifgsm':'PGD',\n",
    "    'ssah':'SSAH',\n",
    "    'ssah-randn-init':'SSAH (Rand. init)',\n",
    "    'mad-mix':'MAD-MIX'\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0e47518f",
   "metadata": {},
   "source": [
    "## Load results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ccef2f39",
   "metadata": {},
   "outputs": [],
   "source": [
    "# merge all *_test.csv files\n",
    "def merge_full_files(root_path, main_for_jpeg_ai = True):\n",
    "    res_df = pd.DataFrame()\n",
    "    for atk in Path(root_path).iterdir():\n",
    "        if '.DS_Store' in str(atk):\n",
    "            continue\n",
    "        cur_atk_path = Path(root_path) / atk.stem\n",
    "\n",
    "        for codec in Path(cur_atk_path).iterdir():\n",
    "            if '.DS_Store' in str(codec):\n",
    "                continue\n",
    "            c = codec.stem\n",
    "            cur_path = Path(f'{str(root_path)}/{atk.stem}/{c}')\n",
    "            if ('jpeg' in c) and main_for_jpeg_ai:\n",
    "                cv = 'mainc_test.csv'\n",
    "            else:    \n",
    "                cv = c + '_test.csv'\n",
    "            \n",
    "            log_path = cur_path / cv\n",
    "            if log_path.exists():\n",
    "                cur_df = pd.read_csv(log_path, index_col=0)\n",
    "                c_name = '-'.join(c.split('-')[:-1])\n",
    "                cur_df['codec_name'] = c_name\n",
    "                cur_df['codec_variant'] = c.split('-')[-1]\n",
    "                cur_df['codec_variant_num'] = codec_variants[c_name].index(c.split('-')[-1])\n",
    "                res_df = pd.concat([res_df, cur_df], ignore_index=True)\n",
    "    return res_df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "07c62219",
   "metadata": {},
   "outputs": [],
   "source": [
    "merged_res = merge_full_files('./csvs') # path to csvs\n",
    "# calculate deltas\n",
    "merged_res['delta_psnr_new'] =  merged_res['psnr_clear_attacked'] - merged_res['psnr_defended-rec-clear_defended-rec-attacked']\n",
    "merged_res['delta_vmaf_new'] =  merged_res['vmaf_clear_attacked'] - merged_res['vmaf_defended-rec-clear_defended-rec-attacked']\n",
    "\n",
    "for fr in ['msssim', 'ssim', 'mse', 'psnr', 'l_inf', 'mae', 'vmaf']:\n",
    "    merged_res[f'delta_{fr}_new'] =  merged_res[f'{fr}_clear_attacked'] - merged_res[f'{fr}_defended-rec-clear_defended-rec-attacked']\n",
    "    merged_res[f'delta_{fr}_old'] =  merged_res[f'{fr}_clear_defended-rec-clear'] - merged_res[f'{fr}_attacked_defended-rec-attacked']\n",
    "    merged_res[f'change_{fr}'] =  (merged_res[f'{fr}_clear_defended-rec-clear'] - merged_res[f'{fr}_attacked_defended-rec-attacked']) / merged_res[f'{fr}_clear_defended-rec-clear'] \n",
    "is_randn_map = {}\n",
    "attack_base_name = {x:x for x in merged_res.attack.unique()}\n",
    "for at in attacks:\n",
    "    if at == 'pgd-ifgsm' or 'randn' in at:\n",
    "        is_randn_map[at] = True\n",
    "    else:\n",
    "        is_randn_map[at] = False\n",
    "\n",
    "merged_res['is_randn'] = merged_res['attack'].map(is_randn_map)\n",
    "merged_res['attack_base_name'] = merged_res['attack'].map(attack_base_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0a827bdf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['cheng2020-attn', 'jpegai-v71-bop'], dtype=object)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "merged_res.codec_name.unique()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "099b639e",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "99bc4b5a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'NIC Model')"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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WLFi1vURERE2+w0dOlR///23lixZooCAAHl4eCgyMlJffPHFA9s2m83q06eP3N3dtWbNGpUpU0Zubm46ceKE1q9fb93vUeeRMWNG+fj46LPPPku0n8KFCz/yPAEAAIBHYTIHJ+fr6ys/Pz/9/fff8vf3t34988wzmj17tnXoWocOHTRhwgRJUvbs2dW2bVt16tRJN27c0K1btyTdDSEPExAQIC8vL23dutVm/ffff2+z/Ouvv6pJkyaqVq2aNYD9+OOPku4GIknWe6kSXLt2TadOnVL79u3l7+8vNze3RI971HlUrVpVd+7ckcVisXk8jh8/ruDgYOtwvEedKwAAAPAwXFFKA95880316dNHQ4YMUatWrRQfH6/Fixfr4MGD1okRqlSposWLFytHjhwKCAjQxYsX9cknn6hq1arKli2bJClTpkzav3+/9u7dq8qVK8tkMtn0kyFDBvXv318fffSRvL29Vb16dW3fvv2+oFS+fHlt2LBBZcuWVZ48ebR//34tWLBAJpNJkZGRkmSdfGHXrl0qXry4KlSooPz582v58uXKkyePMmXKpB07dlivDCUc96jzqFevnqpUqaL+/furf//+Kl68uA4dOqRZs2apTp06Nud64MAB7dq1S35+fsqcOXMKPTsAAAB4GpksD7up5CmQMMmAv79/otujoqJ06tQpFS1aVF5eXqlZWqJGjBihPXv26LvvvrNZv2vXLs2ZM0dHjhyRu7u7ypYtq9dee816b1BcXJzmzZunsLAwXbhwQRkzZlRgYKCGDBliHVL3ySefaO7cuYqNjdXmzZuVL1++RGtYunSpPv30U128eFEBAQFq1qyZ3n33XX377bcqUKCAzp49q/fee0/79u2TJBUpUkRdu3ZVWFiYIiIitGbNGknS5MmTtWrVKrm7u2vnzp06efKk3n//fR05ckQeHh4qUaKE+vXrp4kTJ6pkyZKaOXNmks7jzp07mjlzprZu3aorV64od+7cat68uQYMGGC9Z+uXX37RyJEjdenSJU2aNEktW7a0/5P1CM72swUAAJDePSob3IugxB+zSCH8bAEAADiX5AQlbuQAAAB2ExwcrMaNGys4ONjRpQDAEyEoAQAAu4iKilJoaKjMZrNCQ0MVFRXl6JIA4LERlAAAgF3ExcVZZzE1m802HwwOAGkNQQkAAAAADAhKAAAAgINxf5/zISgBAAAADsT9fc6JoAQAAAA4EPf3OSeCEgAAAAAYEJQAAAAAwICg9BBmsyVN9R0YGKjZs2fft37ChAkqU6aMvvzyS+u6TZs2qXPnzqpUqZICAgL0/PPP65NPPlFMTMx9bZYqVcr6Va5cOdWvX19jx47V1atXE63j1q1bqlChgmrWrKnY2Nj7tnfp0kUjRoy4b/3ixYtVqlQpzZ07N7mnDgAAANiVm6MLcGYuLiYFr9ips+HXU7Xf/Lkya0DHWnZpa8KECVqxYoWmTp2qFi1aSJLeeecdbdiwQf369dO7774rNzc37d27V7NmzdLWrVu1ePFiZciQwdpGjx491KNHD0l3bzY8fvy4pk6dqs6dO2vVqlXKmDGjTZ+bNm1S9uzZdenSJX399dcKCgp6ZJ2ffPKJPvjgAw0bNky9evWyy7kDAAAAj4ug9Ahnw6/rn7PXHF3GY3n//fe1cuVKffjhh3ruueckSV9++aXWrl2rzz77TJUrV7buW6RIEdWuXVvPP/+8PvjgA40fP966zcfHRzlz5rQuFyxYUGXKlFHz5s21cOFCDR482KbftWvXqk6dOjp37pxWrlz5yKC0ZMkSffDBBxo1apS6du1qj1MHAAAAnghD755SEydO1MqVKzVr1ixrSJKkzz77THXr1rUJSQny5s2rV155RV9++aVu3rz50Pbz5cunxo0ba9OmTTbrT548qYMHD6pWrVpq0qSJdu/erVOnTj2wnU8//VQffPCBxo4dS0gCAACA0yAoPYUmT56sTz/9VL169VJgYKB1fVRUlP744w9VqlTpgcfWqFFDMTExOnz48CP7KVmypM6cOaPbt29b161Zs0Y+Pj6qW7euGjduLHd3d61cuTLR4z/77DNNnDhRLVu2VMeOHZNxhgAAAEDKIig9Zb744gutWLFCFStW1LJly3T27FnrtuvXr8tisShLliwPPD5r1qyS9MCJGu6VKVMmSXcnb5DufgZAWFiYAgMD5eXlpSxZsqh27doKDQ1VdHS0zbE//fSTJk+erOrVq2vz5s06dOhQck8VAAAASDEEpafMrVu3tGDBAs2bN09eXl4aMmSI9UPLsmTJIpPJZA02iblx44YkKVu2bI/sK2F4nq+vryRp+/btunz5spo3b27dp3nz5oqIiNCWLVtsjr127ZqmTJmikJAQFS9eXEOGDHloXQAAAEBqIig9Zbp27apq1aopS5YsmjRpkn777TfrlOGenp7y9/fX3r17H3j87t275eHhoXLlyj2yr99//11FihSxzpC3bt06SdLAgQPl5+cnPz8/DR8+XJLuG37XrFkztWjRQh4eHpo6daouXLigsWPHPtY5AwAAAPZGUHrKuLn9byLD2rVrq3PnzlqwYIF27dol6e5U399//712795937Hh4eFasmSJnn/+eeuwuge5cOGCvv32W7Vs2VKSdOXKFW3fvl1t27ZVaGiozVe7du104MABHT9+PNE6S5YsqTfffFMbN260hi0AAADAkZge/BHy58qcpvscOnSofv75Zw0bNkxhYWFq1qyZDh48qL59+6p///5q2LChPDw89Ouvv2rWrFnKly/ffR8Ge+fOHV26dEnS3Qkhjh07po8++kgFChRQ9+7dJUlhYWGKi4tT7969VaxYMZvj+/Xrpy+//FIrV67UmDFjEq2zW7du+v777/Xee+8pICBARYsWtdtjAAAAACQXQekhzGaL3T749XH6dnExPXE7Xl5emjJlijp06KARI0Zo/vz5GjFihKpWraqlS5dq0aJFiomJUZEiRdS5c2d17txZHh4eNm0sXrxYixcvliS5u7srb968CgoKUo8ePWyG3dWsWfO+kCRJhQoVUqNGjRQWFqahQ4cmWqfJZNIHH3ygVq1aafDgwfriiy/uqwMAAABILSaLxWJxdBEpKWGaa39//0S3R0VF6dSpUypatKi8vLxSszQ85fjZApDe3Lp1S61bt7Yur1+/3jrhD4AH4/9O6nlUNrgX9ygBAAAAgAFBCQAAAAAMCEoAAAAAYEBQAgAAAAADghIAAAAAGBCUAAAAAMCAoAQAAAAABgQlAAAAADAgKAEAAACAAUHpISxmc7rsGwAAAEjv3BxdgDMzubjo1MYQRV45n6r9emfPq6Itej/28XFxcVq+fLnWr1+vU6dOydPTU35+furTp4+qV68uSRoxYoTOnj2rpUuXavbs2ZozZ85D25w4caJGjRqlgQMHauDAgfdtf/PNN/Xzzz9rw4YNypkzpy5evKhZs2bpxx9/1LVr15QlSxbVrFlTAwcOVKFChWyOPXPmjBYuXKgdO3bo0qVLypkzpxo0aKB+/fopZ86c9/X1xRdf6J133tErr7yit99+22bbf//9p4YNG9qsc3V1VebMmVWtWjW99dZbypcv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BUEJAAAAAAwISgAAAABgQFACAAAAAAOCEgAAAAAYJHvWu0eJj4/X2rVrdeTIEWXKlElDhw61dxcAAAAAkKLsfkXpnXfe0caNG+Xn56cVK1ZIkn766SctWbLE3l0BAAAAQIqwe1D69ttv9fHHH6tDhw5ycbnbfNmyZfX555/buysAAAAASBF2D0pZsmTRnTt3bNZlzZpVly9ftndXAAAAAJAi7B6UOnTooKFDh+rKlSsymUySpL///luZMmWyd1cAAAAAkCLsOpmD2WxWsWLFFBERocaNGysmJkbvvPOOduzYoc6dO9uzKwAAAABIMXYNSi4uLho8eLD279+vTp06adeuXbp+/bpatWqlKlWq2LMrAAAAAEgxdp8evE6dOvr1119VqVIltW7d2t7NAwAAAECKs/s9SvHx8Ro0aJBWrFihS5cu2bt5AAAAAEhxdr+iVLVqVWXOnFlr167VlClTlCFDBpUuXVqlSpXSsGHD7N0dAAAAANid3YNS165drd9bLBadPn1ax44d0/Hjx+3dFQAAAACkCLsHJUnaunWrfv/9d2XPnl3PPvusnnvuOT333HMp0RUAAAAA2J3d71H64IMPNHfuXFksFp08eVKDBw/WgAEDFBUVZe+uAAAAACBF2P2KUmhoqLZt26aMGTNKkmJjYzV27Fh98MEHGjt2rL27AwAAAAC7s/sVJTc3N5lMJuuyu7u7RowYoS1btti7KwAAAABIEXYPSu3atdPbb7+t27dvW9dFRkbKxcXuXQEAAABAirD70LvXXntNkyZNUmBgoMqXL69MmTJp79696ty5s727AgAAAIAUYfeg5OrqqtGjR6t3797au3evIiIi1LlzZwUEBNi7KwAAAABIEXYPShcvXlSWLFmUO3dutWjRwt7NAwAAAECKs/uNQ3369NHhw4dt1l2+fFkRERH27goAAAAAUoTdg9K///6rSpUq2awLDw9Xnz597N0VAAAAAKQIuwelHDly6N9//7VZV6ZMGZ08edLeXQEAAABAirB7UOrVq5feeustnTlzxrru33//lbe3t727AgAAAIAUYffJHF566SVdunRJbdq00bPPPqtMmTJp9+7devnll+3dFQAAAACkCLsHJUkaOHCgOnTooJ07d+r69et66aWXVK1atZToCgAAAADszu5D795//30dPXpUOXLkUIsWLVSiRAkVLlzY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",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "measure = 'delta_vmaf_new'\n",
    "plot_data = merged_res.copy()\n",
    "plot_data['codec_name'] = plot_data['codec_name'].apply(lambda x: codec_2_name[x])\n",
    "sns.set(style='whitegrid')\n",
    "fig, ax = plt.subplots(1,1, figsize=(10, 8))\n",
    "sns.barplot(data=plot_data, x='codec_name', hue='test_dataset', y=measure)\n",
    "\n",
    "ax.legend(title='Test dataset')\n",
    "ax.set_ylabel('$\\\\leftarrow$ $\\Delta_{{score}}$ VMAF')\n",
    "ax.set_xlabel('NIC Model')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sd_1",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
