{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "5b20dee6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "from pathlib import Path\n",
    "import torch\n",
    "from matplotlib.ticker import PercentFormatter\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def load_pickle_inspect(file_name):\n",
    "    pkl_path = Path(file_name)\n",
    "    if not pkl_path.exists():\n",
    "        raise FileNotFoundError(f\"Pickle file not found: {pkl_path.resolve()}\")\n",
    "\n",
    "# Try torch.load first (works for many torch/pickle artifacts), fallback to pickle.load\n",
    "    try:\n",
    "        data = torch.load(pkl_path)\n",
    "    except Exception:\n",
    "        with pkl_path.open(\"rb\") as f:\n",
    "            data = pickle.load(f)\n",
    "\n",
    "\n",
    "    def to_cpu(obj):\n",
    "        if isinstance(obj, torch.Tensor):\n",
    "            return obj.cpu()\n",
    "        if isinstance(obj, dict):\n",
    "            return {k: to_cpu(v) for k, v in obj.items()}\n",
    "        if isinstance(obj, (list, tuple)):\n",
    "            seq = [to_cpu(x) for x in obj]\n",
    "            return type(obj)(seq)\n",
    "        return obj\n",
    "\n",
    "    data_cpu = to_cpu(data)\n",
    "    return data_cpu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "3702749b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/project/6101774/ddstn/envs/SVD_DP/lib/python3.11/site-packages/torch/_weights_only_unpickler.py:529: UserWarning: Detected pickle protocol 4 in the checkpoint, which was not the default pickle protocol used by `torch.load` (2). The weights_only Unpickler might not support all instructions implemented by this protocol, please file an issue for adding support if you encounter this.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "\n",
    "path_0 = Path(\"stats_sst2_roberta-base_peach-eon-679_epochs20_denoising_nototclip.pkl\")\n",
    "path_1 = Path(\"stats_sst2_roberta-base_sleek-durian-678_epochs20_denoising_nototclip.pkl\")\n",
    "path_101 = Path(\"stats_sst2_roberta-base_dazzling-resonance-680_epochs20_denoising_nototclip.pkl\")\n",
    "path_102 = Path(\"stats_sst2_roberta-base_sweet-firebrand-681_epochs20_denoising_nototclip.pkl\")\n",
    "path_105 = Path(\"stats_sst2_roberta-base_cerulean-frost-747_epochs20_denoising_nototclip.pkl\")\n",
    "path_110 = Path(\"stats_sst2_roberta-base_glad-oath-682_epochs20_denoising_nototclip.pkl\")\n",
    "\n",
    "kappa_0_data = load_pickle_inspect(path_0)\n",
    "kappa_1_data = load_pickle_inspect(path_1)\n",
    "kappa_101_data = load_pickle_inspect(path_101)\n",
    "kappa_102_data = load_pickle_inspect(path_102)\n",
    "kappa_105_data = load_pickle_inspect(path_105)\n",
    "kappa_110_data = load_pickle_inspect(path_110)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "ef6ef4d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_improvement_stats(data):\n",
    "    total_stats = {\n",
    "        'positive_improvements': 0,\n",
    "        'negative_improvements': 0,\n",
    "        'zero_improvements': 0,\n",
    "    }\n",
    "    for item in data:\n",
    "        if not item[\"denoised\"]:\n",
    "            total_stats['zero_improvements'] += 1\n",
    "        elif item['denoised_sim'] - item['original_sim'] > 0:\n",
    "            total_stats['positive_improvements'] += 1\n",
    "        else:\n",
    "            total_stats['negative_improvements'] += 1\n",
    "        \n",
    "    return total_stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "6c9281f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "kappa_swipe = {\n",
    "    '0.0': extract_improvement_stats(kappa_0_data),\n",
    "    '1.0': extract_improvement_stats(kappa_1_data),\n",
    "    '1.01': extract_improvement_stats(kappa_101_data),\n",
    "    '1.02': extract_improvement_stats(kappa_102_data),\n",
    "    '1.05': extract_improvement_stats(kappa_105_data),\n",
    "    '1.10': extract_improvement_stats(kappa_110_data),\n",
    "}\n",
    "\n",
    "kappa_swipe_ratio = {kappa: stat[\"positive_improvements\"] / (stat[\"positive_improvements\"] + stat[\"negative_improvements\"]) for kappa, stat in kappa_swipe.items()}\n",
    "kappa_swipe_positive = {stat[\"positive_improvements\"]: kappa for kappa, stat in kappa_swipe.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "17dda95d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9bplvclkYvLkyUyePPm2/dSrV8/iTXcAdnZ2zJ07l7lz59okVhEREREpmYr98gkRERERkYKmpFhERERESj0lxSIiIiJS6ikpFhEREZFST0mxiIiIiJR6SopFREREpNRTUiwiIiIipZ6SYhEREREp9axOinfv3s2vv/5q/vzFF1/QrVs3/vOf/5CZmWnT4ERERERECoPVSfHgwYM5dOgQAMeOHaN37964ubmxevVqxo4da/MARUREREQKmtVJ8aFDh2jQoAEAq1evpmXLlqxYsYLFixfz6aef2jo+EREREZECZ3VSbBgGOTk5AGzYsIFOnToBULlyZS5cuGDb6ERERERECoHVSXHjxo157bXXWLZsGVu2bOHhhx8GID4+Hj8/P5sHKCIiIiJS0KxOit9++212797NsGHDeOmll6hRowYA//vf/2jWrJnNAxQRERERKWgO1p4QGhpqsfvETdOnT8fBweruRERERESKnNUzxdWqVePixYu5ytPT0wkJCbFJUCIiIiIihcnqpPiPP/4gOzs7V3lGRganTp2ySVAiIiIiIoUp3+sdvvzyS/PP0dHReHl5mT9nZ2ezceNGgoODbRudiEgeOjToXdQhlEj7izoAEZFiLN9Jcbdu3QAwmUz069fPos7R0ZGgoCDeeustmwYnIiIiIlIY8p0U39ybODg4mJ9//pkKFSoUWFAiIiIiIoXJ6jXF8fHxhZYQZ2dn88orrxAcHIyrqyvVq1dnypQpGIZhbmMYBhMmTCAgIABXV1fat2/P4cOHzfUZGRk89dRTeHp6EhISwoYNGyyuMX36dIYPH14o4xERERGR4umO9lDbuHEjGzdu5Ny5c+YZ5Js+/PBDmwQG8MYbbzBv3jyWLFlC3bp12blzJ/3798fLy4sRI0YAMG3aNN59912WLFlCcHAwr7zyChEREfz222+4uLgwf/58du3aRWxsLN999x19+vQhMTERk8lEfHw8CxYsYOfOnTaLWURERERKHquT4ldffZXJkyfTuHFjAgICMJlMBREXAD/++CNdu3Y1vzUvKCiIjz/+mJ9++gm4MUs8c+ZMXn75Zbp27QrA0qVL8fPzY82aNfTu3Zu4uDi6dOlC3bp1qVatGi+++CIXLlzAx8eHoUOH8sYbb+Dp6VlgYxARERGR4s/qpPi9995j8eLFPPXUUwURj4VmzZoxf/58Dh06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hKenJydOnMhVfvLkScqUKWOToERERERECpPVSfHjjz/Os88+y8qVKzl58iQnT57kk08+YeDAgTbfkk1EREREpDBYvXzizTffxGQy8fTTT3P9+nUAHB0dGTp0KP/9739tHqCIiIiISEGzOil2cnLinXfeISoqiqNHjwJQvXp13NzcbB6ciIiIiEhhuKN9iuHGdmbe3t7mn0VERERESiqr1xRfv36dV155BS8vL4KCgggKCsLLy4uXX37Z/MpkEREREZGSxOqZ4uHDh/PZZ58xbdo0wsLCAIiNjWXSpElcvHiRefPm2TxIEREREZGCZHVSvGLFCj755BMeeughc1n9+vWpXLkyTzzxhJJiERERESlxrF4+4ezsTFBQUK7y4OBgnJycbBGTiIiIiEihsjopHjZsGFOmTCEjI8NclpGRwdSpUxk2bJhNgxMRERERKQxWL5/Ys2cPGzdupFKlSoSGhgKwb98+MjMzadeuHd27dze3/eyzz2wXqYiIiIhIAbE6Kfb29qZHjx4WZZUrV7ZZQCIiIiIihc3qpHjRokUFEYeIiIiISJGxek2xiIiIiMjdRkmxiIiIiJR6SopFREREpNRTUiwiIiIipV6+kuJy5cpx4cIFAAYMGMDly5cLNKib5s2bR/369fH09MTT05OwsDC+++47c316ejqRkZGUL18eDw8PevToQWJiork+KSmJzp074+HhQcOGDdmzZ49F/5GRkbz11luFMhYRERERKb7ylRRnZmaSmpoKwJIlS0hPTy/QoG6qVKkS//3vf9m1axc7d+6kbdu2dO3alQMHDgAwatQovvrqK1avXs2WLVs4c+aMxT7JU6dO5fLly+zevZvWrVvz3HPPmeu2b9/Ojh07GDlyZKGMRURERESKr3xtyRYWFka3bt1o1KgRhmEwYsQIXF1d82z74Ycf2iy4zp07W3yeOnUq8+bNY/v27VSqVImFCxeyYsUK2rZtC9zYLq527dps376dpk2bEhcXR+/evQkJCWHQoEHMnz8fgKysLIYMGcIHH3yAvb29zeIVERERkZIpXzPFH330EZ06deLKlSuYTCZSUlK4dOlSnkdByc7O5pNPPiEtLY2wsDB27dpFVlYW7du3N7epVasWVapUITY2FoDQ0FA2bdrE9evXiY6Opn79+gBMmzaN1q1b07hx4wKLV0RERERKjnzNFPv5+fHf//4XgODgYJYtW0b58uULNLCbfv31V8LCwkhPT8fDw4PPP/+cOnXqsHfvXpycnPD29s4Va0JCAgDjxo1j6NChVK9enaCgIBYuXMjhw4dZsmQJsbGxDBkyhHXr1tG4cWMWLFiAl5fXLePIyMggIyPDoszZ2RlnZ2ebj1lERERECpfVu0/Ex8cXWkIMULNmTfbu3cuOHTsYOnQo/fr147fffsvXuV5eXqxYsYLjx4+zZcsW6tSpw+DBg5k+fTrLly/n2LFjHDx4EDc3NyZPnnzbvqKiovDy8rI4oqKibDFEERERESlid7Ql25YtW+jcuTM1atSgRo0adOnShR9++MHWsQHg5OREjRo1aNSoEVFRUYSGhvLOO+/g7+9PZmYmycnJFu0TExPx9/fPs69Fixbh7e1N165diYmJoVu3bjg6OtKzZ09iYmJuG8f48eNJSUmxOMaPH2+jUYqIiIhIUbI6Kf7oo49o3749bm5ujBgxwvzQXbt27VixYkVBxGghJyeHjIwMGjVqhKOjIxs3bjTXHTx4kBMnThAWFpbrvPPnzzN58mRmzZoF3FijnJWVBdx48C47O/u213V2djZvDXfz0NIJERERkbtDvtYU/9nUqVOZNm0ao0aNMpeNGDGCGTNmMGXKFPr06WOz4MaPH89DDz1ElSpVuHz5MitWrCAmJobo6Gi8vLx49tlnGT16NOXKlcPT05Phw4cTFhZG06ZNc/U1cuRIxowZQ8WKFQEIDw9n2bJldOzYkfnz5xMeHm6zuEVERESkZLF6pvjYsWO5tkoD6NKlC/Hx8TYJ6qZz587x9NNPU7NmTdq1a8fPP/9MdHQ0HTp0AODtt9/mkUceoUePHrRs2RJ/f38+++yzXP1ER0dz5MgRnn/+eXPZsGHDqFatGk2aNCEzM5OJEyfaNHYRERERKTmsnimuXLkyGzdupEaNGhblGzZsoHLlyjYLDGDhwoW3rXdxcWHOnDnMmTPntu0iIiKIiIiwKHNzc2PVqlX/OEYRERERKfmsTorHjBnDiBEj2Lt3L82aNQNg27ZtLF68mHfeecfmAYqIiIiIFDSrk+KhQ4fi7+/PW2+9ZZ5prV27NitXrqRr1642D1BEREREpKBZnRQDPProozz66KO2jkVEREREpEjcUVIsRaNDg95FHUKJtL+oAxAREZFi745e3iEiIiIicjdRUiwiIiIipZ6SYhEREREp9f5RUmwYBoZh2CoWEREREZEicUdJ8dKlS7n33ntxdXXF1dWV+vXrs2zZMlvHJiIiIiJSKKzefWLGjBm88sorDBs2jPDwcAC2bt3KkCFDuHDhAqNGjbJ5kCIiIiIiBcnqpHjWrFnMmzePp59+2lzWpUsX6taty6RJk5QUi9yhnKwsjs5eyPWr16j90o0/R/ELl3Pt5BlM9v/3S50aLwzC0bNMnn1cO51AwrcbSE88h72bK75tmuPd8F4AjJwcTn/2DZcPHsHF14dKj3c193P1xCkS128haEAfTCZTAY9URESk+LE6KT579qz59c5/1qxZM86ePWuToERKo3Mbf8DR24vrV69ZlPt1bE35Zvf/7fnZ19I5vmwVvm1bENS4D9dOJ3B8yUocy3njXrUyqb8dIis5hZr/Hs659Vu48H0sAY90xMjO5uw366n0WBclxCIiUmpZvaa4Ro0a5tc7/9nKlSu55557bBKUSGlz7XQCVw7HU6FF0zvu4+rJ09g5OFDugYaY7OxwqxyIZ50QknftAyAzKRm3KpWwc3DAvUYwmUnJAFzYuoMyNWvg7FPeFkMREREpkayeKX711Vd5/PHH+f77781rirdt28bGjRvzTJZF5PaM7BzOfPEdAZ07QB67uZzf8iPnY7bh6OVJ+Wb3m5dD5O4o924whmGQkXgeABd/Hy5siSUnK4u0o3/g7OdDxsVLpO7/neDBT+fVo4iISKlhdVLco0cPduzYwdtvv82aNWsAqF27Nj/99BMNGza0dXwid70LW3fgEuCHe1AV0uKPW9T5dWiNs2957BwdSTt2nJMrv8DO2QnPOjVz9eNauSJGVhYXt++i3P0NuHbqLJfjDuHg7gZAmZDqXD1xmmPvL8XF14eAzh05uXIN/g+358rBI1zcvgs7R0f8H2yLs2+FQhm7iIhIcWF1UgzQqFEjPvroI1vHIlLqZFy8xKWf91Dt+f551rtVqWj+2eOeapS9vwEpv/6eZ1Ls4OZKlb6PkRC9mfObfsDZtwLeDe/l2qkz5jZ+7Vvi174lAMl79+Po7Ymzrw9H53xIjWHPkp6QyOk131JtkGaORUSkdMlXUpyamoqnp6f559u52U5E/t7V4ye5npbGkXfmAzeWUuRkZvB71DtUebInbpUDLdr/3YNwblUrUW3QU+bPJ1euwS2oSq52169e48IP2wke+CQZF5Jw9CqDvasLrpUrkp5wzgYjExERKVnylRSXLVuWs2fP4uvri7e3d57/MBuGgclkIjs72+ZBitytvOrVxqN6kPnz1ZNnOLPmO6o/3x+TvT2XDx3FPagKJgd70uJPkPTzHgK7PnTL/q6dSbix9MEwSN53gLT4E1TPYxY6ce0mfFo1w97VBUdvTzIvJJGVepn0s4k4lS1bEEMVEREp1vKVFG/atIly5coBsHnz5gINSKQ0sXNyxM7J0fzZIekSmMDRy5PraVc5v3krp85fBMDR2wv/B9viVa+Wuf3xpatwq1oJn1Y3tklM2r6L1LhDkJODa+WKBPV/Iteexmnxx7l+JQ2v+nVu9FvGA5/W4Ryd8yF2zs5U7N6poIctIiJS7OQrKW7VqpX55+DgYCpXrpxrttgwDE6ePGnb6ERKGffgquYXdzi4u1FtcL/btq/6dC+LzxW7P0xFHv7ba7gHV7UoK9/s/nzthSwiInK3snqf4uDgYM6fP5+rPCkpieDgYJsEdVNUVBT3338/ZcqUwdfXl27dunHw4EGLNunp6URGRlK+fHk8PDzo0aMHiYmJFnF17twZDw8PGjZsyJ49eyzOj4yM5K233rJp3CIiIiJSslidFN9cO/xXV65cwcXFxSZB3bRlyxYiIyPZvn0769evJysri44dO5KWlmZuM2rUKL766itWr17Nli1bOHPmDN27dzfXT506lcuXL7N7925at27Nc889Z67bvn07O3bsYOTIkTaNW0RERERKlnxvyTZ69GjgxtPvr7zyCm5ubua67OxsduzYQYMGDWwa3Nq1ay0+L168GF9fX3bt2kXLli1JSUlh4cKFrFixgrZt2wKwaNEiateuzfbt22natClxcXH07t2bkJAQBg0axPz5N57yz8rKYsiQIXzwwQfY29vbNG4RERERKVnynRTfXHZgGAa//vorTk5O5jonJydCQ0P517/+ZfsI/yQlJQXA/NDfrl27yMrKon379uY2tWrVokqVKsTGxtK0aVNCQ0PZtGkTAwcOJDo6mvr16wMwbdo0WrduTePGjfN17YyMDDIyMizKnJ2dcXZ2tsXQRERERKQI5TspvrnrRP/+/XnnnXcKfT/inJwcRo4cSXh4OPXq1QMgISEBJycnvL29Ldr6+fmRkJAAwLhx4xg6dCjVq1cnKCiIhQsXcvjwYZYsWUJsbCxDhgxh3bp1NG7cmAULFuDl5ZXn9aOionj11VctyiZOnMikSZNsPlYRERERKVxWv9Fu0aJFBRHH34qMjGT//v1s3brVqvO8vLxYsWKFRVnbtm2ZPn06y5cv59ixYxw8eJDnnnuOyZMn3/Khu/Hjx5uXkNykWWIRERGRu8MdveZ5586drFq1ihMnTpCZmWlR99lnn9kksD8bNmwYX3/9Nd9//z2VKlUyl/v7+5OZmUlycrLFbHFiYiL+/v559rVo0SK8vb3p2rUr3bt3p1u3bjg6OtKzZ08mTJhwyxi0VEJERETk7mX17hOffPIJzZo1Iy4ujs8//5ysrCwOHDjApk2bbrn04E4ZhsGwYcP4/PPP2bRpU64t3xo1aoSjoyMbN240lx08eJATJ04QFhaWq7/z588zefJkZs2aBdx4QDArKwu48eCd3sYnIiIiUjpZPVP8+uuv8/bbbxMZGUmZMmV45513CA4OZvDgwQQEBNg0uMjISFasWMEXX3xBmTJlzOuEvby8cHV1xcvLi2effZbRo0dTrlw5PD09GT58OGFhYTRt2jRXfyNHjmTMmDFUrFgRgPDwcJYtW0bHjh2ZP38+4eHhNo1fREREREoGq2eKjx49ysMP33hjlpOTE2lpaZhMJkaNGmXe7sxW5s2bR0pKCq1btyYgIMB8rFy50tzm7bff5pFHHqFHjx60bNkSf3//PJdwREdHc+TIEZ5//nlz2bBhw6hWrRpNmjQhMzOTiRMn2jR+ERERESkZrJ4pLlu2LJcvXwagYsWK7N+/n3vvvZfk5GSuXr1q0+AMw/jbNi4uLsyZM4c5c+bctl1ERAQREREWZW5ubqxateofxSgiIiIiJZ/VSXHLli1Zv3499957Lz179uSFF15g06ZNrF+/nnbt2hVEjCIiIiIiBcrqpHj27Nmkp6cD8NJLL+Ho6MiPP/5Ijx49ePnll20eoIiIiIhIQbM6Kb75NjkAOzs7xo0bZ/587do120QlIiIiIlKIrH7QLi8ZGRnMmDEj15ZpIiIiIiIlQb6T4oyMDMaPH0/jxo1p1qwZa9asAW68DCM4OJi3336bUaNGFVScIiIiIiIFJt/LJyZMmMD7779P+/bt+fHHH+nZsyf9+/dn+/btzJgxg549e2Jvb1+QsYqIiIiIFIh8J8WrV69m6dKldOnShf3791O/fn2uX7/Ovn37MJlMBRmjiIiIiEiByndSfOrUKRo1agRAvXr1cHZ2ZtSoUUqIS7Cc69c5+/V60o7+QfbVazh4elCheRPKNgo1t7m0cx8Xtu4gK/UyDu6u+Hdqj2ftkDz7u3IknsR1MWRevISjVxn8HmpHmXuqAZCdnsGp1V9y9fgp3KpWolKvrtg7OwGQ8stvXD50lEqPdS74QYuIiIjkId9JcXZ2Nk5OTv93ooMDHh4eBRKUFJKcHBzLuBPUvzeOZb25duoMx5euwtHLE48awST9vJeLP/5MpV5dcAnwIzvtKjmZWXl2lZmUzMmPP6NSr6543FOdK4ePcvLjz6kx7Fmcynlzaede7JydqDX+BU6t/oJLO/dQIbwJ2dfSOR/zI0HP9inkwYuIiIj8n3wnxYZh8Mwzz+Ds7AxAeno6Q4YMwd3d3aJdXq9YluLJzskJ33YtzZ/dKlfEPbgqV4+fxL1aVc5v+oGKPR7BNdAfAAcP91t1xZXDx3AJ8KNMzRoAlKlZA9dKASTv/RXfti3ITErGPbgKJns73KsFkZ54DoDEdZsp3/wBHNzdCnCkIiIiIreX76S4X79+Fp+ffPJJmwcjRSsn6zrXTp/Fq34dMi4kcf1KGtfOJHDmi+8wcgw87qmG/4NtsXdxznVunq/kNgzSE84D4OLnQ9qx43g3vJe0+OO4B1ch7fhJMpOSCez6UEEPTUREROS28p0UL1q0qCDjkCJmGAZn1nyHU/myeNapydWTpwBIO/oH1YY8A8CpVV+Q8N1GKj7aKdf5HtWDSIzeROpvhyhTswaXDx7h6olTuAdVAcC7UX3Sz53n2LwluAVVwiu0Ln8sXEGlx7uStGM3KfvjsHd1JeCRDjh6lim0cYuIiIjAHbzRTu4+hmFw9qt1ZFy8SNAzvTHZmbD7/+vHK7QMMy9tqNAyjFOrv8yzD2ef8lTq1ZXzm7ZyZs23uFapiFe9Ohg52QDYOTgQ2DnC3P7c5m141gnByM4hacduqj3/DCm//EbC2k1U7tW1gEcsIiIiYklJcSlnGAZnv17HtVNnCOr/BPYuLgA4VyiHycG6/z08a4dY7Exx7P0leDe4N1e7jAtJXP79EMHPPc3luEM4+/tg5+CAW+WKXNy6458NSEREROQO2OQ1z1Jynf16PVePn6LqM72xd3Uxl9s5OuIVWpcLP2wn+1o62dfSufDDdsrUuueWfV07fRYjO4fsjAzObd5K9tV0vBvWy33Nr6IJ6NQBOwd7nMp6c+3UWbLT07ly9A8cy3kXxDBFREREbkszxaVYZnIKl37ajcnBnsNvzTWXe4XWJbDLgwR0asfZr9dxaMY8TPb2lKl1D/4PtTW3O/LuB1RoFYZ3aF0AEtdv4dqpM4AJj+pBBA14wrwM46ZLu3/BqXxZ3KpWAsC1UgCedUI4POM9HDzLUElLJ0RERKQIKCkuxZy8vag7Zdwt6+2cnKjY/REq3qK+xoiBFp+Dnun9t9cse199yt5X36LM/8G2+D/Y9hZniIiIiBQ8LZ8QERERkVJPSbGIiIiIlHrFPin+/vvv6dy5M4GBgZhMJtasWWNRbxgGEyZMICAgAFdXV9q3b8/hw4fN9RkZGTz11FN4enoSEhLChg0bLM6fPn06w4cPL4yhiIiIiEgxVeyT4rS0NEJDQ5kzZ06e9dOmTePdd9/lvffeY8eOHbi7uxMREUF6ejoA8+fPZ9euXcTGxjJo0CD69OljfvtafHw8CxYsYOrUqYU2HhEREREpfor9g3YPPfQQDz2U92uADcNg5syZvPzyy3TtemPXgqVLl+Ln58eaNWvo3bs3cXFxdOnShbp161KtWjVefPFFLly4gI+PD0OHDuWNN97A09OzMIckIiIiIsVMsZ8pvp34+HgSEhJo3769uczLy4smTZoQGxsLQGhoKFu3buXatWtER0cTEBBAhQoVWL58OS4uLjz66KP5ulZGRgapqakWR0ZGRoGMS0REREQKV4lOihMSEgDw8/OzKPfz8zPXDRgwgNDQUOrUqcPUqVNZtWoVly5dYsKECcyaNYuXX36ZGjVqEBERwenTp295raioKLy8vCyOqKioghuciIiIiBSaYr984p9ydHTMtR65f//+jBgxgj179rBmzRr27dvHtGnTGDFiBJ9++mme/YwfP57Ro0dblDk7OxdY3CIiIiJSeEr0TLG/vz8AiYmJFuWJiYnmur/avHkzBw4cYNiwYcTExNCpUyfc3d3p1asXMTExt7yWs7Mznp6eFoeSYhEREZG7Q4lOioODg/H392fjxo3mstTUVHbs2EFYWFiu9unp6URGRvL+++9jb29PdnY2WVlZAGRlZZGdnV1osYuIiIhI8VHsk+IrV66wd+9e9u7dC9x4uG7v3r2cOHECk8nEyJEjee211/jyyy/59ddfefrppwkMDKRbt265+poyZQqdOnWiYcOGAISHh/PZZ5/xyy+/MHv2bMLDwwtxZCIiIiJSXBT7NcU7d+6kTZs25s831/X269ePxYsXM3bsWNLS0hg0aBDJyck0b96ctWvX4uLiYtHP/v37WbVqlTm5BnjssceIiYmhRYsW1KxZkxUrVhTKmERERESkeCn2SXHr1q3NL9vIi8lkYvLkyUyePPm2/dSrV8/iTXcAdnZ2zJ07l7lz59okVhEREREpmYr98gkRERERkYKmpFhERERESj0lxSIiIiJS6ikpFhEREZFST0mxiIiIiJR6SopFREREpNRTUiwiIiIipZ6SYhEREREp9ZQUi4iIiEipp6RYREREREo9JcUiIiIiUuopKRYRERGRUk9JsYiIiIiUekqKRURERKTUU1IsIiIiIqWekmIRERERKfWUFIuIiIhIqaekWERERERKPSXFIiIiIlLq3TVJ8Zw5cwgKCsLFxYUmTZrw008/metGjx5NuXLlqFy5MsuXL7c4b/Xq1XTu3LmwwxURERGRYsShqAOwhZUrVzJ69Gjee+89mjRpwsyZM4mIiODgwYPs2LGDFStWsG7dOg4fPsyAAQOIiIigQoUKpKSk8NJLL7Fhw4aiHoKIiIiIFKG7YqZ4xowZPPfcc/Tv3586derw3nvv4ebmxocffkhcXBytW7emcePGPPHEE3h6ehIfHw/A2LFjGTp0KFWqVCniEYiIiIhIUSrxSXFmZia7du2iffv25jI7Ozvat29PbGwsoaGh7Ny5k0uXLrFr1y6uXbtGjRo12Lp1K7t372bEiBFFGL2IiIiIFAclPim+cOEC2dnZ+Pn5WZT7+fmRkJBAREQETz75JPfffz/PPPMMS5Yswd3dnaFDh/Lee+8xb948atasSXh4OAcOHLjldTIyMkhNTbU4MjIyCnp4IiIiIlIYjBLu9OnTBmD8+OOPFuUvvvii8cADD+R5zqRJk4yRI0ca+/btM/z8/Ixz584ZH374oXHffffd8joTJ040AItj4sSJthxKiZWenm5MnDjRSE9PL+pQSi3dg+JB96Ho6R4UPd2D4kH3wXomwzCMIs3K/6HMzEzc3Nz43//+R7du3czl/fr1Izk5mS+++MKi/e+//07nzp3Zs2cPH374IVu3bmXVqlWkpaXh4eFBamoqZcqUyXWdjIyMXDPDzs7OODs7F8i4SpLU1FS8vLxISUnB09OzqMMplXQPigfdh6Kne1D0dA+KB90H65X45RNOTk40atSIjRs3mstycnLYuHEjYWFhFm0Nw2Dw4MHMmDEDDw8PsrOzycrKAjD/Nzs7O8/rODs74+npaXEoIRYRERG5O9wVW7KNHj2afv360bhxYx544AFmzpxJWloa/fv3t2j3wQcf4OPjY96XODw8nEmTJrF9+3a+++476tSpg7e3dxGMQERERESK0l2RFD/++OOcP3+eCRMmkJCQQIMGDVi7dq3Fw3eJiYlMnTqVH3/80Vz2wAMPMGbMGB5++GF8fX1ZsmRJUYQvIiIiIkXsrkiKAYYNG8awYcNuWe/n58cff/yRq3zChAlMmDChACO7+zk7OzNx4kQtJylCugfFg+5D0dM9KHq6B8WD7oP1SvyDdiIiIiIi/1SJf9BOREREROSfUlIsIiIiIqWekmIRERERKfWUFEu+zJkzh6CgIFxcXGjSpAk//fTTbduvXr2aWrVq4eLiwr333su3335bSJHenb7//ns6d+5MYGAgJpOJNWvW/O05MTEx3HfffTg7O1OjRg0WL15c4HHeTQriO7+TPkuzgrgHUVFR3H///ZQpUwZfX1+6devGwYMHC2YAd4mCuA+TJk3CZDJZHLVq1SqYAdwFrL0HZ8+epU+fPoSEhGBnZ8fIkSPzbKd/qy0pKZa/tXLlSkaPHs3EiRPZvXs3oaGhREREcO7cuTzb//jjjzzxxBM8++yz7Nmzh27dutGtWzf2799fyJHfPdLS0ggNDWXOnDn5ah8fH8/DDz9MmzZt2Lt3LyNHjmTgwIFER0cXcKR3j4L4zq3ts7QriHuwZcsWIiMj2b59O+vXrycrK4uOHTuSlpZWUMMo8Qrq75+6dety9uxZ87F169aCCP+uYO09yMjIwMfHh5dffpnQ0NA82+jf6jwU6UumpUR44IEHjMjISPPn7OxsIzAw0IiKisqzfa9evYyHH37YoqxJkybG4MGDCzTO0gIwPv/889u2GTt2rFG3bl2Lsscff9yIiIgowMjuXgXxneenT/k/BfX//blz5wzA2LJliy3CvOvZ6j5MnDjRCA0NLYAI737W/t3RqlUr44UXXshVrn+rc9NMsdxWZmYmu3bton379uYyOzs72rdvT2xsbJ7nxMbGWrQHiIiIuGV7sT3dg8Kn77zo3ck9SElJAaBcuXIFGltpkt/7cPjwYQIDA6lWrRp9+/blxIkThRlmqae/s3JTUiy3deHCBbKzsy3eDgg3XoaSkJCQ5zkJCQlWtRfbu9U9SE1N5dq1a0UU1d1N33nRs/Ye5OTkMHLkSMLDw6lXr15hhXnXy899aNKkCYsXL2bt2rXMmzeP+Ph4WrRoweXLl4si5FJJ/1bndte80U5ERMQakZGR7N+/X2tZi8BDDz1k/rl+/fo0adKEqlWrsmrVKp599tkijExKMyXFclsVKlTA3t6exMREi/LExET8/f3zPMff39+q9mJ7t7oHnp6euLq6FlFUdzd950XPmnswbNgwvv76a77//nsqVapUmGHe9e7kz4K3tzchISEcOXKkMEIU9G91XrR8Qm7LycmJRo0asXHjRnNZTk4OGzduJCwsLM9zwsLCLNoDrF+//pbtxfZ0DwqfvvOil597YBgGw4YN4/PPP2fTpk0EBwcXdph3vTv5s3DlyhWOHj1KQEBAQYcn/5/+zspDUT/pJ8XfJ598Yjg7OxuLFy82fvvtN2PQoEGGt7e3kZCQYBiGYTz11FPGuHHjzO23bdtmODg4GG+++aYRFxdnTJw40XB0dDR+/fXXohpCiXf58mVjz549xp49ewzAmDFjhrFnzx7j+PHjhmEYxrhx44ynnnrK3P7YsWOGm5ub8eKLLxpxcXHGnDlzDHt7e2Pt2rVFNYQSpyC+87/rUywVxD0YOnSo4eXlZcTExBhnz541H1evXi308ZUUBXEfxowZY8TExBjx8fHGtm3bjPbt2xsVKlQwzp07V+jjKwmsvQeGYZjbN2rUyOjTp4+xZ88e48CBA+Z6/Vudm5JiyZdZs2YZVapUMZycnIwHHnjA2L59u7muVatWRr9+/Szar1q1yggJCTGcnJyMunXrGt98800hR3x32bx5swHkOm5+7/369TNatWqV65wGDRoYTk5ORrVq1YxFixYVetwlWUF853/Xp1gqiHuQV3+A/nzcRkHch8cff9wICAgwnJycjIoVKxqPP/64ceTIkcIZUAl0J/cgr/ZVq1a1aKN/qy2ZDMMwCmACWkRERESkxNCaYhEREREp9ZQUi4iIiEipp6RYREREREo9JcUiIiIiUuopKRYRERGRUk9JsYiIiIiUekqKRURERKTUU1IsIiIiIqWekmIRERERKfWUFIuIyN9q3bo1I0eOLOowREQKjJJiERERESn1lBSLiIiISKmnpFhEpIRJTk7GZDKxbds2AI4cOUKtWrV4+eWXMQzDou38+fMJDAwkJyfHorxr164MGDAAgLVr19K8eXO8vb0pX748jzzyCEePHr1tDEFBQcycOdOirEGDBkyaNAmAnJwcoqKiCA4OxtXVldDQUP73v//9g1GLiBQsJcUiIiXML7/8gslkIjQ0lK1bt9KqVSv+85//8Nprr2EymSza9uzZk4sXL7J582ZzWVJSEmvXrqVv374ApKWlMXr0aHbu3MnGjRuxs7Pj0UcfzZVIWyMqKoqlS5fy3nvvceDAAUaNGsWTTz7Jli1b7rhPEZGC5FDUAYiIiHX27dtH9erV+eKLLxg7diwff/wxLVu2zLNt2bJleeihh1ixYgXt2rUD4H//+x8VKlSgTZs2APTo0cPinA8//BAfHx9+++036tWrZ3V8GRkZvP7662zYsIGwsDAAqlWrxtatW3n//fdp1aqV1X2KiBQ0zRSLiJQw+/btIyEhgWeeeQZ/f/9bJsQ39e3bl08//ZSMjAwAli9fTu/evbGzu/FPwOHDh3niiSeoVq0anp6eBAUFAXDixIk7iu/IkSNcvXqVDh064OHhYT6WLl36t8syRESKimaKRURKmH379tG4cWNee+01WrRowZo1a+jWrdst23fu3BnDMPjmm2+4//77+eGHH3j77bct6qtWrcqCBQvM64/r1atHZmbmLfu0s7PLtX45KysLgCtXrgDwzTffULFiRYs2zs7O1g5XRKRQKCkWESlBsrOz2b9/PytXriQ8PJzHHnuMSZMm0bVr11zriW9ycXGhe/fuLF++nCNHjlCzZk3uu+8+AC5evMjBgwdZsGABLVq0AGDr1q1/G4ePjw9nz541f05NTSU+Ph6AOnXq4OzszIkTJ7RUQkRKDCXFIiIlyKFDh0hPT6dBgwYAvPLKK4SGhvLpp5/y2GOP3fK8vn378sgjj3DgwAGefPJJc3nZsmUpX7488+fPJyAggBMnTjBu3Li/jaNt27YsXryYzp074+3tzYQJE7C3twegTJky/Otf/2LUqFHk5OTQvHlzUlJS2LZtG56envTr1++ffQkiIgVASbGISAmyb98+vL29qVKlCgD33nsv3bt3Z9KkSXTv3t28Tviv2rZtS7ly5Th48CB9+vQxl9vZ2fHJJ58wYsQI6tWrR82aNXn33Xdp3br1beMYP3488fHxPPLII3h5eTFlyhTzTDHAlClT8PHxISoqimPHjuHt7c19993Hf/7zn3/+JYiIFACT8ddFYSIiIiIipYx2nxARERGRUk9JsYiIiIiUekqKRURERKTUU1IsIiIiIqWekmIRERERKfWUFIuIiIhIqaekWERERERKPSXFIiIiIlLqKSkWERERkVJPSbGIiIiIlHpKikVERESk1FNSLCIiIiKl3v8DNsPVcrE1JzMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 720x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "keys = sorted(kappa_swipe_ratio.keys(), key=float)\n",
    "ratios = [kappa_swipe_ratio[k] for k in keys]\n",
    "x = list(range(len(keys)))\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(max(6, len(keys)*1.2), 4))\n",
    "# bottom = green (ratio), top = red (1 - ratio)\n",
    "ax.bar(x, ratios, color='#2BAEAE', label='Positive improvements')\n",
    "ax.bar(x, [1 - r for r in ratios], bottom=ratios, color='#E67E56', label='Negative improvements')\n",
    "\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(keys)\n",
    "ax.set_ylim(0, 1)\n",
    "\n",
    "# set y-ticks as percentages\n",
    "yticks = [i/10 for i in range(0, 11)]  # 0%,10%,...,100%\n",
    "ax.set_yticks(yticks)\n",
    "ax.yaxis.set_major_formatter(PercentFormatter(1.0))\n",
    "\n",
    "ax.set_ylabel('Ratio of positive improvements')\n",
    "ax.set_xlabel('$\\\\kappa$ value')\n",
    "ax.set_title('RoBERTa base on SST-2')\n",
    "# legend removed\n",
    "\n",
    "# remove border/spines around the plot\n",
    "for spine in ax.spines.values():\n",
    "    spine.set_visible(False)\n",
    "ax.set_frame_on(False)\n",
    "\n",
    "# add ratio text above green part\n",
    "for xi, r in zip(x, ratios):\n",
    "    pct = f\"{r*100:.1f}%\"\n",
    "    y = r / 2 if r > 0 else 0.01\n",
    "    ax.text(xi, y, pct, ha='center', va='center', fontsize=9, color='#002B36')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23d52312",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
