{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": 11,
   "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_base/stats_mnli_roberta-base_solar-donkey-804_epochs20_denoising_nototclip.pkl\")\n",
    "path_1 = Path(\"mnli_base/stats_mnli_roberta-base_blooming-field-799_epochs20_denoising_nototclip.pkl\")\n",
    "path_101 = Path(\"mnli_base/stats_mnli_roberta-base_eternal-donkey-800_epochs20_denoising_nototclip.pkl\")\n",
    "path_102 = Path(\"mnli_base/stats_mnli_roberta-base_dashing-yogurt-801_epochs20_denoising_nototclip.pkl\")\n",
    "path_105 = Path(\"mnli_base/stats_mnli_roberta-base_toasty-serenity-802_epochs20_denoising_nototclip.pkl\")\n",
    "path_110 = Path(\"mnli_base/stats_mnli_roberta-base_splendid-snowball-803_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": 12,
   "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": 13,
   "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": 14,
   "id": "17dda95d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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UOd/+yOLiEiBsjspjo6O5qOPPuKRRx6xljVs2JBKlSrx1FNPKSkWERERkWLH7t/Nmc1mqlatmqs8JCQENzc3R8QkIiIiIlKg7E6Khw4dypQpU8jMzLSWZWZmMnXqVIYOHerQ4ERERERECoLdyyf27NnDhg0bqFixIqGhoQDs27ePrKws2rVrR7du3axtP/30U8dFKiIiIiKST+xOin19fenevbtNWaVKeuuSiIiIiBRfdifFixcvzo84REREREQKjTbBFBEREZEST0mxiIiIiJR4SopFREREpMRTUiwiIiIiJV6ekuKyZcty7tw5APr378+lS5fyNagb5s2bR8OGDfH29sbb25uwsDC++eYba31GRgaRkZGUK1cOLy8vunfvTnJysrX+woULdOrUCS8vLxo3bsyePXts+o+MjOStt94qkLGIiIiISNGVp6Q4KyuLtLQ0AJYuXUpGRka+BnVDxYoV+fe//82uXbvYuXMnbdu2pUuXLhw6dAiAkSNH8uWXX7J69Wo2b97M77//brNP8tSpU7l06RK7d++mTZs2vPDCC9a67du3s2PHDkaMGFEgYxERERGRoitPW7KFhYXRtWtXmjRpgmEYDB8+HA8Pj5u2XbRokcOC69Spk83nqVOnMm/ePLZv307FihVZuHAh0dHRtG3bFri+XVydOnXYvn07zZs3Jz4+nl69elGzZk0GDhzI/PnzAcjOzmbw4MF88MEHODs7OyxeERERESme8jRT/OGHH9KxY0cuX76MyWQiNTWVixcv3vTILxaLhY8++ogrV64QFhbGrl27yM7Opn379tY2tWvXpnLlysTFxQEQGhrKxo0buXbtGjExMTRs2BCAadOm0aZNG5o2bZpv8YqIiIhI8ZGnmeKAgAD+/e9/AxASEsLy5cspV65cvgZ2w4EDBwgLCyMjIwMvLy8+++wz6taty969e3Fzc8PX1zdXrElJSQCMHTuWIUOGUL16dapWrcrChQs5evQoS5cuJS4ujsGDB7Nu3TqaNm3KggUL8PHxuWUcmZmZZGZm2pSZzWbMZrPDxywiIiIiBcvu3ScSEhIKLCEGqFWrFnv37mXHjh0MGTKEvn378tNPP+XpXB8fH6Kjozl58iSbN2+mbt26DBo0iOnTp7NixQpOnDjB4cOH8fT0ZPLkybftKyoqCh8fH5sjKirKEUMUERERkUJ2R1uy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tm7dSnp6OjExMQQFBVG+fHlWrFiBu7s7jz/+eJ6ulZmZSVpams2RmZmZL+MSERERkYJVrJPipKQkAAICAmzKAwICrHX9+/cnNDSUunXrMnXqVFatWsXFixcZP348s2bN4pVXXqFGjRpERETw22+/3fJaUVFR+Pj42BxRUVH5NzgRERERKTBFfvnE3+Xq6pprPXK/fv0YPnw4e/bsYc2aNezbt49p06YxfPhwPvnkk5v2M27cOEaNGmVTZjab8y1uERERESk4xXqmODAwEIDk5GSb8uTkZGvdn23atIlDhw4xdOhQYmNj6dixI6VKlaJnz57Exsbe8lpmsxlvb2+bQ0mxiIiIyN2hWCfFISEhBAYGsmHDBmtZWloaO3bsICwsLFf7jIwMIiMjef/993F2dsZisZCdnQ1AdnY2FoulwGIXERERkaKjyCfFly9fZu/evezduxe4/nDd3r17OXXqFCaTiREjRvDaa6/xxRdfcODAAZ599lmCg4Pp2rVrrr6mTJlCx44dady4MQDh4eF8+umn7N+/n9mzZxMeHl6AIxMRERGRoqLIryneuXMnDz74oPXzjXW9ffv2ZcmSJYwZM4YrV64wcOBAUlJSaNmyJWvXrsXd3d2mn4MHD7Jq1Sprcg3wxBNPEBsbS6tWrahVqxbR0dEFMiYRERERKVqKfFLcpk0b68s2bsZkMjF58mQmT558237q169v86Y7ACcnJ+bOncvcuXMdEquIiIiIFE9FfvmEiIiIiEh+U1IsIiIiIiWekmIRERERKfGUFIuIiIhIiaekWERERERKPCXFIiIiIlLiKSkWERERkRJPSbGIiIiIlHhKikVERESkxFNSLCIiIiIlnpJiERERESnxlBSLiIiISImnpFhERERESjwlxSIiIiJS4ikpFhEREZEST0mxiIiIiJR4SopFREREpMRTUiwiIiIiJZ6SYhEREREp8e6apHjOnDlUrVoVd3d3mjVrxg8//GCtGzVqFGXLlqVSpUqsWLHC5rzVq1fTqVOngg5XRERERIoQl8IOwBE+/vhjRo0axXvvvUezZs2YOXMmERERHD58mB07dhAdHc26des4evQo/fv3JyIigvLly5OamsrLL7/M+vXrC3sIIiIiIlKI7oqZ4hkzZvDCCy/Qr18/6taty3vvvYenpyeLFi0iPj6eNm3a0LRpU5566im8vb1J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",
      "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 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
}
