{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "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": 16,
   "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(\"mnli_large/stats_mnli_roberta-large_earthy-waterfall-810_epochs20_denoising_nototclip.pkl\")\n",
    "path_1 = Path(\"mnli_large/stats_mnli_roberta-large_balmy-star-805_epochs20_denoising_nototclip.pkl\")\n",
    "path_101 = Path(\"mnli_large/stats_mnli_roberta-large_easy-waterfall-806_epochs20_denoising_nototclip.pkl\")\n",
    "path_102 = Path(\"mnli_large/stats_mnli_roberta-large_stellar-armadillo-807_epochs20_denoising_nototclip.pkl\")\n",
    "path_105 = Path(\"mnli_large/stats_mnli_roberta-large_robust-music-808_epochs20_denoising_nototclip.pkl\")\n",
    "path_110 = Path(\"mnli_large/stats_mnli_roberta-large_brisk-darkness-809_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": 17,
   "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": 18,
   "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": 20,
   "id": "17dda95d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsUAAAGGCAYAAACT7/xHAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAbA5JREFUeJzt3Xd8VMX+//HXphdIQgkp1ECkS0AQCAGpEkERBEEEFamCAaRc/cFVupgrKKA0BRGQS1CwgJUgJShSlKpgpIamJJSQBEIam/P7g8t+XRMwi5tG3s/H4zxudmbOnM/sEfK5w5w5JsMwDERERERESjCHwg5ARERERKSwKSkWERERkRJPSbGIiIiIlHhKikVERESkxFNSLCIiIiIlnpJiERERESnxlBSLiIiISImnpFhERERESjwlxSIiIiJS4ikpFhG5CyxbtgyTycTJkycLOxQRkWJJSbGIFEk3k7ybh5OTExUrVuTZZ5/l999/t0ufJpOJChUq0LZtW7755psc7f/a9s/H0KFDLe2effZZqzpXV1dq1qzJxIkTSU9PB6BatWq37e/msWzZsjsam/y9kydPWr7nV199Ndc2ffv2xWQyUapUKavyNm3aYDKZ6NKlyy37feONNyxlMTExmEwmPv7449vGZDKZGD58+B2MRkTszamwAxARuZ2pU6cSFBREeno6O3fuZNmyZWzbto2DBw/i5ub2j/o0DIOEhASWLVtG586d+eKLL3jkkUes2j744IM888wzOfqoWbOm1WdXV1fee+89AJKTk1m3bh3Tpk3j+PHjrFy5kjlz5nD16lVL+6+//ppVq1Yxe/Zsypcvbylv0aLFHY1J8s7NzY1Vq1bxyiuvWJWnpqaybt262/539eWXX7Jnzx4aN26c32GKSAFTUiwiRVqnTp1o0qQJAIMGDaJ8+fK8/vrrfP755/Tq1esf9wkwcOBA/Pz8WLVqVY6kuGbNmjz11FN/26eTk5NVu+eff54WLVqwatUqZs2aRbdu3azax8fHs2rVKrp160a1atXuaBz56dq1a3h4eBR2GPmic+fOfPrppxw4cICQkBBL+bp168jMzOShhx5i8+bNOc6rUqUKV65cYcqUKXz++ecFGbKIFAAtnxCRYqVVq1YAHD9+3Kp88+bNtGrVCk9PT3x8fOjatSuxsbF56tPHxwd3d3ecnOw3T2AymWjZsiWGYXDixIk8nbNu3ToefvhhAgMDcXV1pUaNGkybNg2z2XxHMeS1vzZt2lC/fn327NnDAw88gIeHB//+978BuHTpEk8//TReXl74+PjQr18/Dhw4kOtSj99++43HH3+csmXL4ubmRpMmTfKcPKampjJ27FgqV66Mq6srtWrV4o033sAwDKt2N5cbrF27lvr16+Pq6kq9evVYv359nr+X0NBQgoKCiIqKsipfuXIlDz30EGXLls31vNKlSzN69Gi++OIL9u7dm+friUjxoKRYRIqVmw+SlSlTxlK2ceNGwsPDOX/+PJMnT2bMmDFs376dsLCwXB88S05O5uLFi1y4cIFDhw4xbNgwrl69muuMcHp6OhcvXsxxZGZm3lGst7Ns2TJKlSrFmDFjeOutt2jcuDETJ05k3LhxeTr/n/R36dIlOnXqRMOGDZkzZw5t27YlOzubLl26sGrVKvr168f06dM5d+4c/fr1y3H+oUOHaN68ObGxsYwbN44333wTT09PunXrxmeffXbbOA3D4NFHH2X27Nk89NBDzJo1i1q1avHiiy8yZsyYHO23bdvG888/T+/evZkxYwbp6en06NGDS5cu5fm7efLJJ/nwww8tSffFixfZsGEDffr0ue15L7zwAmXKlGHy5Ml5vpaIFBOGiEgRtHTpUgMwNm7caFy4cME4c+aM8fHHHxu+vr6Gq6urcebMGUvbhg0bGhUqVDAuXbpkKTtw4IDh4OBgPPPMMzn6/Ovh6upqLFu2LEcMubW9eaxatcrSrl+/foanp6dx4cIF48KFC8axY8eMN954wzCZTEb9+vWN7OzsHH3PnDnTAIy4uDhL2bVr13K0e+655wwPDw8jPT09T9/XnfTXunVrAzDeeecdq7affPKJARhz5syxlJnNZqNdu3YGYCxdutRS3r59e+Pee++16jc7O9to0aKFcc8999w29rVr1xqA8eqrr1qVP/7444bJZDKOHTtmKQMMFxcXq7IDBw4YgDF37tzbXicuLs4AjJkzZxoHDx40AOP77783DMMw5s+fb5QqVcpITU213M8/a926tVGvXj3DMAxjypQpBmDs2bMnR783bdmyxQCMNWvW3DYmwIiIiLhtGxEpGJopFpEirUOHDvj6+lK5cmUef/xxPD09+fzzz6lUqRIA586dY//+/Tz77LNW/+zdoEEDHnzwQb7++usc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6IjZbLZs75aVlZXr66tFRERE5O5nc1K8ZcuW/IgjV126dGH69OlUqVKFevXqsW/fPmbNmsWAAQOAG0n4qFGjePXVV7nnnnssW7IFBgZa3sD3Z9OmTaNz5840atQIgLCwMF588UX69+/PvHnzCAsLK7CxiYiIiEjRcUf7FAMcO3aM48eP88ADD+Du7o5hGHafKZ47dy4TJkzg+eef5/z58wQGBvLcc88xceJES5uXXnqJ1NRUhgwZQlJSEi1btmT9+vW4ublZ9XXw4EFWr17N/v37LWWPP/44MTExtGrVilq1ahXYWmkRERERKVpsToovXbpEr1692LJlCyaTiaNHj1K9enUGDhxImTJlePPNN+0WXOnSpZkzZw5z5sy5ZRuTycTUqVOZOnXqbfuqX7++1ZvuABwcHFiwYAELFiywR7giIiIiUkzZvPvE6NGjcXZ25vTp03h4eFjKn3jiCdavX2/X4ERERERECoLNM8UbNmwgOjqaSpUqWZXfc889nDp1ym6BiYiIiIgUFJtnilNTU61miG9KTEzUlmUiIiIiUizZnBS3atWKDz74wPLZZDKRnZ3NjBkzaNu2rV2DExEREREpCDYvn5gxYwbt27dn9+7dZGZm8tJLL3Ho0CESExP54Ycf8iNGEREREZF8ZfNMcf369Tly5AgtW7aka9eupKam0r17d/bt20eNGjXyI0YRERERkXx1R/sUe3t78/LLL9s7FhERERGRQnFHSXF6ejo///wz58+ft7xy+aZHH33ULoGJiIiIiBQUm5Pi9evX88wzz3Dx4sUcdSaTCbPZbJfAREREREQKis1rikeMGEHPnj05d+4c2dnZVocSYhEREREpjmxOihMSEhgzZgx+fn75EY+IiIiISIGzOSl+/PHHiYmJyYdQREREREQKh81riufNm0fPnj35/vvvuffee3F2draqHzlypN2CExEREREpCDYnxatWrWLDhg24ubkRExODyWSy1JlMJiXFIiIiIlLs2JwUv/zyy0yZMoVx48bh4GDz6gsRERERkSLH5qw2MzOTJ554QgmxiIiIiNw1bM5s+/Xrx0cffZQfsYiIiIiIFAqbl0+YzWZmzJhBdHQ0DRo0yPGg3axZs+wWnIiIiIhIQbA5Kf7ll19o1KgRAAcPHrSq+/NDdyIiIiIixYXNyye2bNlyy2Pz5s12D7BatWqYTKYcR0REBADp6elERERQrlw5SpUqRY8ePUhISLCcn5iYSJcuXShVqhSNGjVi3759Vv1HRETw5ptv2j1uERERESk+7vhpuWPHjhEdHU1aWhoAhmHYLag/++mnnzh37pzl+PbbbwHo2bMnAKNHj+aLL75gzZo1bN26lT/++IPu3btbzp8+fTpXrlxh7969tGnThsGDB1vqdu7cya5duxg1alS+xC4iIiIixYPNSfGlS5do3749NWvWpHPnzpw7dw6AgQMHMnbsWLsH6Ovri7+/v+X48ssvqVGjBq1btyY5OZklS5Ywa9Ys2rVrR+PGjVm6dCnbt29n586dAMTGxtK7d29q1qzJkCFDiI2NBSArK4uhQ4fyzjvv4OjoaPe4RURERKT4sDkpHj16NM7Ozpw+fRoPDw9L+RNPPMH69evtGtxfZWZm8t///pcBAwZgMpnYs2cPWVlZdOjQwdKmdu3aVKlShR07dgAQEhLC5s2buX79uuXhQIAZM2bQpk0bmjRpkqdrZ2RkkJKSYnVkZGTYf5AiIiIiUuBsToo3bNjA66+/TqVKlazK77nnHk6dOmW3wHKzdu1akpKSePbZZwGIj4/HxcUFHx8fq3Z+fn7Ex8cDMG7cOJycnKhRowafffYZS5Ys4ejRoyxfvpwJEyYwdOhQqlevTq9evUhOTr7ltSMjI/H29rY6IiMj82uoIiIiIlKAbN59IjU11WqG+KbExERcXV3tEtStLFmyhE6dOhEYGJjnc7y9vYmKirIqa9euHTNnzmTlypWcOHGCw4cPM3jwYKZOnXrLh+7Gjx/PmDFjrMrye7wiIiIiUjBsnilu1aoVH3zwgeWzyWQiOzubGTNm0LZtW7sG92enTp1i48aNDBo0yFLm7+9PZmYmSUlJVm0TEhLw9/fPtZ+lS5fi4+ND165diYmJoVu3bjg7O9OzZ09iYmJueX1XV1e8vLysDiXFIiIiIncHm2eKZ8yYQfv27dm9ezeZmZm89NJLHDp0iMTERH744Yf8iBG4kcxWqFCBhx9+2FLWuHFjnJ2d2bRpEz169ADg8OHDnD59mtDQ0Bx9XLhwgalTp7Jt2zbgxotIsrKygBsP3pnN5nyLX0RERESKLpuT4vr163PkyBHmzZtH6dKluXr1Kt27dyciIoKAgID8iJHs7GyWLl1Kv379cHL6v5C9vb0ZOHAgY8aMoWzZsnh5eTFixAhCQ0Np3rx5jn5GjRrF2LFjqVixIgBhYWGsWLGCjh07smjRIsLCwvIlfhEREREp2mxOiuFGMvryyy/bO5Zb2rhxI6dPn2bAgAE56mbPno2DgwM9evQgIyOD8PBwFixYkKNddHQ0x44dY8WKFZay4cOHs3v3bpo1a0bTpk2ZNGlSvo5DRERERIomm5Pi4OBgnnrqKfr27cs999yTHzHl0LFjx1u+HMTNzY358+czf/782/YRHh5OeHi4VZmHhwerV6+2W5wiIiIiUjzZ/KBdREQEX331FbVq1eL+++/nrbfesmx/JiIiIiJSHN3Ryzt++uknfvvtNzp37sz8+fOpXLkyHTt2tNqVQkRERESkuLA5Kb6pZs2aTJkyhSNHjvD9999z4cIF+vfvb8/YREREREQKxB09aHfTjz/+SFRUFB999BEpKSn07NnTXnGJiIiIiBQYm5PiI0eOsHLlSlatWkVcXBzt2rXj9ddfp3v37pQqVSo/YhQRERERyVc2J8W1a9fm/vvvJyIigt69e+Pn55cfcYmIiIiIFBibk+LDhw8X2FZsIiIiIiIFweak+GZCvGfPHmJjYwGoW7cu9913n30jExEREREpIDYnxefPn+eJJ55g69at+Pj4AJCUlETbtm358MMP8fX1tXeMIiIiIiL5yuYt2UaMGMHVq1c5dOgQiYmJJCYmcvDgQVJSUhg5cmR+xCgiIiIikq9snilev349GzdupE6dOpayunXrMn/+fDp27GjX4ERERERECoLNM8XZ2dk4OzvnKHd2diY7O9suQYmIiIiIFCSbk+J27drxwgsv8Mcff1jKfv/9d0aPHk379u3tGpyIiIiISEGwOSmeN28eKSkpVKtWjRo1alCjRg2CgoJISUlh7ty5+RGjiIiIiEi+snlNceXKldm7dy8bN27kt99+A6BOnTp06NDB7sGJiIiIiBQEm5LirKws3N3d2b9/Pw8++CAPPvhgfsUlIiIiIlJgbEqKnZ2dqVKlCmazOb/iERH5Ww827F3YIRRLBws7ABGRIszmNcUvv/wy//73v0lMTMyPeERERERECpzNa4rnzZvHsWPHCAwMpGrVqnh6elrV7927127BiYiIiIgUBJuT4m7duuVDGLf2+++/8//+3//jm2++4dq1awQHB7N06VKaNGkCgGEYTJo0icWLF5OUlERYWBgLFy7k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lKFTp05ERUXRvn17AD7++GPKly9P27ZtAejRo4fVOe+//z6+vr78+uuv1K9f3+b4MjIyeO2119i4cSOhoaEAVK9enW3btvHuu+/SunVrm/sUEclvmikWESlmDhw4QHx8PM8++yz+/v63TIhv6tu3L5988gkZGRkArFy5kt69e+PgcONXwNGjR3nyySepXr06Xl5eVKtWDYDTp0/fUXzHjh3j2rVrPPjgg5QqVcpyfPDBB3+7LENEpLBoplhEpJg5cOAATZo04dVXX6VVq1asXbuWbt263bJ9ly5dMAyDr776ivvvv5/vv/+e2bNnW9VXrVqVxYsXW9Yf169fn8zMzFv26eDgkGP9clZWFgBXr14F4KuvvqJixYpWbVxdXW0drohIgVBSLCJSjJjNZg4ePMhHH31EWFgYjz/+OJMnT6Zr16451hPf5ObmRvfu3Vm5ciXHjh2jVq1a3HfffQBcunSJw4cPs3jxYlq1agXAtm3b/jYOX19fzp07Z/mckpJCXFwcAHXr1sXV1ZXTp09rqYSIFBtKikVEipEjR46Qnp5Ow4YNAZgwYQIhISF88sknPP7447c8r2/fvjzyyCMcOnSIp556ylJepkwZypUrx6JFiwgICOD06dOMGzfub+No164dy5Yto0uXLvj4+DBx4kQcHR0BKF26NP/6178YPXo02dnZtGzZkuTkZH744Qe8vLzo16/fP/sSRETygZJiEZFi5MCBA/j4+FClShUA7r33Xrp3787kyZPp3r27ZZ3wX7Vr146yZcty+PBh+vTpYyl3cHDgww8/ZOTIkdSvX59atWrx9ttv06ZNm9vGMX78eOLi4njkkUfw9vZm2rRplpligGnTpuHr60tkZCQnTpzAx8eH++67j3//+9///EsQEckHJuOvi8JEREREREoY7T4hIiIiIiWekmIRERERKfGUFIuIiIhIiaekWERERERKPCXFIiIiIlLiKSkWERERkRJPSbGIiIiIlHhKikVERESkxFNSLCIiIiIlnpJiERERESnxlBSLiIiISImnpFhERERESrz/D+cdbFci54NOAAAAAElFTkSuQmCC",
      "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 large on MNLI')\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
}
