{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "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(\"sst_large/stats_sst2_roberta-large_neat-valley-816_epochs20_denoising_nototclip.pkl\")\n",
    "path_1 = Path(\"sst_large/stats_sst2_roberta-large_silvery-waterfall-811_epochs20_denoising_nototclip.pkl\")\n",
    "path_101 = Path(\"sst_large/stats_sst2_roberta-large_lucky-glade-812_epochs20_denoising_nototclip.pkl\")\n",
    "path_102 = Path(\"sst_large/stats_sst2_roberta-large_lunar-pine-813_epochs20_denoising_nototclip.pkl\")\n",
    "path_105 = Path(\"sst_large/stats_sst2_roberta-large_ancient-moon-814_epochs20_denoising_nototclip.pkl\")\n",
    "path_110 = Path(\"sst_large/stats_sst2_roberta-large_driven-sunset-815_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": 3,
   "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": 7,
   "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 = {kappa: stat[\"positive_improvements\"] for kappa, stat in kappa_swipe.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "17dda95d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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nLS0NAAWLlzIrl27iImJYdiwYTz++OMYhgFAXFwcixYtYvr06QU2PhEREREpeIU6Kb5+/Tqff/45M2fOpHXr1lSvXp0pU6ZQvXp1FixYgGEYzJkzh5deeonu3bvToEEDPvroI86ePcvq1asBiI2NpVu3btStW5eIiAguXLjAxYsXARgxYgSvv/463t7eBThKERERESlohTopvnHjBmazGTc3N6tyd3d3tm7dSlxcHPHx8XTs2NFS5+PjQ7NmzYiJiQEgJCSErVu3cv36daKioggICKBMmTKsWLECNzc3evbsma9jEhEREZHCx6mgA7iTEiVKEBoayrRp06hduzZ+fn588sknxMTEUL16deLj4wHw8/OzOs/Pz89SN2jQIPbv30+dOnUoU6YMK1eu5PLly0yaNIno6GheeuklPv30U6pVq8aHH35I+fLlc4wlPT2d9PR0qzJXV1dcXV3zYOQiIiIikp8K9UwxwPLlyzEMg/Lly+Pq6so777zDY489hoND7kJ3dnZm3rx5xMXF8csvv9CyZUvGjx/P6NGj2bNnD6tXr2bfvn00b96c0aNH37afGTNm4OPjY3XMmDHDXsMUERERkQJU6JPiatWqsXnzZq5evcqpU6f4+eefyczMpGrVqvj7+wOQkJBgdU5CQoKl7q82bdrEwYMHGTlyJNHR0XTp0gVPT0/69u1LdHT0beOYOHEiycnJVsfEiRPtNk4RERERKTiFPim+xdPTk4CAAC5fvkxUVBTdu3cnKCgIf39/NmzYYGmXkpLCjh07CA0NzdZHWloaERERvP/++zg6OmI2m8nMzAQgMzMTs9l82+u7urri7e1tdWjphIiIiMi9odAnxVFRUaxZs4a4uDjWrVtHu3btqFWrFgMHDsRkMjFmzBheffVVvv76a3799VeeeuopAgMD6dGjR7a+pk2bRpcuXWjUqBEAYWFhfPHFF+zfv5+5c+cSFhaWz6MTERERkcKgUD9oB1iWKZw+fZpSpUrRu3dvpk+fjrOzMwATJkwgNTWVYcOGkZSURMuWLVmzZk22HSsOHDjAypUr2bt3r6XskUceITo6mlatWlGzZk0iIyPzc2giIiIiUkgU+qS4b9++9O3b97b1JpOJqVOnMnXq1Dv2U69ePas33QE4ODgwf/585s+fb5dYRURERKRoKvTLJ0RERERE8pqSYhEREREp9pQUi4iIiEixp6RYRERERIo9JcUiIiIiUuwpKRYRERGRYk9JsYiIiIgUe0qKRURERKTYszkp3r17N7/++qvl81dffUWPHj144YUXyMjIsGtwIiIiIiL5weak+JlnnuHw4cMAHD9+nH79+uHh4cGqVauYMGGC3QMUEREREclrNifFhw8fpmHDhgCsWrWK1q1bExkZydKlS/n888/tHZ+IiIiISJ6zOSk2DIOsrCwA1q9fT5cuXQCoWLEiFy9etG90IiIiIiL5wOakuEmTJrz66qssX76czZs389BDDwEQFxeHn5+f3QMUEREREclrNifFb731Frt372bkyJG8+OKLVK9eHYD//e9/tGjRwu4BioiIiIjkNSdbTwgJCbHafeKWWbNm4eRkc3ciIiIiIgXO5pniqlWrcunSpWzlaWlpBAcH2yUoEREREZH8ZHNS/Mcff2A2m7OVp6enc/r0absEJSIiIiKSn3K93uHrr7+2/BwVFYWPj4/ls9lsZsOGDQQFBdk3OhERERGRfJDrpLhHjx4AmEwmBgwYYFXn7OxMlSpVePPNN+0anIiIiIhIfsh1Unxrb+KgoCB++eUXypQpk2dBiYiIiIjkJ5vXFMfFxeVbQmw2m3n55ZcJCgrC3d2datWqMW3aNAzDsLQxDINJkyYREBCAu7s7HTt25MiRI5b69PR0nnzySby9vQkODmb9+vVW15g1axajRo3Kl/GIiIiISOF0V3uobdiwgQ0bNnD+/HnLDPItH374oV0CA3j99ddZsGABy5Yto27duuzcuZOBAwfi4+PD6NGjAZg5cybvvPMOy5YtIygoiJdffpnw8HB+++033NzcWLhwIbt27SImJoYffviBxx9/nISEBEwmE3FxcSxatIidO3faLWYRERERKXpsTopfeeUVpk6dSpMmTQgICMBkMuVFXAD89NNPdO/e3fLWvCpVqvDJJ5/w888/AzdniefMmcNLL71E9+7dAfjoo4/w8/Nj9erV9OvXj9jYWLp160bdunWpWrUqzz33HBcvXqRs2bKMGDGC119/HW9v7zwbg4iIiIgUfjYnxe+99x5Lly7lySefzIt4rLRo0YKFCxdy+PBhgoOD2bdvH1u3bmX27NnAzaUc8fHxdOzY0XKOj48PzZo1IyYmhn79+hESEsLy5cu5fv06UVFRBAQEUKZMGVasWIGbmxs9e/bMVSzp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kydPZu/evfz222+ULVuWESNG8P3337N06VK8vb0ZNWoUAD/99FO2vvr3709oaCgjR44Ebj5st3LlSpYvX8748eMJCgpi3rx5do3f3s5NfrSgQyiSAl75zG596R7cHXveA4B6X35p1/6KiwM9e9qtL92Du6N7UPDseQ9A9+Fu2fs+2MNd7cLcv39/+vfvz7Vr17h69SrlypWzd1wAnD59mscee4xLly5RtmxZWrZsyfbt2ylb9ub6l7feegsHBwd69+5Neno64eHhzJ8/P1s/UVFRHD16lOXLl1vKRo4cyc6dO2nWrBlNmzZl8uTJeTIGERERESn8bE6KX331Vfr3709QUBAeHh54eHjkRVwAfPrpp3esd3NzY968eX87wxseHk54eLhVmYeHBytXrvzHMYqIiIhI0WfzopBVq1ZRvXp1WrRowfz587l48WJexCUiIiIikm9sTor37dvH/v37adu2LW+88QaBgYE89NBDREZGcu3atbyIUUREREQkT93V44N169bltdde4/jx42zatIkqVaowZsyY226FJiIiIiJSmP3jPTU8PT1xd3fHxcXFssWZiIiIiEhRcldJcVxcHNOnT6du3bo0adKEPXv28Morr1herywiIiIiUpTYvPtE8+bN+eWXX2jQoAEDBw7kscceo3z58nkRm4iIiIhIvrA5Ke7QoQMffvghderUyYt4RERERETync1J8fTp0/MiDhERERGRApOrpHjcuHFMmzYNT09Pxo0bd8e2s2fPtktgIiIiIiL5JVdJ8Z49eyw7S+zZsydPAxIRERERyW+5Soo3bdqU488iIiIiIvcCm7dkGzRoEFeuXMlWnpqayqBBg+wSlIiIiIhIfrI5KV62bBnXr1/PVn79+nU++ugjuwQlIiIiIpKfcr37REpKCoZhYBgGV65cwc3NzVJnNpv5/vvvKVeuXJ4EKSIiIiKSl3KdFPv6+mIymTCZTAQHB2erN5lMvPLKK3YNTkREREQkP+Q6Kd60aROGYdC+fXs+//xzSpUqZalzcXGhcuXKBAYG5kmQIiIiIiJ5KddJcZs2bQCIi4ujUqVKmEymPAtKRERERCQ/5Sop3r9/P/Xq1cPBwYHk5GR+/fXX27Zt0KCB3YITEREREckPuUqKGzZsSHx8POXKlaNhw4aYTCYMw8jWzmQyYTab7R6kiIiIiEheytWWbHFx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cXHGtm3bjI4dOxplypQxzp8/n+/jKwpsvQeGYVjaN27c2Hj88ceNPXv2GAcPHrTU63d1dkqKJVfeffddo1KlSoaLi4vRtGlTY/v27Za6Nm3aGAMGDLBqv3LlSiM4ONhwcXEx6tata3z33Xf5HPG9ZdOmTQaQ7bj1vQ8YMMBo06ZNtnMaNmxouLi4GFWrVjWWLFmS73EXZXnxnf9dn2ItL+5BTv0B+u/jDvLiPjz66KNGQECA4eLiYpQvX9549NFHjaNHj+bPgIqgu7kHObWvXLmyVRv9rrZmMgzDyIMJaBERERGRIkNrikVERESk2FNSLCIiIiLFnpJiERERESn2lBSLiIiISLGnpFhEREREij0lxSIiIiJS7CkpFhEREZFiT0mxiIiIiBR7SopFREREpNhTUiwiIn+rbdu2jBkzpqDDEBHJM0qKRURERKTYU1IsIiIiIsWekmIRkSImKSkJk8nEtm3bADh69Ci1atXipZdewjAMq7YLFy4kMDCQrKwsq/Lu3bszaNAgANasWUPLli3x9fWldOnSPPzwwxw7duyOMVSpUoU5c+ZYlTVs2JApU6YAkJWVxYwZMwgKCsLd3Z2QkBD+97///YNRi4jkLSXFIiJFzP79+zGZTISEhLB161batGnDCy+8wKuvvorJZLJq26dPHy5dusSmTZssZYmJiaxZs4b+/fsDkJqayrhx49i5cycbNmzAwcGBnj17ZkukbTFjxgw++ugj3nvvPQ4ePMjYsWN54okn2Lx58133KSKSl5wKOgAREbHNvn37qFatGl999RUTJkzgk08+oXXr1jm2LVmyJJ07dyYyMpIOHToA8L///Y8yZcrQrl07AHr37m11zocffkjZsmX57bffqFevns3xpaen89prr7F+/XpCQ0MBqFq1Klu3buX999+nTZs2NvcpIpLXNFMsIlLE7Nu3j/j4eJ5++mn8/f1vmxDf0r9/fz7//HPS09MBWLFiBf369cPB4eavgCNHjvDYY49RtWpVvL29qVKlCgAnT568q/iOHj3KtWvXeOCBB/Dy8rIcH3300d8uyxARKSiaKRYRKWL27dtHkyZNePXVV2nVqhWrV6+mR48et23ftWtXDMPgu+++4/777+fHH3/krbfesqqvXLkyixYtsqw/rlevHhkZGbft08HBIdv65czMTACuXr0KwHfffUf58uWt2ri6uto6XBGRfKGkWESkCDGbzRw4cIDPPvuMsLAwHnnkEaZMmUL37t2zrSe+xc3NjV69erFixQqOHj1KzZo1ue+++wC4dOkShw4dYtGiRbRq1QqArVu3/m0cZcuW5dy5c5bPKSkpxMXFAVCnTh1cXV05efKklkqISJGhpFhEpAg5fPgwaWlpNGzYEICXX36ZkJAQPv/8cx555JHbnte/f38efvhhDh48yBNPPGEpL1myJKVLl2bhwoUEBARw8uRJnn/++b+No3379ixdupSuXbvi6+vLpEmTcHR0BKBEiRL8+9//ZuzYsWRlZdGyZUuSk5PZtm0b3t7eDBgw4J99CSIieUBJsYhIEbJv3z58fX2pVKkSAPXr16dXr15MmTKFXr16WdYJ/1X79u0pVaoUhw4d4vHHH7eUOzg48OmnnzJ69Gjq1atHzZo1eeedd2jbtu0d45g4cSJxcXE8/PDD+Pj4MG3aNMtMMcC0adMoW7YsM2bM4Pjx4/j6+nLffffxwgsv/PMvQUQkD5iMvy4KExEREREpZrT7hIiIiIgUe0qKRURERKTYU1IsIiIiIsWekmIRERERKfaUFIuIiIhIsaekWERERESKPSXFIiIiIlLsKSkWERERkWJPSbGIiIiIFHtKikVERESk2FNSLCIiIiLFnpJiERERESn2/h+HMkYv9UFNbQAAAABJRU5ErkJggg==",
      "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 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": "61b61b46",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
